前言:本文的 Zuul 路由网关 主要技术内容学习自教程视频:https://www.bilibili.com/video/BV1jJ411S7xr?p=17,此教程非常通俗易懂且有质量,也希望更多人能够支持这样高质量的UP,我在学习时收获很多,因视频形式不易复习回顾,因此加了一部分自己的见解并整理成图文博客的形式。
1 什么是 Zuul
Zuul 包含了对请求的路由和过滤两个最主要的功能,外加代理功能:
- 路由功能负责将外部请求转发到具体的微服务实例上,是实现外部访问统一入口的基础。
- 过滤器功能则负责对请求的处理过程进行干预,是实现请求校验,服务聚合等功能的基础。
Zuul 和 Eureka 进行整合,将 Zuul 自身注册为 Eureka 服务治理下的应用,同时从 Eureka 中获得其他微服务的消息,也即以后的访问微服务都是通过 Zuul 跳转后获得。
2 为什么要使用 Zuul
网关可以对外暴露聚合API,屏蔽内部微服务的微小变动,保持整个系统的稳定性。还可以做负载均衡,统一鉴权,协议转换,监控监测等一系列功能。
3 项目实战:路由功能
3.1 项目的基本构建与实现
1、新建 Module 模块 springcloud-zuul-gateway-9527 ,pom 文件添加 Eureka 和 Zuul 的配置
<!--Zuul-->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-zuul</artifactId>
<version>1.4.7.RELEASE</version>
</dependency>
<!--Eureka相关-->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-eureka</artifactId>
<version>1.4.7.RELEASE</version>
</dependency>
2、application.yaml 配置
3、hosts 修改(这步骤可有可无,教程的作者是想更真实地从表面上模拟分布式项目的的发生)
4、主启动类
5、启动项目,测试
3.2 出现问题-1
http://myzuul.com:9527/springcloud-provider-dept/dept/get/2 这样去访问的话,就暴露了我们真实微服务的名称,该怎么处理呢? 接下来的内容就是围绕这个问题的解决而出现的。
修改 springcloud-zuul-gateway-9527 工程,yml 配置增加 Zuul 路由映射
3.3 出现问题-2
现在访问原路径依旧可以访问!这不是我们所希望的,而我们希望只能通过配置后的 url 访问,接下来是这个问题的解决。
3.4 出现问题-3
上面的例子中,我们只写了一个 serviceId,那要是有多个需要隐藏,怎么办呢? 下面是这个问题的解决。
3.5 补充
同时,我们也可以给各微服务的访问请求加上公共的 url 前缀