SpringCloud(12):Zuul路由网关
创始人
2024-05-14 04:39:49
0

1 为什么需要服务网关

在分布式系统系统中,有商品、订单、用户、广告、支付等等一大批的服务,前端怎么调用呢?和每个服务一个个打交道?这显然是不可能的,这就需要有一个角色充当所有请求的入口,这个角色就是服务网关(API gateway)。

2 客户端直接与微服务通讯的问题

  1. 客户端会多次请求不同的微服务,增加了客户端的复杂性。
  2. 存在跨域请求,在一定场景下处理相对复杂。
  3. 认证复杂,每个服务都需要独立认证。
  4. 难以重构,随着项目的迭代,可能需要重新划分微服务。例如,可能将多个服务合并成一个或者将一个服务拆分成多个。如果客户端直接与微服务通讯,那么重构将会很难实施。

3 网关的优点

  1. 易于监控。可在微服务网关收集监控数据并将其推送到外部系统进行分析。
  2. 易于认证。可在微服务网关上进行认证。然后再将请求转发到后端的微服务,而无须在每个微服务中进行认证。
  3. 减少了客户端与各个微服务之间的交互次数。

为了解决上面这些问题,我们需要将权限控制这样的东西从我们的服务单元中抽离出去,而最适合这些逻辑的地方就是处于对外访问最前端的地方,我们需要一个更强大一些的均衡负载器,它就是本文将来介绍的:服务网关。

4 什么是网关?

服务网关是微服务架构中一个不可或缺的部分。通过服务网关统一向外系统提供REST API的过程中,除了具备服务路 由、均衡负载功能之外,它还具备了权限控制等功能。Spring Cloud Netflflix 中的 Zuul 就担任了这样的一个角色,为 微服务架构提供了前门保护的作用,同时将权限控制这些较重的非业务逻辑内容迁移到服务路由层面,使得服务集群主体能够具备更高的可复用性和可测试性。

5 使用zuul

5.1 新建zuul的module工程

5.2 新建pom文件

        org.springframework.cloudspring-cloud-starter-netflix-eureka-clientorg.springframework.cloudspring-cloud-starter-netflix-zuul

5.3 application.yml配置文件

eureka:client:serviceUrl:defaultZone: http://localhost:8888/eureka/
server:port: 9000
spring:application:name: study-zuul
zuul:routes:#路由名称,随意命名api-order:path: /api-order/**serviceId: study-userapi-user:path: /api-user/**serviceId: study-user

5.4 启动类

package com.study;import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.netflix.eureka.EnableEurekaClient;
import org.springframework.cloud.netflix.zuul.EnableZuulProxy;@SpringBootApplication
// 开启zuul功能
@EnableZuulProxy
@EnableEurekaClient
public class ZuulApp {public static void main(String[] args) {SpringApplication.run(ZuulApp.class, args);}
}

5.5测试路由访问

直接访问该端口结果如下:

通过路由网关访问,和上面结果一样

5.6 配置统一前缀访问

zuul:routes:#路由名称,随意命名api-order:path: /api-order/**serviceId: study-userapi-user:path: /api-user/**serviceId: study-user#前缀访问prefix: /study

添加统一前缀以后之前访问地址:http://localhost:9000/api-user/user/3

需要增加前缀才能访问,如下:

http://localhost:9000/study/api-user/user/3

5.7 忽略服务名serviceId访问

zuul:routes:#路由名称,随意命名api-order:path: /api-order/**serviceId: study-userapi-user:path: /api-user/**serviceId: study-user#忽略服务名serviceId访问ignored-services: "*"

添加ignored-services: "*"以后,之前直接通过服务名访问的端口将无法直接访问,必须通过路由访问。

5.8 配url绑定映射

zuul:routes:testurl:url: http://www.baidu.compath: /testurl/**

添加以后只要访问http://地址/testurl/**的将直接跳转到http://www.baidu.com。

testurl可以自己设置名称。

5.9 配置URL映射负载

ribbon:eureka:enabled: false
#Ribbon请求的微服务serviceId
study-user:ribbon:listOfServers: http://www.huya.com,http://www.douyu.com
zuul:routes:testurl:serviceId: study-userpath: /testurl/**

访问/testurl/**,会自动跳转http://www.huya.com或者http://www.douyu.com根据负载均衡来进行。

如http://localhost:9000/testurl/

6 zuul过滤器

Zuul本身是一系列过滤器的集成,那么他当然也就提供了自定义过滤器的功能,zuul提供了四种过滤器:前置过滤器,路由过滤器,错误过滤器,简单过滤器,实现起来也十分简单,只需要编写一个类去实现zuul提供的接口。

使用zuul过滤器

package com.study.Filter;import com.netflix.zuul.ZuulFilter;
import org.springframework.cloud.netflix.zuul.filters.support.FilterConstants;
import org.springframework.stereotype.Component;@Component
public class Filter1 extends ZuulFilter {/*** 类型包含 pre post route error* pre 代表在路由代理之前执行* route 代表代理的时候执行* error 代表出现错的时候执行* post 代表在route 或者是 error 执行完成后执行*/@Overridepublic String filterType() {// 路由之前(前置过滤器)return FilterConstants.PRE_TYPE;}@Overridepublic int filterOrder() {// 优先级,数字越大,优先级越低return 2;}@Overridepublic boolean shouldFilter() {// 是否执行该过滤器,true代表需要过滤return true;}@Overridepublic Object run() {System.out.println("Filter1 run");return null;}
}

设置两个过滤器,一个前置,一个后置,查看运行结果。

 

相关内容

热门资讯

喜欢穿一身黑的男生性格(喜欢穿... 今天百科达人给各位分享喜欢穿一身黑的男生性格的知识,其中也会对喜欢穿一身黑衣服的男人人好相处吗进行解...
发春是什么意思(思春和发春是什... 本篇文章极速百科给大家谈谈发春是什么意思,以及思春和发春是什么意思对应的知识点,希望对各位有所帮助,...
网络用语zl是什么意思(zl是... 今天给各位分享网络用语zl是什么意思的知识,其中也会对zl是啥意思是什么网络用语进行解释,如果能碰巧...
为什么酷狗音乐自己唱的歌不能下... 本篇文章极速百科小编给大家谈谈为什么酷狗音乐自己唱的歌不能下载到本地?,以及为什么酷狗下载的歌曲不是...
华为下载未安装的文件去哪找(华... 今天百科达人给各位分享华为下载未安装的文件去哪找的知识,其中也会对华为下载未安装的文件去哪找到进行解...
怎么往应用助手里添加应用(应用... 今天百科达人给各位分享怎么往应用助手里添加应用的知识,其中也会对应用助手怎么添加微信进行解释,如果能...
家里可以做假山养金鱼吗(假山能... 今天百科达人给各位分享家里可以做假山养金鱼吗的知识,其中也会对假山能放鱼缸里吗进行解释,如果能碰巧解...
四分五裂是什么生肖什么动物(四... 本篇文章极速百科小编给大家谈谈四分五裂是什么生肖什么动物,以及四分五裂打一生肖是什么对应的知识点,希...
一帆风顺二龙腾飞三阳开泰祝福语... 本篇文章极速百科给大家谈谈一帆风顺二龙腾飞三阳开泰祝福语,以及一帆风顺二龙腾飞三阳开泰祝福语结婚对应...
美团联名卡审核成功待激活(美团... 今天百科达人给各位分享美团联名卡审核成功待激活的知识,其中也会对美团联名卡审核未通过进行解释,如果能...