首页 > 其他分享 >day02

day02

时间:2024-07-25 15:53:43浏览次数:8  
标签:网关 day02 配置 nacos 路由 public cloud

使用OpenFeign依赖

openfeign用于远程服务调用,通常与负载均衡插件loadbalancer一起使用

连接池

Feign底层发起http请求,依赖于其它的框架。其底层支持的http客户端实现包括:

  • HttpURLConnection:默认实现,不支持连接池
  • Apache HttpClient :支持连接池
  • OKHttp:支持连接池

通常使用带连接池的客户端来替代默认的客户端

OKHttp为例:

  1. 引入pom依赖
<!--OK http 的依赖 -->
<dependency>
  <groupId>io.github.openfeign</groupId>
  <artifactId>feign-okhttp</artifactId>
</dependency>
  1. 在yaml文件配置开启连接池,默认关闭
feign:
  okhttp:
    enabled: true # 开启OKHttp功能
  1. 重启服务,连接池生效

配置openfeign的日志输出

OpenFeign只会在FeignClient所在包的日志级别为DEBUG时,才会输出日志。而且其日志级别有4级:

  • NONE:不记录任何日志信息,这是默认值。
  • BASIC:仅记录请求的方法,URL以及响应状态码和执行时间
  • HEADERS:在BASIC的基础上,额外记录了请求和响应的头信息
  • FULL:记录所有请求和响应的明细,包括头信息、请求体、元数据。

Feign默认的日志级别就是NONE,所以默认我们看不到请求日志。

  1. 定义日志级别

新建一个配置类,添加@Bean方法,返回值为openfeign日志级别的枚举变量

package com.hmall.api.config;

import feign.Logger;
import org.springframework.context.annotation.Bean;

public class DefaultFeignConfig {
    @Bean
    public Logger.Level feignLogLevel(){
        return Logger.Level.BASIC;
    }
}

  1. 配置日志生效

有两种方式:

  • 局部生效:在某个FeignClient中配置,只对当前FeignClient生效
@FeignClient(value = "item-service", configuration = DefaultFeignConfig.class)
  • 全局生效:在@EnableFeignClients中配置,针对所有FeignClient生效。
@EnableFeignClients(basePackages = "com.hmall.api.client", defaultConfiguration = DefaultFeignConfig.class)

网关

利用网关,可以用于用户请求的转发和负载均衡,比如用户所有请求均通过8080发出,经过网关路由转发到对应的微服务的对应节点

创建一个网关分为以下步骤:

  • 创建网关微服务
  • 引入SpringCloudGateway、NacosDiscovery依赖
  • 编写启动类
  • 配置网关路由

创建网关

  1. 创建网关微服务模块

  2. 引入SpringCloudGateway、NacosDiscovery依赖

<dependencies>
	<!--网关-->
    <dependency>
        <groupId>org.springframework.cloud</groupId>
        <artifactId>spring-cloud-starter-gateway</artifactId>
    </dependency>
    <!--nacos discovery-->
    <dependency>
        <groupId>com.alibaba.cloud</groupId>
        <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
    </dependency>
    <!--负载均衡-->
    <dependency>
        <groupId>org.springframework.cloud</groupId>
        <artifactId>spring-cloud-starter-loadbalancer</artifactId>
    </dependency>
</dependencies>
  1. 创建启动类
@SpringBootApplication
public class GatewayApplication {
    public static void main(String[] args) {
        SpringApplication.run(GatewayApplication.class);
    }
}
  1. 编写路由配置
server:
  port: 8080
spring:
  application:
    name: gateway-server
  cloud:
    nacos:
      server-addr: 192.168.48.100:8848
    gateway:
      routes:
        - id: item-service  # 路由名称:item-service
          uri: lb://item-service  # 负载均衡转发到指定服务
          predicates: # 路由断言,配置路由-服务命中的条件
            - Path=/items/**,/search/** # 这里通过请求路径前缀判断
          filters:	# 局部路由过滤器,可设置多个过滤器
            - filter1=xxx
        - id: item-service  # 路由名称:user-service
          uri: lb://user-service
          predicates:
            - Path=/users/**,/addresses/**
      default-filters:	# 全局路由过滤器,与routes同级

自定义过滤器

  • 网关请求处理流程
image-20240525171019984

网关过滤器链中的过滤器有两种:

  • GatewayFilter:路由过滤器,作用范围比较灵活,可以是任意指定的路由Route.
  • GlobalFilter:全局过滤器,作用范围是所有路由,不可配置。
  1. 自定义GlobalFilter

自定义GlobalFilter需要实现GlobalFilter, Ordered(用于指定过滤器优先级)接口

@Component
public class PrintAnyGlobalFilter implements GlobalFilter, Ordered {
    @Override
    public Mono<Void> filter(ServerWebExchange exchange, GatewayFilterChain chain) {
        // 编写过滤器逻辑
    }

    @Override
    public int getOrder() {
        // 过滤器执行顺序,值越小,优先级越高
        return 0;
    }
}
  1. 传递信息:网关->微服务

网关传递信息给微服务很简单:

  • 在网关过滤器中将信息添加到请求头
//在网关过滤器中修改请求头的方法
ServerWebExchange newEx = exchange.mutate()
                .request(b -> b.header("user-info", user_info))
                .build();
return chain.filter(newEx);
  • 接着在SpringMVC的拦截器中获取信息并存入ThreadLocal中

这里有一个可能会碰到的错误,如果把该拦截器配置到spring.foctories文件中实现自动装配,那么如果网关引入了该拦截器所在的模块,那么会导致网关缺失MVC依赖错误,因为拦截器是SpringMVC层的,解决方法就是使用条件装配@ConditionalOnClass(DispatcherServlet.class),只在拥有SpringMVC的环境中装配该Bean

  1. 传递信息:微服务->微服务

微服务之间调用是基于OpenFeign来实现的,发起的也是http请求,因此也可以通过请求头携带的方式来传递信息,openfeign提供了一个拦截器接口feign.RequestInterceptor,只需要实现该接口并实现apply方法,然后利用RequestTemplate对象来修改请求头。这样一来,每次OpenFeign发起请求的时候都会调用该方法,传递用户信息。

  • 实现RequestInterceptor以及apply方法
    @Bean
    public RequestInterceptor userInfoRequestInterceptor(){
        return new RequestInterceptor() {
            @Override
            public void apply(RequestTemplate requestTemplate) {
                Long id = UserContext.getUser();
                if (id != null){
                    requestTemplate.header("user-info",id.toString());	//添加请求头
                }
            }
        };
    }

微服务消息传递流程:

image-20240525215334325

配置管理

配置共享

将多个微服务中共同的配置信息抽取到nacos配置文件,由nacos统一管理

实现步骤:

  1. 添加相关依赖
        <!--nacos配置管理-->
        <dependency>
            <groupId>com.alibaba.cloud</groupId>
            <artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
        </dependency>
        <!--读取bootstrap文件-->
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-bootstrap</artifactId>
        </dependency>
  1. 抽取微服务中共同的配置信息到nacos中
image-20240526180555489
  1. 添加bootstrap.yaml文件

由于读取Nacos配置是SpringCloud上下文(ApplicationContext)初始化时处理的,发生在项目的引导阶段。然后才会初始化SpringBoot上下文,去读取application.yaml,所以目前无法读取到nacos地址,也就不能拉去配置信息。但springcloud上下文在初始化时会读取一个bootstrap.yaml文件,可以在其中配置nacos的信息

  • 添加bootstrap.yaml文件
  • 编写配置信息
spring:
  application:
    name: cart-service
  profiles:
    active: dev
  cloud:
    nacos:
      server-addr: 192.168.48.100:8848
      config:
        file-extension: yaml
        shared-configs:
          - dataId: shared-jdbc.yaml
          - dataId: shared-log.yaml
          - dataId: shared-swagger.yaml
  1. 修改application.yaml配置内容,添加相关配置键值对,删除重复配置

配置热启动

nacos支持配置热启动,可无需重启便能修改配置信息

  1. 在nacos中添加配置文件(命名格式有限制),编写配置信息
dataId: [微服务名]-[spring.active.profile].[后缀名]
//配置文件内容
hm:
  cart:
    maxAmount: 1 # 购物车商品数量上限
  1. 在微服务中使用@ConfigurationProperties注解读取配置信息

Nacos动态路由

Nacos可以配置动态路由,将路由信息保存在nacos配置管理中,动态的添加/删除路由信息,不用重启路由服务

使用的依赖:

<!--统一配置管理-->
<dependency>
    <groupId>com.alibaba.cloud</groupId>
    <artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
</dependency>
<!--加载bootstrap-->
<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-bootstrap</artifactId>
</dependency>

通过注入RouteDefinitionWriter(用于更新内存中的路由配置信息)和NacosConfigManager(用于拉取nacos路由配置信息和监听配置信息变化)的bean对象

  • 拉取并监听nacos路由配置信息
String configInfo = nacosConfigManager.getConfigService()
                .getConfigAndSignListener(dataId, group, 5000, new Listener() {
                    @Override
                    public Executor getExecutor() {
                        return null;
                    }

                    @Override
                    public void receiveConfigInfo(String configInfo) {
                        updateConfigInfo(configInfo);
                    }
                });
  • 更新内存路由配置
writer.delete(Mono.just(routeId)).subscribe();	//routeId为String类型
writer.save(Mono.just(routeDefinition)).subscribe();

标签:网关,day02,配置,nacos,路由,public,cloud
From: https://www.cnblogs.com/six-years/p/18323325

相关文章

  • java学习day02
    一.数据类型1.1本质数据存储形式,存储空间大小1.2存储整数存储:1.3分类基本数据类型数值型整型byte字节8bit-128~127short短整型16bit-32768~32767int整型32bit-2,147,483,648~2,147,483,647long长整型64bit浮点型float单浮点32bitdouble双浮......
  • Day02-计算机硬件以及快捷键(电脑基础知识)
    Day02-计算机硬件以及快捷键(电脑基础知识)学习Java第二天,想要学好计算机,最基础也是最能用来装13就是了解电脑的基础知识了!此篇文章依旧是受秦疆老师视频影响,对计算机硬件以及一些基本操作进行了总结在开始之前首先推荐一些电脑必备好用的软件:视频播放器推荐PotPlayer,压......
  • 黑马头条(day02)
     目录1)文章列表加载1.1)需求分析1.2)表结构分析1.3)导入文章数据库1.3.1)导入数据库1.3.2)导入对应的实体类1.4)实现思路1.5)接口定义1.6)功能实现1.6.1)导入微服务1.6.2)编写controller1.6.3)编写service1.6.4)编写mapper1.6.5)配置网关1.6.6)前后端联调测试 2)freemarker......
  • # Day02
    1.#盘符转换2.#查看当前目录下的所有文件dir3.#切换目录cdchangedirectory4.#返回上一级cd..5.#进入目录下的一级文件先用第二步查看目录下的文件然后cd+空格+一级文件名称6.#进入一级文件下的二级文件方法同第五步7.#清理屏幕cls(简记clearscreen)8.#......
  • day02-项目搭建+consul
    1RestTemplateRestTemplate提供了多种便捷访问远程Http服务的方法,是一种简单便捷的访问restful服务模板类,是Spring提供的用于访问Rest服务的客户端模板工具集官网地址:https://docs.spring.io/spring-framework/docs/6.0.11/javadoc-api/org/springframework/web/client/RestTe......
  • python随笔day02
    1.arg元组类型和**kwargs字典类型#元组参数:元组类型数据,对传递参数有顺序要求deftest(*args):print(f"args[0]={args[0]},args[1]={args[1]},args[2]={args[2]}")test(1,2,3)#字典参数:字典类型数据,对传递参数没有顺序要求,格式要求key=value值deftest2(**kwargs):......
  • Day02
    总结Java特性:简单性,面向对象,可移植性(跨平台),高性能,分布式,动态性,多线程,安全性,健壮性单行注释://多行注释:/**/文档注释:JavaDoc:/***/强类型语言:安全性高,速度低,所有变量必须先定义后使用,使用要严格符合规定。数据类型变量名=值;弱类型语言:在JS中运用较多。位bit:数据存储......
  • 苍穹外卖day02
    员工管理,分类管理新增员工产品经理需求分析使用请求post去请求,按照json格式去提交,后端给前端返回resultPath:/admin/employeeMethod:post请求的json就是包含上图表单里面数据返回的数据是后端给前端:**在controller类里面增加方法,然后在service里面增加方法,再在imp......
  • SpingMvc-Day02
    SpringMVC:表述层作用:1.接受前端参数[SpringMVC简化] 2.调用业务逻辑 3.响应前端数据[SpringMVC简化]SpringMVC组件: 1.DispatcherServlet:处理全部请求 2.handlerMapping:缓存handler方法和地址 3.handlerAdapter:适配器、参数和相应简化 4.ViewResovler视图解释器:查找视图页面......
  • Day02基础语法
    基础语法1、注释单行注释//多行注释/**/文档注释2、标识符关键字所有标识符都应该以字母(A-Z,a-z),美元符($),或下划线(_)开始首字母后可以是字母(A-Z,a-z),美元符($),或下划线(_)或数字的任意字符组合不能用关键字作为变量名和方法名标识符大小写敏感可以使用中文命名,但不建......