【微服务架构】SpringCloud之路由网关(zuul)
什么是zuul
zuul 是netflix开源的一个API Gateway 服务器, 本质上是一个web servlet应用。
Zuul 在云平台上提供动态路由,监控,弹性,安全等边缘服务的框架。Zuul 相当于是设备和 Netflix 流应用的 Web 网站后端所有请求的前门。
在微服务架构中,需要几个关键的组件,服务注册与发现、服务消费、负载均衡、断路器、智能路由、配置管理等,由这几个组件可以组建一个简单的微服务架构,如下图:
注意:A服务和B服务是可以相互调用的。并且配置服务也是注册到服务注册中心的。
客户端的请求首先经过负载均衡(zuul、Ngnix),再到达服务网关(zuul集群),然后再到具体的服务,服务统一注册到高可用的服务注册中心集群,服务的所有的配置文件由配置服务管理(下一篇文章讲述),配置服务的配置文件放在git仓库,方便开发人员随时改配置。
过滤器类型与请求生命周期
Zuul大部分功能都是通过过滤器来实现的。Zuul中定义了四种标准过滤器类型,这些过滤器类型对应于请求的典型生命周期。
(1) PRE:这种过滤器在请求被路由之前调用。我们可利用这种过滤器实现身份验证、在集群中选择请求的微服务、记录调试信息等。
(2) ROUTING:这种过滤器将请求路由到微服务。这种过滤器用于构建发送给微服务的请求,并使用Apache HttpClient或Netfilx Ribbon请求微服务。
(3) POST:这种过滤器在路由到微服务以后执行。这种过滤器可用来为响应添加标准的HTTP Header、收集统计信息和指标、将响应从微服务发送给客户端等。
(4) ERROR:在其他阶段发生错误时执行该过滤器。
除了默认的过滤器类型,Zuul还允许我们创建自定义的过滤器类型。例如,我们可以定制一种STATIC类型的过滤器,直接在Zuul中生成响应,而不将请求转发到后端的微服务。
Zuul请求的生命周期如下图:
先要启动EureKaserver工程(注册中心)和SpringCloud-Service工程(服务生产者)
可以参考:https://blog.csdn.net/u012081441/article/details/80708060
编写Zuul过滤器
理解过滤器类型和请求生命周期后,我们来编写一个Zuul过滤器。编写Zuul的过滤器非常简单,我们只需继承抽象类ZuulFilter,然后实现几个抽象方法就可以了。
pom.xml文件
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"><modelVersion>4.0.0</modelVersion><groupId>com.fit</groupId><artifactId>SpringCloud-Zuul</artifactId><version>0.0.1-SNAPSHOT</version><!-- SpringBoot父类依赖引用 --><parent><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-parent</artifactId><version>1.5.2.RELEASE</version><relativePath /></parent><dependencies><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><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId></dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-test</artifactId><scope>test</scope></dependency></dependencies><dependencyManagement><dependencies><dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-dependencies</artifactId><version>Dalston.RC1</version><type>pom</type><scope>import</scope></dependency></dependencies></dependencyManagement><build><plugins><plugin><groupId>org.springframework.boot</groupId><artifactId>spring-boot-maven-plugin</artifactId></plugin></plugins></build><repositories><repository><id>spring-milestones</id><name>Spring Milestones</name><url>https://repo.spring.io/milestone</url><snapshots><enabled>false</enabled></snapshots></repository></repositories>
</project>
application.yml文件
eureka:client:serviceUrl:defaultZone: http://localhost:8888/eureka/
server:port: 8769
spring:application:name: SpringCloud-Zuul
zuul:routes:api-a:path: /SpringCloud-Service/**service-id: SpringCloud-Service
TokenFilter.java文件
@Component
public class TokenFilter extends ZuulFilter {private static Logger log = LoggerFactory.getLogger(TokenFilter.class);@Overridepublic String filterType() {return "pre";}@Overridepublic int filterOrder() {return 0;}public boolean shouldFilter() {return true;}public Object run() {RequestContext ctx = RequestContext.getCurrentContext();HttpServletRequest request = ctx.getRequest();log.info(String.format("%s >>> %s", request.getMethod(), request.getRequestURL().toString()));Object accessToken = request.getParameter("token");if (accessToken != null) {return null;}log.warn("token is empty");ctx.setSendZuulResponse(false);ctx.setResponseStatusCode(401);try {ctx.getResponse().getWriter().write("token is empty");} catch (Exception e) {}return null;}
}
由代码可知,自定义的Zuul Filter需实现以下几个方法:
filterType:返回过滤器的类型。有pre、route、post、error等几种取值,分别对应上文的几种过滤器。
filterOrder:返回一个int值来指定过滤器的执行顺序,不同的过滤器允许返回相同的数字。
shouldFilter:返回一个boolean值来判断该过滤器是否要执行,true表示执行,false表示不执行。
run:过滤器的具体逻辑。本例中,我们让它打印了请求的HTTP方法以及请求的地址。
ZuulApp.java文件
@EnableZuulProxy
@EnableEurekaClient
@SpringBootApplication
public class ZuulApp {/*** @param args*/public static void main(String[] args) {// TODO Auto-generated method stubSpringApplication.run(ZuulApp.class, args);}
}
源码下载
【微服务架构】SpringCloud之路由网关(zuul)相关推荐
- 微服务:简述微服务架构中的API网关
微服务:简述微服务架构中的API网关 API网关是任何微服务架构的重要组成部分.有了它我们可以在一个独立的模块上方便的处理一些非业务逻辑,可以让微服务本身专注在自身特定的功能上,使得每个微服务的开发更 ...
- SpringCloud微服务注册调用入门-路由网关
1 . 路由网关的介绍 路由网关(Zuul)的主要功能是路由转发和过滤器 . 路由功能是微服务的一部分 , 比如/service/user转发到到用户服务 , /service/shop转发到到商店服 ...
- 微服务架构 SpringCloud(一)组件和概念介绍
一:什么是微服务(Microservice) 微服务英文名称Microservice,Microservice架构模式就是将整个Web应用组织为一系列小的Web服务.这些小的Web服务可以独立地编译及 ...
- 微服务架构之「 API网关 」
点击上方"方志朋",选择"置顶公众号" 技术文章第一时间送达! 在微服务架构的系列文章中,前面已经通过文章<架构设计之「服务注册 」>介绍过了服务注 ...
- yii2 请求外部api_微服务架构之「 API网关 」
作者:奎哥来自公众号:不止思考 在微服务架构的系列文章中,前面已经通过文章<架构设计之「服务注册 」>介绍过了服务注册的原理和应用,今天这篇文章我们来聊一聊「 API网关 」. 「 API ...
- SpringCloud之路由网关zuul(五)
2019独角兽企业重金招聘Python工程师标准>>> 在微服务架构中,需要几个基础的服务治理组件,包括服务注册与发现.服务消费.负载均衡.断路器.智能路由.配置管理等,由这几个基础 ...
- 微服务架构:BFF和网关是如何演化出来的?
题图 from pixabay.com 1.介绍 BFF(Backend for Frontend)和网关Gateway是微服务架构中的两个重要概念,这两个概念相对比较新,有些开发人员甚至是架构师都不 ...
- 转:微服务架构:BFF和网关是如何演化出来的?(这篇文章相当棒)
转自: https://juejin.im/entry/6844903806208049159 这篇文章写得非常棒,从服务,到bff, 到gateway 的一步步演化,描述的非常清晰易懂. 1.介绍 ...
- SpringCloud教程- 路由网关Zuul (SpringCloud版本Greenwich.SR4)
文章目录 Zuul简介 创建zuul-gateway工程 服务过滤 代码地址:github-spring-cloud地址 Zuul简介 Zuul是NetFlix开源的微服务网关,它可以和Eureka. ...
最新文章
- LeetCode简单题之分发饼干
- oracle11g memory_target,oracle11g MEMORY_MAX_TARGET设置成0 问题处理
- python socket tcp_python socket 模拟tcp通讯
- (51)FPGA条件选择(case)
- nginx+redis 实现 jsp页面缓存,提升系统吞吐率
- 数据解析1:XML解析(1)
- [转贴]What's the Scroll Lock key on my computer for?
- Dynatable – 基于 HTML5 jQuery 的交互表格插件
- Git生成SSH共钥
- JAVA实现邮件发送
- 天正lisp文件夹_CAD使用一个LISP文件,实现自动加载菜单和程序集
- YUV422转RGB并显示于Qlabel
- Java计算机毕业设计电费管理系统源码+系统+数据库+lw文档
- CornerStone的使用
- 【转载】C++ 内存分配(new,operator new)详解
- 6.详解第二代蜂窝移动通信系统的典型代表——GSM和通用分组无线业务(GPRS)
- 让你大吃一惊的国外广告联盟
- qt 截图 视频 截屏幕 截窗口
- win7无线网显示小太阳
- 微信组件:微信转账查询
热门文章
- SVN优化(一) SVN忽略maven项目的target
- Linux shell 学习笔记(9)— 循环语句(for、while)以及更改字段分隔符
- c语言使用指定字符串替换特定的子串
- Vue 自定义权限指令
- CPU三级缓存技术解析
- Cuda Stream流 分析
- 多尺度目标检测 Multiscale Object Detection
- OpenCV读写视频文件解析
- 2021年大数据Flink(十五):流批一体API Connectors ​​​​​​​Kafka
- 2021年大数据Spark(二十六):SparkSQL数据处理分析