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服务(服务的搭建可参考),都启动好之后,如图:
