上篇博客《SpringCloud——Eureka服务注册和发现》中介绍了注册中心Eureka、服务提供者和服务消费者。这篇博客咱们将介绍服务网关。java
图(1) 未使用服务网关的作法
web
图(2) 服务网关的作法
spring
服务网关,英文Service GateWay,他是微服务框架中惟一的入口。有些相似外观模式,对外只提供一个访问的入口。这样作的好处有不少,减小了客户端屡次调用微服务,也能够在“入口”处进行负载或权限的处理。api
在SpringCloud Netflix中,Zuul就是这样一个角色。markdown
引入jar包app
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-zuul</artifactId>
</dependency>
在Application中开启Zuul负载均衡
@EnableZuulProxy
@SpringCloudApplication //整合了@SpringBootApplication、@EnableDiscoveryClient、@EnableCircuitBreaker,主要目的仍是简化配置
public class ZuulApplication {
public static void main(String[] args) {
new SpringApplicationBuilder(ZuulApplication.class).web(true).run(args);
}
}
Zuul环境搭建完毕以后,咱们就能够来看他的主要功能了,包括服务路由和服务过滤。框架
方法一:url配置
在application.properties中,进行以下配置。ide
zuul.routes.api-a-url.path=/api-a-url/** zuul.routes.api-a-url.url=http://localhost:2222/
以后,咱们就能够经过”/api-a-url”来代替”http://localhost:2222/“进行访问,相似修改本地hosts文件来设置域名。这种方式屏蔽了ip和端口。函数
缺点: url路由粒度过粗。须要知道全部服务地址才能完成映射。
方法二:服务映射(serviceId)
既然eureka中已经有咱们的配置信息,那咱们能够借助他来完成地址映射。
zuul.routes.api-a.path=/api-a/**
zuul.routes.api-a.serviceId=compute-service
eureka.client.serviceUrl.defaultZone=http://localhost:8761/eureka/
定义过滤
public class AccessFilter extends ZuulFilter {
/*filterType:返回一个字符串表明过滤器的类型,在zuul中定义了四种不一样生命周期的过滤器类型,具体以下: pre:能够在请求被路由以前调用 routing:在路由请求时候被调用 post:在routing和error过滤器以后被调用 error:处理请求时发生错误时被调用 filterOrder:经过int值来定义过滤器的执行顺序 shouldFilter:返回一个boolean类型来判断该过滤器是否要执行,因此经过此函数可实现过滤器的开关。在上例中,咱们直接返回true,因此该过滤器老是生效。 run:过滤器的具体逻辑。须要注意,这里咱们经过ctx.setSendZuulResponse(false)令zuul过滤该请求,不对其进行路由,而后经过ctx.setResponseStatusCode(401)设置了其返回的错误码,固然咱们也能够进一步优化咱们的返回,好比,经过ctx.setResponseBody(body)对返回body内容进行编辑等。 */
@Override
public Object run() {
RequestContext ctx = RequestContext.getCurrentContext();
HttpServletRequest request = ctx.getRequest();
Object accessToken = request.getParameter("accessToken"); //定义规则:访问url中必须带有accessToken参数
if(accessToken == null) {
ctx.setSendZuulResponse(false);
ctx.setResponseStatusCode(401);
return null;
}
return null;
}
……
}
实例化
//实例化过滤器
@Bean
public AccessFilter accessFilter() {
return new AccessFilter();
}
启动项目,若是访问的url中不含有accessToken参数则会报错,只有包含该参数的请求url才会被放行。
Zuul的主要功能:负载均衡、服务路由、服务过滤等,并非新鲜的东西。api gateway相似外观模式,提供统一的入口。负载均衡和路由和Nginx的功能很像,过滤和权限管理相似shiro的权限配置。
万变不离其宗,目的都是在于把这些与服务自己关系不大的东西剥离出来,并且是越早剥离越好,能在Controller处理的毫不放在Service,能在转发前处理的就不要留到转发后。相似你们说的服务的无状态性,over!
回家倒计时四个小时………………