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

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值