一、Zuul 是netflix开源的一个API Gateway 服务器, 本质上是一个web servlet应用。
Zuul 在云平台上提供动态路由,监控,弹性,安全等边缘服务的框架。Zuul 相当于是设备和 Netflix 流应用的 Web 网站后端所有请求的前门。
Zuul的例子可以参考 netflix 在github上的 simple webapp,可以按照netflix 在github wiki 上文档说明来进行使用。
二、在实践Zuul之前,为了将前面学习的再进行巩固,同时不跟前面的项目冲突,这里开始创建一个zuul项目,按照前面所学,重新搭建一个项目。
先新建一个空Maven项目。
- 新建module:zuul_server ,端口:8000,添加eurekaServer依赖,注解开启eureka server功能。
- 新建module:zuul_eureka_client, 端口:8001,注册到eureka-server,添加eurekaClient依赖,注解开启eureka client功能
在启动类添加一个hi方法,返回一个字符串。 - 新建module: zuul_cloud_client, 端口:9000,注册到eureka-server,添加eurekaClient、zuul依赖,注册开启eureka client、zuul功能。
zuul项目需要添加以下依赖:同时需要添加 @EnableEurekaClient、@EnableZuulProxy 依赖开启功能
添加application.yaml配置:<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-zuul</artifactId> </dependency>
这里配置了网关程序端口为9000,同时作为eureka客户端的配置,配置了zuul路由,当前只配置了zuul-eureka-client的路由,serviceId为用用程序的标识,path为自定义路由转发路径,"hiapi"为自定义路径,可以修改。server: port: 9000 spring: application: name: zuul-cloud-client eureka: instance: hostname: zuul-cloud-client client: service-url: defaultZone: http://zuul-server:8000/eureka zuul: routes: hiapi: path: /hiapi/** serviceId: zuul-eureka-client
如:http://localhost:8001/hi 就等于 http://localhost:9000/hiapi/hi
也就是通过网关访问的并且开头为hiapi的url都会被分发到zuul-eureka-client服务。
如果服务存在多个实例,zuul结合Ribbon会做负载均衡,将请求分发到不同实例。
三、依次启动zuul-server、zuul-eureka-client、zuul-cloud-client .
在浏览器输入:http://localhost:8001/hi 可以看到正常访问,这是zuul-eureka-client的直接访问结果
在浏览器输入:http://localhost:9000/hiapi/hi
可以看到通过网关访问hiapi/hi 的请求 被分发到 zuul-eureka-client 服务。