Spring Cloud系列——微服务网关 Zuul
一.微服务架构及应用场景1.点对点的方式2.API-网关的方式主要产品有Zuul。二.Zuul介绍Zuul 是 Netflix 开源的微服务网关,Spring Cloud 对 Zuul 进行了整合和增强。在 SpringCloud 体系中,Zuul 担任着网关的角色,对发送到服务端的请求进行一些预处理,比如安全验证、动态路由、负载分配等。Zuul 的核心是 Filter...
·
一.微服务架构及应用场景
- 1.点对点的方式
- 2.API-网关的方式
主要产品有Zuul。
二.Zuul
- 介绍
Zuul 是 Netflix 开源的微服务网关,Spring Cloud 对 Zuul 进行了整合和增强。在 SpringCloud 体系中,Zuul 担任着网关的角色,对发送到服务端的请求进行一些预处理,比如安全验证、动态路由、负载分配等。
Zuul 的核心是 Filters,根据执行时期分为以下几类:
PRE:这种过滤器在请求被路由之前调用,实现身份验证。
ROUTING:这种过滤器将请求路由到微服务,用于构造发送给微服务的请求。
POST:这种过滤器在路由到微服务以后执行,可以为响应添加Http Header,收集统计信息和指标,将响应从微服务发送给客户端。
ERROR:在其他阶段发生错误时执行该过滤器。
- 自定义过滤器
需要继承ZuulFilter
,比如
@Slf4j
@Component //过滤器才能被发现,注册到容器中
public class PreRequestFilter extends ZuulFilter {
@Override
public String filterType() {
return FilterConstants.PRE_TYPE;
}
@Override
public int filterOrder() {// 值越小,越早被发现
return 0;
}
@Override
public boolean shouldFilter() {//需要过滤器永远执行
return true;
}
@Override
public Object run() throws ZuulException {
RequestContext ctx = RequestContext.getCurrentContext();
ctx.set("startTime",System.currentTimeMillis());//记下当前的时间戳,这个时间要传到下一个过滤器
return null;
}
}
分别启动Eureka、Zuul,打开Eureka控制台:
开放原子开发者工作坊旨在鼓励更多人参与开源活动,与志同道合的开发者们相互交流开发经验、分享开发心得、获取前沿技术趋势。工作坊有多种形式的开发者活动,如meetup、训练营等,主打技术交流,干货满满,真诚地邀请各位开发者共同参与!
更多推荐
已为社区贡献2条内容
所有评论(0)