一.微服务架构及应用场景

  • 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控制台:
在这里插入图片描述

Logo

开放原子开发者工作坊旨在鼓励更多人参与开源活动,与志同道合的开发者们相互交流开发经验、分享开发心得、获取前沿技术趋势。工作坊有多种形式的开发者活动,如meetup、训练营等,主打技术交流,干货满满,真诚地邀请各位开发者共同参与!

更多推荐