Zuul的主要功能是路由转发和过滤器。客户端请求通过路由网关调用相应的服务。这样客户端只需要和网关交互,而无需直接调用特定微服务的接口,而且方便监控,易于认证,减少客户端和各个微服务之间的交互次数。
实现Zuul的方式如下:
1. 配置pom
<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>
这里我们引入Eureka,需要将zuul注册到注册中心上去这样才能拉取服务列表。
2. 创建启动类
启动类上需要添加@EnableZuulProxy
@SpringBootApplication
@EnableDiscoveryClient
@EnableZuulProxy
public class ZuulApplication3001 {
public static void main(String[] args) {
SpringApplication.run(ZuulApplication3001.class, args);
}
}
3. 增加配置文件
server:
port: 3001
eureka:
instance:
preferIpAddress:true
client:
serviceUrl:
defaultZone: http://localhost:7001/eureka/
spring:
application:
name: Zuul3001
zuul:
prefix: /nikola
routes:
ribbon:
path: /ribbonClass/**
serviceId: GateView8001
feign:
path: /feignClass/**
serviceId: GateView8001
路由规则为前缀为/nikola
。serviceId对应注册到Eureka的服务实例名。path为访问该服务的请求路径。
3. 测试
在浏览器中输入:http://localhost:3001/nikola/feignClass/class; 回车显示
[{“id”:1,“classcode”:“001”,“classname”:“class1”,“description”:“good class”,“operator”:“admin”,“makedate”:1557759681000,“modifydate”:1557759681000,“bak1”:null,“bak2”:null,“bak3”:null,“bak4”:null,“bak5”:null}]