Spring cloud实践之道六(网关Zuul)
标签:
Spring Cloud
为什么需要网关
根据前面的内容,我们已经能做到下面的内容:
Eureka进行服务的注册和发现
Ribbon进行负载均衡
通过Feign,RestTemplate进行服务的调用
Hystrix进行服务降级,隔离故障
Spring Cloud Config进行集群配置
Spring Cloud Bus进行配置的刷新
下面我们要考虑一下这问题:
外部应用如何来访问服务
外部应用如何进行服务访问的权限控制
如何将请求均衡分发给后台服务
解决方案:
Spring Cloud Zuul路由是微服务架构的不可或缺的一部分,提供动态路由,监控,弹性,安全等的边缘服务。
网关框架图
网关路由
在pom.xml文件中增加依赖
<dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-zuul</artifactId> </dependency> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-eureka</artifactId> </dependency>
增加注解
@SpringBootApplication@EnableZuulProxy@EnableDiscoveryClientpublic class ZuulApplication { public static void main(String[] args) { new SpringApplicationBuilder(ZuulApplication.class).web(true).run(args);
}
}配置文件中进行路由的定义
#这里的配置表示,访问/a/** 直接重定向到服务eurekaClient/** zuul.routes.a.path=/a/** zuul.routes.a.serviceId=eurekaClient
服务过滤
书写一个过滤类,继承ZuulFilter
public class AccessFilter extends ZuulFilter { private static Logger log = LoggerFactory.getLogger(AccessFilter.class); /**
* 返回一个字符串代表过滤器的类型,在zuul中定义了四种不同生命周期的过滤器类型
*
* pre:可以在请求被路由之前调用
* routing:在路由请求时候被调用
* post:在routing和error过滤器之后被调用
* error:处理请求时发生错误时被调用
*/
@Override
public String filterType() { return "pre";
} /**
* 通过int值来定义过滤器的执行顺序
*/
@Override
public int filterOrder() { return 0;
} /**
* 返回一个boolean类型来判断该过滤器是否要执行,所以通过此函数可实现过滤器的开关。
*/
@Override
public boolean shouldFilter() { return true;
} /**
* 过滤器的具体逻辑。需要注意,这里我们通过ctx.setSendZuulResponse(false)令zuul过滤该请求,不对其进行路由,
* 然后通过ctx.setResponseStatusCode(401)设置了其返回的错误码,当然我们也可以进一步优化我们的返回,
* 比如,通过ctx.setResponseBody(body)对返回body内容进行编辑等。
*/
@Override
public Object run() {
RequestContext ctx = RequestContext.getCurrentContext();
HttpServletRequest request = ctx.getRequest();
log.info(String.format("%s request to %s", request.getMethod(), request
.getRequestURL().toString()));
Object accessToken = request.getParameter("accessToken"); if (accessToken == null) {
log.warn("access token is empty");
ctx.setSendZuulResponse(false);
ctx.setResponseStatusCode(401); return null;
}
log.info("access token ok"); return null;
}
}这个过滤器需要装载
// 装载过滤器
@Bean
public AccessFilter accessFilter() { return new AccessFilter();
}所有的请求加上accessToken才能正常访问
下图为filterType的生命周期示意图
filterType生命周期介绍
作者:hutou
链接:https://www.jianshu.com/p/9b3fc9f1ca2e
点击查看更多内容
1人点赞
评论
共同学习,写下你的评论
评论加载中...
作者其他优质文章
正在加载中
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦

