个人学习SpringCloud系列 Zuul Filter篇
Github Link: https://github.com/panjianlong13/SpringBoot-SpringCloud/tree/master/spring-cloud-zuul-filter
Zuul 核心简介
Zuul 除了转发,动态路由,负载均衡等功能外,还可以用来鉴权、流量转发、请求统计。
Zuul大部分功能都是通过过滤器来实现的,这些过滤器类型对应于请求的典型生命周期
PRE: 这种过滤器在请求被路由之前调用。我们可利用这种过滤器实现身份验证、在集群中选择请求的微服务、记录调试信息等。
ROUTING:这种过滤器将请求路由到微服务。这种过滤器用于构建发送给微服务的请求,并使用Apache HttpClient或Netfilx Ribbon请求微服务。
POST:这种过滤器在路由到微服务以后执行。这种过滤器可用来为响应添加标准的HTTP Header、收集统计信息和指标、将响应从微服务发送给客户端等。
ERROR:在其他阶段发生错误时执行该过滤器。
除了默认的过滤器类型,Zuul还允许我们创建自定义的过滤器类型。例如,我们可以定制一种STATIC类型的过滤器,直接在Zuul中生成响应,而不将请求转发到后端的微服务。
禁用指定的Filter
可以在application.yml中配置需要禁用的filter
zuul:
FormBodyWrapperFilter:
pre:
disable: true
Zuul Filter实战
基于上一篇的Zuul项目进行改造
ZuulFilter
是Zuul中核心组件,通过继承该抽象类,覆写几个关键方法达到自定义调度请求的作用
开启过滤器
@EnableZuulProxy
@SpringBootApplication
public class ZuulApplication {
public static void main(String[] args) {
SpringApplication.run(ZuulApplication.class, args);
}
@Bean
public TokenFilter tokenFilter() {
return new TokenFilter();
}
@Bean
public PasswordFilter PasswordFilter() {
return new PasswordFilter();
}
}
依次开启Eureka Server,Provider-1,Provider-2,Zuul-Filter
访问Eureka 注册中心 http://localhost:8761/
1.无Token测试 http://localhost:8080/
2.有Token无Password测试 http://localhost:8080/?token=peter
3.有Token,Password测试
Zuul高可用
实际使用Zuul的方式如图,不同的客户端使用不同的负载将请求分发到后端的Zuul,Zuul在通过Eureka调用后端服务,最后对外输出。因此为了保证Zuul的高可用性,前端可以同时启动多个Zuul实例进行负载,在Zuul的前端使用Nginx或者F5进行负载转发以达到高可用性。