微服务 feign-gateway

早期微服务跨集群调用 使用的是Eureka 和RestTemplate,这种写法虽然可以解决服务之间的调用问题 ,但是随着服务的增多,实例变动,早期的写法相当于把请求方式,请求地址,参数写死了,耦合度太高,参数非常多的情况使用起来不方便。

Feign

Feign是一种声明式的 ,模板客户端,可以使用类似于SpringMvc风格的注解,更加方便的实现服务之间 的调用。

如何使用?

首先你肯定需要导入依赖 这里直接去导入SpringCloud的起步依赖

复制代码
<dependency> 
<groupId>org.springframework.cloud</groupId>  
<artifactId>spring-cloud-starter-openfeign</artifactId>
</dependency>

然后在服务调用者的启动类上开启Feign

会发现它是基于接口的 风格和以SpringMVC的风格相似

那么你只需要通过Feign客户端调用方法 他就可以返回对应的返回值类型 非常方便

如何配置Feign 这里只给出

日志的配置

日志级别

  1. NONE:没有日志记录

  2. BASIC:记录请求方法、URL以及响应状态代码和执行时间

  3. HEADERS:记录基本信息以及请求和响应头信息

  4. FULL:记录基本信息以及请求和响应头信息、请求和响应体信息

Feign性能优化:

1.Feign使用的是默认的UrlConection

可以修改为 连接池 Apache提供的HttpClient,或者是OKHttp

2.修改日志级别,因为日志也是比较消耗性能,如果日志级别是Full,那就输出全部日志信息,修改为None又不太合适,什么都不输出还要日志干什么。所以推荐使用的是Basic.

Feign最佳实践方案:

经过市场的实践与检验,给出了两种最佳实践。

1.继承

通过定义统一Api接口 服务的调用者Feign客户端可以继承api类,但是无法继承接口的参数,需要自己重新写。

服务的提供者可以实现接口,重写业务逻辑。

但是这样会造成紧耦合。

并且官方也不推荐这样做。

2.方式二(抽取):将FeignClient抽取为独立模块,并且把接口有关的POJO、默认的Feign配置都放到这个模块中,提供给所有消费者使用,

GateWay网关

利用nacos实现了微服务的配置 注册发现 解决了服务间的统一调度,利用Feign实现了服务调用,但是对于客户端请求,以及服务响应就必须使用网关。

SpringCloud实现网关的方式有

zuul gateway

Zuul使用的是阻塞式编程,学过Io流,大家应该知道,阻塞式编程,就是等待请求的过程中,程序会一直等待直到完成,等待过程中不做任何事。

GateWay使用响应式编程,性能更好。

网关路由配置:

复制代码
server:
  port: 10010
logging:
  level:
    cn.itcast: debug
  pattern:
    dateformat: MM-dd HH:mm:ss:SSS
spring:
  application:
    name: gateway
  cloud:
    nacos:
      server-addr: nacos:8848 # nacos地址
    gateway:
      routes:
        - id: user-service # 路由标示,必须唯一
          uri: lb://userservice # 路由的目标地址
          predicates: # 路由断言,判断请求是否符合规则
            - Path=/user/** # 路径断言,判断路径是否是以/user开头,如果是则符合
        - id: order-service
          uri: lb://orderservice
          predicates:
            - Path=/order/**
      default-filters:
        - AddRequestHeader=Truth,hhhhhhhhhhhhhh!

过滤器:

GatewayFilter是网关中提供的一种过滤器,可以对进入网关的请求和微服务返回的响应做处理:

单个路由下都可以配置自己的filter,也可以配置Defaultfilter为所有路由配置

或者是配置全局路由,需实现路由接口。

网关跨域配置

相关推荐
HalvmånEver几秒前
7.高并发内存池大页内存申请释放以及使用定长内存池脱离new
java·spring boot·spring
凤山老林7 分钟前
SpringBoot 使用 H2 文本数据库构建轻量级应用
java·数据库·spring boot·后端
dreamread1 小时前
【SpringBoot整合系列】SpringBoot3.x整合Swagger
java·spring boot·后端
把你毕设抢过来1 小时前
基于Spring Boot的社区智慧养老监护管理平台(源码+文档)
数据库·spring boot·后端
闻哥2 小时前
深入Redis的RDB和AOF两种持久化方式以及AOF重写机制的分析
java·数据库·spring boot·redis·spring·缓存·面试
小小unicorn2 小时前
[微服务即时通讯系统]消息转发子服务的实现与测试
微服务·云原生·架构
毕设源码_廖学姐4 小时前
计算机毕业设计springboot古诗词学习App 基于SpringBoot的中华经典诗文数字化研习平台 SpringBoot框架下的传统诗词文化移动学习系统
spring boot·学习·课程设计
爱吃山竹的大肚肚6 小时前
RocketMQ 4.x + Spring Boot 生产级集成方案(完整笔记)
spring boot·rocketmq·java-rocketmq
毕设源码_严学姐6 小时前
计算机毕业设计springboot心理健康辅导系统 高校学生心灵关怀服务平台的设计与实现 校园智慧心理服务系统的设计与实现
spring boot·后端·课程设计
姗姗的鱼尾喵7 小时前
Java 面试内容分享
java·spring boot·面试