源码地址:SpringCloud学习源码
API网关是一个更为智能的应用服务器,它的定义类似于面向对象设计模式中的Facade模式,它的存在就像是整个微服务架构系统的门面一样,所有的外部客户端访问都需要经过它来进行调度和过滤。它除了要实现请求路由、 负载均衡、 校验过滤等功能之外,还需要更多能力,比如与服务治理框架的结合、请求转发时的熔断机制、服务的聚合等一系列高级功能。在SpringCloud中了提供了基于NetflixZuul实现的API网关组件Spring Cloud Zuul。
简单来说,就是既具备路由转发功能,又具备过滤器功能,比如将/aaa/**路径请求转发到service-a服务上,将/bbb/***路径请求转发到service-b服务上,比如过滤,对请求参数的信息进行过滤,不符合的进行过滤拦截等。
搭建Zuul网关服务:
pom.xml中加入:
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-zuul</artifactId>
</dependency>
@EnableZuulProxy启用Zuul网关服务
@SpringBootApplication
@EnableEurekaClient
@EnableZuulProxy
public class SpringcloudzuulApplication {
public static void main(String[] args) {
SpringApplication.run(SpringcloudzuulApplication.class, args);
}
}
yml配置文件:
server:
port: 5580 #端口号
spring:
application:
name: service-zuul #服务注册中心测试名
zuul:
routes:
api-a:
path: /user/**
serviceId: provider-user #如果是/user/**路径下的请求,则跳转到provider-user
api-b:
path: /book/**
serviceId: provider-book #如果是/book/**路径下的请求,则跳转到provider-book
eureka:
client:
serviceUrl:
defaultZone: http://user:password123@localhost:8761/eureka
启动Eureka注册中心服务器,启动Eureka服务提供者provider-user,启动Eureka服务提供者provider-book,启动spring-cloud-zuul网关服务。
访问网关服务:
http://localhost:5580/user/simple/1 可以查询用户信息
访问网关服务:
http://localhost:5580/book/simple/1 可以查询图书信息
说明Zuul路由功能起作用了。