API网关(一)
2021-03-14 18:45
标签:main border 文件信息 div 电商 spring 核心 定义 并发 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的依赖: 配置文件信息: 接下来创建一个启动类,通过@EnableZuulProxy开启路由代理功能,代码如下: 2.2 集成Eureka 通过对上节的学习,我们已经可以简单的使用Zuul进行路由的转发了,在实际使用中我们通常是用Zuul来代理请求转发到内部的服务上去,同一为外部提供服务。 内部服务的数量会很多,而且可以随时扩展,我们不可能增加一个服务就改一次路由的配置,所以也得通过结合Eureka来实现动态的路由转发功能。首先要添加Eureka的依赖: 启动类不需要修改,因为@EnableZuulProxy已经自带了@EnableDiscoveryClient,只需在配置文件中增加Eureka的地址即可: 重启服务,我们可以通过默认的转发规则来访问Eureka中的服务。比如访问我们之前定义的hello接口,就相当于通过http://localhost:2013/fsh-house/house/hello来访问fsh-house服务中的hello接口。访问规则是“API网关地址+访问的服务名称+接口URI”。 11 API网关(一) 标签:main border 文件信息 div 电商 spring 核心 定义 并发 原文地址:https://www.cnblogs.com/xc-xinxue/p/12459955.htmlspring.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/
@SpringBootApplication
@EnableZuulProxy
public class ZuulApplication {
public static void main(String[] args) {
SpringApplication.run(ZuulApplication.class, args);
}
}
eureka.client.serverUrl.defaultZone=http://yinjihuan:123456@master:8761/eureka/