zuul两大作用_springCloud学习- 路由网关(zuul)
1、zuul简介
1.1、zuul是什么
zuul 是netflix开源的一个API Gateway 服务器, 本质上是一个web servlet应用。
Zuul 在云平台上提供动态路由,监控,弹性,安全等边缘服务的框架。Zuul 相当于是设备和 Netflix 流应用的 Web 网站后端所有请求的前门。
Zuul的主要功能是路由转发和过滤器。路由功能是微服务的一部分,比如/api/user转发到到user服务,/api/shop转发到到shop服务。zuul默认和Ribbon结合实现了负载均衡的功能。
1.2、zuul能做什么
zuul的核心是一系列的filters, 其作用可以类比Servlet框架的Filter,或者AOP。
Zuul可以通过加载动态过滤机制,从而实现以下各项功能:
验证与安全保障: 识别面向各类资源的验证要求并拒绝那些与要求不符的请求。
审查与监控: 在边缘位置追踪有意义数据及统计结果,从而为我们带来准确的生产状态结论。
动态路由: 以动态方式根据需要将请求路由至不同后端集群处。
压力测试: 逐渐增加指向集群的负载流量,从而计算性能水平。
负载分配: 为每一种负载类型分配对应容量,并弃用超出限定值的请求。
静态响应处理: 在边缘位置直接建立部分响应,从而避免其流入内部集群。
多区域弹性: 跨越AWS区域进行请求路由,旨在实现ELB使用多样化并保证边缘位置与使用者尽可能接近。
2、创建service-zuul工程
2.1、创建service-zuul工程,pom.xml文件如下
4.0.0
com.lishun
service-zuul
0.0.1-SNAPSHOT
jar
service-zuul
Demo project for Spring Boot
com.lishun
cloud
1.0-SNAPSHOT
org.springframework.cloud
spring-cloud-starter-netflix-zuul
org.springframework.cloud
spring-cloud-starter-netflix-eureka-client
org.springframework.boot
spring-boot-starter-web
2.2、在其入口applicaton类加上注解@EnableZuulProxy,开启zuul的功能:
@EnableZuulProxy
@EnableEurekaClient
@SpringBootApplicationpublic classServiceZuulApplication {public static voidmain(String[] args) {
SpringApplication.run(ServiceZuulApplication.class, args);
}
}
2.3、加上配置文件application.yml加上以下的配置代码:
eureka:
client:
serviceUrl:
defaultZone: http://localhost:8761/eureka/
server:
port: 8769
spring:
application:
name: service-zuul
zuul:
routes:
api-a:
path: /api-a/**
serviceId: service-ribbon
api-b:
path: /api-b/**
serviceId: service-feign
首先指定服务注册中心的地址为http://localhost:8761/eureka/,服务的端口为8769,服务名为service-zuul;
以/api-a/ 开头的请求都转发给service-ribbon服务;以/api-b/开头的请求都转发给service-feign服务;
2.4、启动5个服务,浏览器访问 http://localhost:8769/api-a/hi?name=lis 页面显示
hi lis ,i am from port:8762
浏览器访问 http://localhost:8769/api-b/hi?name=lis 页面显示
hi lis ,i am from port:8762
这说明zuul起到了路由的作用
3、服务过滤
前面提到,Zuul通过加载动态过滤机制,不仅可以实现路由功能,还能实现验证,检查,监控等功能。
下面使用zuul来实现安全验证功能
@Componentpublic class MyFilter extendsZuulFilter {private static Logger log = LoggerFactory.getLogger(MyFilter.class);
@OverridepublicString filterType() {return "pre";
}
@Overridepublic intfilterOrder() {return 0;
}
@Overridepublic booleanshouldFilter() {return true;
}
@Overridepublic Object run() throwsZuulException {
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) {
log.warn("token is empty");
ctx.setSendZuulResponse(false);
ctx.setResponseStatusCode(401);try{
ctx.getResponse().getWriter().write("token is empty");
}catch(Exception e){}return null;
}
log.info("ok");return null;
}
}
filterType:返回一个字符串代表过滤器的类型,在zuul中定义了四种不同生命周期的过滤器类型,具体如下:
pre:路由之前
routing:路由之时
post: 路由之后
error:发送错误调用
filterOrder:过滤的顺序
shouldFilter:这里可以写逻辑判断,是否要过滤,本文true,永远过滤。
run:过滤器的具体逻辑。可用很复杂,包括查sql,nosql去判断该请求到底有没有权限访问。
token is empty
hi lis ,i am from port:8762
zuul两大作用_springCloud学习- 路由网关(zuul)相关推荐
- zuul两大作用_SpringCloud微服务(05):Zuul组件,实现路由网关控制
一.Zuul组件简介 1.基础概念 Zuul 网关主要提供动态路由,监控,弹性,安全管控等功能.在分布式的微服务系统中,系统被拆为了多个微服务模块,通过zuul网关对用户的请求进行路由,转发到具体的后 ...
- 史上最简单的SpringCloud教程 | 第五篇: 路由网关(zuul)
转:https://blog.csdn.net/forezp/article/details/69939114 最新版本: 史上最简单的SpringCloud教程 | 第五篇: 路由网关(zuul)( ...
- 第九章:路由网关(Zuul)的使用
2019独角兽企业重金招聘Python工程师标准>>> 第九章:路由网关(Zuul)的使用 前言 介绍完分布式配置中心,结合前面的文章.我们已经有了一个微服务的框架了,可以对外提供a ...
- 闭包的两大作用:保存/保护
闭包的概念 函数执行时形成的私有上下文EC(FN),正常情况下,代码执行完会出栈后释放;但是特殊情况下,如果当前私有上下文中的某个东西被上下文以外的事物占用了,则上下文不会出栈释 放, 从而形成不销 ...
- SpringCloud教程- 路由网关Zuul (SpringCloud版本Greenwich.SR4)
文章目录 Zuul简介 创建zuul-gateway工程 服务过滤 代码地址:github-spring-cloud地址 Zuul简介 Zuul是NetFlix开源的微服务网关,它可以和Eureka. ...
- 第五篇:路由网关(zuul) zuul路由 服务过滤 (Finchley版本)V2.0_dev
前言: 在微服务架构中,需要几个基础的服务治理组件,包括服务注册与发现.服务消费.负载均衡.断路器.智能路由.配置管理等,由这几个基础组件相互协作,共同组建了一个简单的微服务系统. 在Spring C ...
- springcloud 之 路由网关 zuul
话不多说,先上图(图是丑陋了点,大家别介意哈),这幅图是我根据公司现有的业务设计出来的一个简单的基于springcloud微服务架构图. 在springcloud微服务体系中,我们一般不对外直接暴露服 ...
- SpringCloud 学习--路由网关
在微服务架构中,需要几个基础的微服务,包括服务的注册与发现,服务消费,负载均衡,断路器,咋能路由,配置管理等,由这几几个基础组件相互协作,共用组建一个简单的微服务系统. -Zuul 简介 Zuul是N ...
- java B2B2C Springboot电子商城系统-路由网关(zuul)
一.Zuul简介 Zuul的主要功能是路由转发和过滤器.路由功能是微服务的一部分,比如/api/user转发到到user服务,/api/shop转发到到shop服务.zuul默认和Ribbon结合实现 ...
最新文章
- AngularJS中选择样式
- 第一篇读书笔记,关于UML和模式应用(1)--书籍简介
- MATLAB观察系统响应,基于MATLAB的系统的时域响应分析精选.doc
- Doc命令收集(一)
- [luogu3676]小清新数据结构题
- kali安装python3.7_Debian服务器之安装Python3.7
- 消解原理推理_什么是推理统计中的Z检验及其工作原理?
- linux中常用的shell脚本,Linux常用shell脚本
- LeetCode——Word Break
- poj 3040 Allowance (贪心
- 解决springboot jar包冲突
- 了解单片机解密的一些知识
- EnableViewState属性
- 数据挖掘中的关联规则
- L1-020. 帅到没朋友
- 如何选择SCI期刊并能顺利发表
- 2022-2028年全球及中国汽车保险丝行业投资前景分析
- 赛尔号找不到服务器ip,赛尔号互通版
- github新手使用指南
- 测试、前端、产品经理的一般要求
热门文章
- JSD-2204-创建Spring项目-Day19
- 360浏览器和搜狗浏览器查看双内核版本及如何控制内核版本
- php 跳转邮箱,JS点击跳转登陆邮箱功能简单的实现方法
- 舆情监测技术TOOM,web技术实现
- python中的相对导入//__name__和__package__的作用//以及相对导入的两个经典错误
- 关于浏览器方向的大厂面试题
- 【圈外同学】Day01 一个模型,帮你找到真正热爱的
- Docker指定网桥和指定网桥IP
- 使用Python将Word表格嵌入Excel中!
- OA协同办公系统功能介绍