我们从图中可以看出所有的请求来必须先经过API Gateway,这其实就是Zuul网关路由组件同一管理这些请求,才能够访问我们的服务。那么我们来学学Zuul路由网关的功能吧!

2、什么是Zuul网关路由?
- 1、什么是zuul?
zuul包含了对请求 路由
和 过滤
两个功能
路由功能: 负责将外部的请求转发到具体的微服务实例上,是实现外部访问统一的基础。和(controller功能类似)
过滤器功能: 负责对请求的处理过程进行干预、是实现请求校验、服务聚合等功能的基础。
Zuul和Eureka进行整合,将zuul自身注册到Eureka服务治理下的应用,同时从Eureka中获得其他微服务的消息,所以以后访问微服务都是通过zuul跳转后获得。
注意:Zuul最终还是会注册进Eureka中
提供:代理+过滤+路由功能
- 2、图解Zuul的实现原理
Zuul网关:
在服务注册中心和各个服务之间嵌套的一层,将zuul注册进Eureka,请求来了之后通过zuul路由网关统一转发到具体的微服务实例,也可以发现其他微服务,是用来管理和发现各个微服务的。

3、Zuul服务网关怎么使用
我们可以发现在使用springcloud的组件时,步骤几乎都是一样的 导入依赖
、 编写配置
、 开启服务
创建Module模块,名称为springcloud-zuul-9537
第一步:导入Zuul依赖和Eureka依赖,因为Zuul要注册进Eureka中,所以两个依赖必须有
<dependencies> <!--Zuul:服务网关--> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-zuul</artifactId> <version>1.4.6.RELEASE</version> </dependency> <!--Hystrix服务熔断与降级--> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-hystrix</artifactId> <version>1.4.6.RELEASE</version> </dependency> <!--Hystrix监控页面--> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-hystrix-dashboard</artifactId> <version>1.4.6.RELEASE</version> </dependency> <!--Feign--> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-feign</artifactId> <version>1.4.6.RELEASE</version> </dependency> <!--给消费者引入Ribbon依赖。让消费者从注册中心获取到服务列表的地址--> <!-- https://mvnrepository.com/artifact/org.springframework.cloud/spring-cloud-starter-ribbon --> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-ribbon</artifactId> <version>1.4.6.RELEASE</version> </dependency> <!--给消费者加入Eureka客户端,方便消费者在注册中心发现更多服务--> <!-- https://mvnrepository.com/artifact/org.springframework.cloud/spring-cloud-starter-eureka --> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-eureka</artifactId> <version>1.4.3.RELEASE</version> </dependency> <!--实体类+web--> <dependency> <groupId>com.baoji</groupId> <artifactId>springcloud-api</artifactId> <version>1.0-SNAPSHOT</version> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency> </dependencies> </project> 复制代码
第二步:编写application.yml配置文件,将zuul微服务注册进Eureka注册中心
server: port: 9537 spring: application: name: springcloud-zuul-gateway eureka: client: service-url: defaultZone: http://eureka7001.com:7001/eureka/,http://eureka7002.com:7002/eureka/ instance: instance-id: zuul9537 # 修改eureka上的默认描述信息 prefer-ip-address: true # true 可以显示服务的ip,而不是显示localhost #info信息 info: app.name: zuul-gateway-9537 company.name: com.baoji 复制代码
第三步:开启Zuul路由网关
package com.baoji.springcloud; import org.springframework.boot.SpringApplication; import org.springframework.boot.autoconfigure.SpringBootApplication; import org.springframework.cloud.netflix.zuul.EnableZuulProxy; @SpringBootApplication @EnableZuulProxy //开启Zuul路由网关 public class ZuulApplication_9537 { public static void main(String[] args) { SpringApplication.run(ZuulApplication_9537.class,args); } } 复制代码
第四步:修改Windows中Hosts文件
此电脑->C盘->windows->system32->drives->etc->hosts
将本机地址不显示在浏览器url地址栏,让别人看到的是设置的域名
127.0.0.1 www.baoji.zuul.com 复制代码
第五步:测试
1、依次打开Eureka注册中心(7001)、带熔断机制的服务提供方(8001)、Zuul路由网关的服务提供者(9537),输入“`localhost:7001,即可看到注册中心中注册了两个服务

2、输入 http://localhost:8001/dept/get/1
,查看服务提供方数据

3、输入 http://www.baoji.zuul.com:9527/springcloud-provide/dept/get/1
,隐藏真实地址,通过域名和微服务名来访问,可以达到同样的效果

4、但是我们不仅要隐藏真实地址,还要隐藏服务名,那么我们就在application.yml中配置Zuul,隐藏真实服务名
#配置Zuul 隐藏服务名(将真实微服务名用/mydept/**代替),zuul的路由功能
zuul:
routes:
mydept.serviceid: springcloud-provider
mydept.path: /mydept/**
复制代码
5、用 http://www.baoji.zuul.com:9527/mydept/dept/get/1
访问也能达到同样的效果,这样在地址栏中就不能看见任何关于微服务的信息了

6、那么问题来了,我们既可以通过真实的服务名访问,也可以通过Zuul配置的(虚假)访问名称访问,那么我们如何禁止真实的服务名来访问呢?
我们需要在application.yml中配置忽略原真实路径访问
zuul.ignored-services: springcloud-provider # 不能再使用这个路径访问了,被忽略了,如果忽略所有服务名,用“*”表示隐藏所有服务名 复制代码
7、我们也可以通过配置必须使用前缀去访问(不重要),此时我们要访问,地址就变成 http://www.baoji.zuul.com:9527/baoji/mydept/dept/get/1
zuul.prefix: /baoji # 表示必须以baoji为前缀进行访问 复制代码
zuul网关路由路由和过滤功能配置如下:(4代表Zuul路由功能,6和7代表zuul过滤功能)
#配置Zuul 隐藏服务名(将真实微服务名用/mydept/**代替) zuul: routes: mydept.serviceid: springcloud-provider mydept.path: /mydept/** ignored-services: springcloud-provider # 不能再使用这个路径访问了,被忽略了 zuul的过滤功能 prefix: /baoji # 表示必须以baoji为前缀进行访问 复制代码

最后YML:
server: port: 9537 spring: application: name: springcloud-zuul-gateway eureka: client: service-url: defaultZone: http://eureka7001.com:7001/eureka/,http://eureka7002.com:7002/eureka/ instance: instance-id: zuul9537 # 修改eureka上的默认描述信息 prefer-ip-address: true # true 可以显示服务的ip,而不是显示localhost #info信息 info: app.name: zuul-gateway-9537 company.name: com.baoji #配置Zuul 隐藏服务名(将真实微服务名用/mydept/**代替) zuul: routes: mydept.serviceid: springcloud-provider mydept.path: /mydept/** ignored-services: springcloud-provider # 不能再使用这个路径访问了,被忽略了 zuul的过滤功能 prefix: /baoji # 表示必须以baoji为前缀进行访问 复制代码
好了,我们今天学习了Zuul网关的路由、过滤功能实现,接下来我们学习使用Git远程访问springcloud config配置文件的操作,期待吧!赶快点赞:+1:+关注吧!:two_hearts:小红心:two_hearts:走起来!!!
原文
https://juejin.im/post/5eec1c80f265da02bd40f95f
本站部分文章源于互联网,本着传播知识、有益学习和研究的目的进行的转载,为网友免费提供。如有著作权人或出版方提出异议,本站将立即删除。如果您对文章转载有任何疑问请告之我们,以便我们及时纠正。PS:推荐一个微信公众号: askHarries 或者qq群:474807195,里面会分享一些资深架构师录制的视频录像:有Spring,MyBatis,Netty源码分析,高并发、高性能、分布式、微服务架构的原理,JVM性能优化这些成为架构师必备的知识体系。还能领取免费的学习资源,目前受益良多

转载请注明原文出处:Harries Blog™ » Springcloud学习之路六(Zuul网关路由功能、过滤功能、路由的基本配置、路由的访问映射规则)