SpringCloud 集成网关Zuul
Zuul简介
1.zuul是Netflix开源的一个APIGateway服务器,本质是一个web应用;
2.Zuul是开源提供动态链路,监控,弹性,安全等边缘服务的框架;
3.Zuul相当于是服务和所有web请求的大门
官方说明文档
https://github.com/Netflix/zuul/wiki
集成示例:
1.pom导入依赖
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-hystrix</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-zuul</artifactId>
</dependency>
2.启动类
@SpringBootApplication
//
@EnableZuulProxy
@EnableDiscoveryClient
public class LearnZuulApplication {
public static void main(String[] args) {
SpringApplication.run(LearnZuulApplication.class, args);
}
}
- application配置
server:
port: 7000
spring:
application:
name: zuul-demo
eureka:
client:
service-url:
defaultZone: http://localhost:8761/eureka
#####
##网关配置
zuul:
host:
##代理普通的http请求 连接超时时间
connect-timeout-millis: 2000
# socket超时时间
socket-timeout-millis: 1000
# 最大连接200
max-total-connections: 200
# 每个地址最大连接数
max-per-route-connections: 20
#信号量 模式
ribbon-isolation-strategy: semaphore
semaphore:
#最大的信号量数
max-semaphores: 100
# 路由
routes:
route1:
# 代理路径 http://localhost:7000/test1/client1 即转到 http://localhost:8081/client1
path: /test1/**
url: http://localhost:8081
route2:
# http://localhost:7000/test2/client_1 代理路径 http://localhost:8081/client_1
path: /test2/**
serviceId: helloserver
user-token:
path: /token/byPhone
serviceId: user-demo
# 忽略services
ignored-services: helloserver
study:
zuul:
token-filter:
noAuthenticationRoutes: user-token
token:
jwt:
key: kkk123
iss: 11
expm: 10
#容错机制 资源隔离模式下默认是信号量
hystrix:
command:
execution:
timeout:
enabled: true
isolation:
thread:
timeoutInmilliseconds: 100
zuul执行流程
ZuulServlet/ZuulServletFilter
preRoute() //前置
route() //中置
postRoute() // 返回结果
error() //
URL请求的拦截
data:image/s3,"s3://crabby-images/894f7/894f78d71bb16e7bc2d393c86eaa7c5c4448633f" alt=""
循环处理filter
data:image/s3,"s3://crabby-images/adc40/adc40cca2ce8969a2057d89363e0abd23d545a95" alt=""
data:image/s3,"s3://crabby-images/2e078/2e078807f26e1fb13537a1cdd4f50f7eefc871e2" alt=""
data:image/s3,"s3://crabby-images/ea0e3/ea0e3e4edb394234ceb264471c58bb325809453b" alt=""
data:image/s3,"s3://crabby-images/4db34/4db3451d9d9e964e5eaf3ff899cf822f5266de4d" alt=""
处理单个的filter
data:image/s3,"s3://crabby-images/4a938/4a93847f0defc9884efaa5465b63e0a2e00522f9" alt=""
IZuulFilter 下的所有Filter实现类
data:image/s3,"s3://crabby-images/f48a4/f48a4a08634c9adb49ed9dd7533e87d24ce6a347" alt=""
serviceId 的拦截
Ribbon转发
data:image/s3,"s3://crabby-images/10962/10962d5e653aef9f16b192599e54df20a3c6ccce" alt=""
data:image/s3,"s3://crabby-images/88b14/88b145d32e7111fbe5375c982ff38e3be74fda5e" alt=""
获取serviceId,创建转发对象HttpClient
data:image/s3,"s3://crabby-images/8e93d/8e93d1091cc35a64b55f1cb21876de26e3d8c0a6" alt=""
发起请求
data:image/s3,"s3://crabby-images/306ae/306ae6a7db8e0de59b14aacf71c8125e0401c48f" alt=""
ZuulServerAutoConfiguration
FilterRegistrationBean
data:image/s3,"s3://crabby-images/57f21/57f2187e9e67f92de3d16fe40f0d3f5f67f6a659" alt=""
data:image/s3,"s3://crabby-images/f5205/f52055c367f0376db5dade1ac4200b106e992d61" alt=""
网友评论