API网关是对外服务的一个人口, 其隐藏了内部架构的实现, 是微服务架构中必不可 少的一个组件。API网关可以为我们管理大量的API接口, 还可以对接客户、适配协议、 进行安全认证、转发路由、限制流量、监控日志、防止爬虫、进行灰度发布等。
随着业务的发展,服务越来越多,前端用户如何调用微服务就成了一个难题。比如用 户评估一个小区,评估完成之后需要展示小区详情、房价走势、成交数据、挂牌数据等, 这些信息都在不同的服务中,前端系统想要实现这么一个功能就需要和众多的服务进行交 互,调用它们提供的接口,这样性能肯定是低的。而且前端系统的逻辑更复杂了,它需要 知道所有提供信息的微服务。这个时候API网关的作用就体现出来了, 通过API聚合内部 服务, 提供统一对外的API接口给前端系统, 屏蔽内部实现细节。
1.Zuul简介
Zuul是Netflix OSS中的一员, 是一个基于JVM路由和服务端的负载均衡器。提供路由、监控、弹性、安全等方面的服务框架。Zuul能够与Eureka、Ribbon、Hystrix等组件配合使用。
Zuul的核心是过滤器, 通过这些过滤器我们可以扩展出很多功能, 比如:
·动态路由:动态地将客户端的请求路由到后端不同的服务,做一些逻辑处理,比如聚合多个服务的数据返回。
·请求监控:可以对整个系统的请求进行监控,记录详细的请求响应日志,可以实时 统计出当前系统的访问量以及监控状态。
·认证鉴权:对每一个访问的请求做认证,拒绝非法请求,保护好后端的服务。
·压力测试:压力测试是一项很重要的工作,像一些电商公司需要模拟更多真实的用 户并发量来保证重大活动时系统的稳定。通过Zuul可以动态地将请求转发到后端服务的集群中,还可以识别测试流量和真实流量,从而做一些特殊处理。
·灰度发布:灰度发布可以保证整体系统的稳定,在初始灰度的时候就可以发现、调 整问题,以保证其影响度。
2.使用Zuul构建微服务网关
2.1 简单使用
创建一个maven项目fangjia-fsh-api在pom.xml中增加Spring Cloud项目的依赖,然后加入Zuul的依赖:
<dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-zuul</artifactId> </dependency>
配置文件信息:
spring.application.name=fangjia-fsh-api server.port=2103 #通过zuul.routes来配置路由转发,cxytiandi是自定义的名称 #当访问cxytiandi/**开头的地址时就会跳转到http://baidu.com/上 zuul.routes.cxytiandi.path=/cxytiandi/** zuul.routes.cxytiandi.url=http://baidu.com/
接下来创建一个启动类,通过@EnableZuulProxy开启路由代理功能,代码如下:
@SpringBootApplication @EnableZuulProxy public class ZuulApplication { public static void main(String[] args) { SpringApplication.run(ZuulApplication.class, args); } }
2.2 集成Eureka
通过对上节的学习,我们已经可以简单的使用Zuul进行路由的转发了,在实际使用中我们通常是用Zuul来代理请求转发到内部的服务上去,同一为外部提供服务。
内部服务的数量会很多,而且可以随时扩展,我们不可能增加一个服务就改一次路由的配置,所以也得通过结合Eureka来实现动态的路由转发功能。首先要添加Eureka的依赖:
<dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-eureka</artifactId> </dependency>
启动类不需要修改,因为@EnableZuulProxy已经自带了@EnableDiscoveryClient,只需在配置文件中增加Eureka的地址即可:
eureka.client.serverUrl.defaultZone=http://yinjihuan:123456@master:8761/eureka/
重启服务,我们可以通过默认的转发规则来访问Eureka中的服务。比如访问我们之前定义的hello接口,就相当于通过http://localhost:2013/fsh-house/house/hello来访问fsh-house服务中的hello接口。访问规则是“API网关地址+访问的服务名称+接口URI”。
11