SpringCloud网关组件Zuul的简单使用
zuul简介
Zuul是Netflix开源的微服务网关,它可以和Eureka、Ribbon、Hystrix等组件配合使用。Zuul的核心是一系列的过滤器,这些过滤器帮助我们完成以下功能:
- 身份认证与安全:识别每个资源的验证要求,并拒绝那些与要求不符的请求;
- 审查与监控:在边缘位置追踪有意义的数据和统计结果,从而为我们带来精确的生产视图;
- 动态路由:动态地将请求路由到不同的后端集群;
- 压力测试:逐渐增加指向集群的流量,以了解性能;
- 负载分配:为每一种负载类型分配对应容量,并弃用超出限定值的请求;
- 多区域弹性:跨越AWS Region进行请求路由,旨在实现ELB(Elastic Load Balancing)使用的多样化;以及让系统的边缘更贴近系统的使用者。
Spring Cloud对Zuul进行了整合与增强。目前,Zuul使用的默认HTTP客户端是Apache HTTP Client,也可以使用RestClient或者okhttp3.OkHttpClient 。 如果想要使用RestClient,可以设置ribbon.restclient.enabled=true ;想要使用okhttp3.OkHttpClient ,可以设置ribbon.okhttp.enabled=true
一个zuul入门的简单示例
创建zuul网关服务zx-zuul
引入主要依赖
<dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-netflix-zuul</artifactId> </dependency> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-actuator</artifactId> </dependency>
bootstrap.yml主要配置信息
spring: application: name: zx-zuul
application.yml配置信息
server: port: 8010 logging: config: classpath:logback.xml #注册到注册中心的相关配置 eureka: client: healthcheck: enabled: true service-url: defaultZone: http://zxdemo:zxdemopwd@127.0.0.1:8002/eureka/ instance: prefer-ip-address: true ip-address: 127.0.0.1 #网关相关配置 zuul: routes: # 定义路由id,随意写,但是多ID不要重复 zx-ribbon-service: # 匹配的路由规则 path: /api-ribbon/** # 路由的目标服务名 serviceId: zx-ribbon-service
启动类
@SpringBootApplication @EnableEurekaClient @EnableZuulProxy public class ZuulApplication { public static void main(String[] args) { SpringApplication.run(ZuulApplication.class, args); } }
启动注册中心和一个服务
基于前几课的打下的基础,这里我们直接启动之前的注册中心(不清楚注册中心eureka搭建的),注册中心启动好之后,然后启动zx-ribbon-service服务(服务的搭建可参考),都启动好之后,如图: