概述
Zuul包含了对请求的
路由
和过滤
两个最主要的功能:其中路由功能负责将外部请求转发到具体的微服务实例上,是实现外部访问统一入口的基础;
而过滤器功能则负责对请求的处理过程进行干预,是实现请求校验、服务聚合等功能的基础。
Zuul和Eureka进行整合,将Zuul自身注册为Eureka服务治理下的应用,同时从Eureka中获得其他微服务的消息,也即以后的访问微服务都是通过Zuul跳转后获得。
注意:Zuul服务最终还是会注册进Eureka
提供 = 代理 + 路由 + 过滤 三大功能
路由基本配置
新建Module模块【microservicecloud-zuul-gateway-9527】
POM
<!--zuul路由网关-->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-zuul</artifactId>
</dependency>
<!-- 将微服务provider注册进Eureka -->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-eureka</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-config</artifactId>
</dependency>
YML
server:
port: 9527
spring:
application:
name: microservicecloud-zuul-gateway
eureka:
client:
service-url:
defaultZone: http://eureka7001.com:7001/eureka/,http://eureka7002.com:7002/eureka/,http://eureka7003.com:7003/eureka/
instance:
instance-id: gateway-9527.com
prefer-ip-address: true
info:
app.name: microcloud-gateway
company.name: www.demo.com
build.artifactId: $project.artifactId$
build.version: $project.version$
hosts修改
C:\Windows\System32\drivers\etc路径下的hosts文件,新增如下内容:
127.0.0.1 myzuul.com
主启动类
主启动类添加注解@EnableZuulProxy
启动
三个eureka集群
一个服务提供类microservicecloud-provider-dept-8001
一个路由
测试
不用路由:http://localhost:8001/dept/get/2
启用路由:http://myzuul.com:9527/microservicecloud-dept/dept/get/2
路由访问映射规则
修改microservicecloud-zuul-gateway-9527模块,做真实微服务名的映射,
原本是通过http://myzuul.com:9527/microservicecloud-dept/dept/get/2访问,
现在通过http://myzuul.com:9527/mydept/dept/get/2访问
yml
zuul:
routes:
mydept.serviceId: microservicecloud-dept
mydept.path: /mydept/**
但是只在yml文件中这样配置的话,原路径和新路径都可以访问成功,现在要使原路径访问方式失效、
原真实服务名忽略
yml添加配置
# 忽略特定的服务名
zuul:
ignored-services: microservicecloud-dept
# 若想忽略所有的原真实服务名,添加如下配置
zuul:
ignored-services: "*"
设置统一公共前缀
yml添加配置,通过http://myzuul.com:9527/shinkaDemo/mydept/dept/get/2可访问
zuul:
prefix: /shinkaDemo