Zuul
线程阻塞的,所有请求先到zuul,zuul有个线程池,一个请求对应一个线程,线程转发到对应的服务上,得到对应的服务的响应,才会释放,所以效率低
加依赖
创建启动类,加注解@SpringBootApplication @EnableZuulProxy
配置文件 application.properties
#应用名称
spring.application.name=zuul_demo
#应用服务WEB访问端口
server.port=8089
eureka.client.service-url.defaultZone=http://localhost:8761/eureka
#自定义路径,/b会自动找business服务,a 表示两句是一组的可自定义
zuul.routes.a.service-id=business
zuul.routes.a.path=/b/**
#代替上面两行配置,business表服务名
#zuul.routes.business=/b/**
创建类 PermissFilter继承ZuulFilter
重写方法shouldFilter 表是否执行过滤,返回ture,表执行
用netflix的RequestContext
Zuul中的其他配置
有两个服务
zuul.routes.consumer=/consumer/**
zull.routes.consumer-hello=/consumer/hello/**
此时访问一个地址,http://localhost:2020/consumer/hello/123 是希望和第二个匹配的,这时候配置文件必须是.yaml格式,因为此格式是有序的,先匹配先写的,而.properties 是无序的,在这种情况就不能用了
Gateway
异步的,请求到达Gateway,线程会立马将请求分配给子线程完成,让子线程去调服务,然后 线程又可以接受其他请求
功能:限流,路径重写,动态路由,集成spring clound discoveryclient 集成hystrix路由器
导入依赖,Gateway依赖不能和Spring Web 共存,web 用的springmvc 和gateway冲突
配置文件,application.yaml