六、Zuul路由网关
1. 概述
Zuul包含了对请求的路由和过滤两大主要功能。路由功能:负责将外部请求转发到具体的微服务中,是外部访问统一入口的基础。过滤功能:负责对请求的处理过程进行干预,是实现请求校验、服务聚合功能的基础。
Zuul可与Eureka进行整合,将Zuul自身注册为Eureka服务治理下的应用,从Eureka中获得其他微服务状态信息,从而在收到微服务访问请求时实现跳转。
2. 路由基本配置
2.1 新建项目
在工程spring-cloud-demo下,新建一个module,名为service-zuul-gateway。
2.2 引入依赖
引入spring-cloud-starter-eureka与spring-cloud-starter-zuul依赖。
<dependencies>
<!--zuul路由网关-->
<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>
</dependencies>
2.3 修改yml文件
eureka:
client:
serviceUrl:
defaultZone: http://eureka7777.com:7777/eureka/,http://eureka8888.com:8888/eureka/,http://eureka9999.com:9999/eureka/
instance:
instance-id: gateway-7001.com #自定义Eureka微服务管理页面的显示别名
prefer-ip-address: true #访问路径可以显示IP地址,默认为false 不显示
server:
port: 7001
spring:
application:
name: service-zuul-gateway
info:
app.name: charver-springclouddemo-servicemember
company.name: www.chavaer.com
contact.name: chavaer
contact.phone: 188-3288-3388
contace.email: chavaer@super.com.cn
2.4 修改hosts文件
找到本机hosts文件(C:\Windows\System32\drivers\etc\hosts),添加zuul子项目的ip映射:myzuul.com。
127.0.0.1 eureka8888.com
127.0.0.1 eureka9999.com
127.0.0.1 eureka7777.com
127.0.0.1 myzuul.com
2.5 修改启动类
通过@EnableZuulProxy
开启zuul路由网关配置。
@SpringBootApplication
@EnableZuulProxy
public class ZuulGatewayApp {
public static void main(String[] args) {
SpringApplication.run(ZuulGatewayApp.class);
}
}
2.6 效果测试
启动各个微服务
Eureka Server:eureka-server-7777、eureka-server-8888、eureka-server-9999
Service Provider:service-member-8010
Service Consumer:service-zuul-gateway
- 首先不通过zuul路由访问:
http://localhost:8010/member/list
- 再通过zuul路由访问:
http://myzuul.com:7001/service-member/member/list
myzuul.com:我们配置的本机ip即127.0.0.1
7001:微服务service-zuul-gateway的访问端口
service-member:微服务service-member-8010的应用名称
结果:通过微服务service-zuul-gateway路由到微服务service-member
3. 路由访问映射规则
3.1 修改yml文件
通过上一节可知,通过路由微服务可以请求到指定微服务,但是微服务名称service-member暴露出来,为了将原真实服务名隐藏,安全加固,可进行配置:
yml文件配置如下:
zuul:
routes:
service-provider:
path: /myservice/** #服务名映射的url
serviceId: service-member #服务提供方的id
ignored-services: "*" #忽略的服务名,配置后无法通过服务id访问,"*"表示多个
prefix: /cloud #访问url前缀,在服务名映射的url之前
3.2 效果测试
输入url:http://myzuul.com:7001/cloud/myservice/member/list
cloud:配置的公共部分前缀。
myservice:真实服务名service-member的映射,此时无法再用原真实服务名访问。
【上一篇】五、Hystrix断路器
【下一篇】七、SpringCloud Config分布式配置中心