原创文章,转载请注明原文章地址,谢谢!
Zuul
Zuul是在云平台上提供动态路由,监控,弹性,安全等边缘服务的框架。Zuul相当于是设备和Netflix流应用的Web网站后端所有请求的前门。Zuul包含了对请求的路由和过滤两个最主要的功能。其中路由功能负责将外部请求转发到具体的微服务实例上,是实现外部访问统一入口的基础,而过滤器功能则负责对请求的处理过程进行干预,是实现请求校验、服务聚合等功能的基础。Zuul和Eureka进行整合,将Zuul自身注册为Eureka服务治理下的应用,同时从Eureka中获得其他微服务的消息,也即以后的访问微服务都是通过Zuul跳转后获得。注意Zuul服务最终还是会注册进Eureka。
Zuul配置
新建cloud-zuul-9001模块,并在其pom文件中添加Zuul相关的maven依赖。
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-eureka</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-zuul</artifactId>
</dependency>
在application.yml配置文件中添加Zuul相关的配置。需要说明一点,Zuul自身注册进Eureka中,并从Eureka中获取其它微服务的信息,所以这里需要配置Eureka的注册地址。
server:
port: 9001
spring:
application:
name: cloud-zuul
eureka:
instance:
instance-id: cloud-zuul9001
prefer-ip-address: true
client:
service-url:
defaultZone: http://eureka7001.com:7001/eureka/,http://eureka7002.com:7002/eureka/,http://eureka7003.com:7003/eureka/
在主启动类中添加注解@EnableZuulProxy,在hosts文件中添加zuul的映射。
127.0.0.1 myzuul.com
接下来我们测试一下,启动三个eureka集群,提供者8001,网关zuul9001,访问eureka7001.com:7001
接着访问localhost:8001/user/get/2
启用路由访问myzuul.com:9001/cloud-user/user/get/1
路由访问映射规则
修改zuul9001模块的配置文件
zuul:
routes:
myuser.serviceId: cloud-user
myuser.path: /myuser/**
测试一下,启动三个eureka集群,提供者8001,网关zuul9001,访问myzuul.com:9001/myuser/user/get/1
访问原来的路径myzuul.com:9001/cloud-user/user/get/2
接下来,我们配置将原真实服务名忽略。
zuul:
routes:
myuser.serviceId: cloud-user
myuser.path: /myuser/**
ignored-services: cloud-user
访问myzuul.com:9001/myuser/user/get/1
访问原来的路径myzuul.com:9001/cloud-user/user/get/2
使用通配符,配置将原来所有的真实的服务名全部忽略。
zuul:
routes:
myuser.serviceId: cloud-user
myuser.path: /myuser/**
ignored-services: "*"
访问myzuul.com:9001/myuser/user/get/1
访问原来的路径myzuul.com:9001/cloud-user/user/get/2
我们还可以在访问路径中设置统一公共前缀。
zuul:
routes:
myuser.serviceId: cloud-user
myuser.path: /myuser/**
ignored-services: "*"
prefix: /cloud
测试一下,访问原来所有的路径,都是404。而带上我们配置的统一前缀,访问myzuul.com:9001/cloud/myuser/user/get/1
博客内容仅供自已学习以及学习过程的记录,如有侵权,请联系我删除,谢谢!
网友评论