Zuul简介
Zuul的主要功能是路由转发和过滤器。路由功能是微服务的一部分,比如/api/user转发到到user服务,
/api/shop转发到到shop服务。zuul默认和Ribbon结合实现了负载均衡的功能。
关键依赖
<dependencies>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-zuul</artifactId>
</dependency>
</dependencies>
在启动类加上注解@EnableZuulProxy,开启zuul的功能:
@SpringBootApplication
@EnableZuulProxy
public class DemoZuulApplication {
public static void main(String[] args) {
SpringApplication.run(DemoZuulApplication.class, args);
}
}
然后是application.yml配置文件
server:
port: 8094
spring:
application:
name: demo-zuul
eureka:
client:
service-url:
defaultZone: http://127.0.0.1:8090/eureka/
instance:
prefer-ip-address: true
zuul:
routes:
client-one:
path: /api-co/**
serviceId: client-one
Client-two:
path: /api-ct/**
serviceId: Client-two
这里注意,大多数问题出自配置文件及启动类,严格按照格式来编写。zuul网关的编写有俩种方式。但是都大同小异。
一下片段就是一个网关,要写多个继续拼接,上面我写了俩个。
方式1:
client-one:
path: /api-co/**
serviceId: client-one
client-one : 网关的名字不要重复即可,这里问题不大
path : 这个很重要,网关路径,记住一定要/xxx/** 这种格式,俩根 “/” 都不能少(说多了都是泪)。
serviceId : 服务名,对应注册中心的服务名即可
方式2:
client-one:
path: /api-co/**
url: http://localhost:8091/
前俩个都是一样的
url :填对应服务的ip地址(一般demo都是localhost)和端口,效果和serviceId:服务名是一致的。
接下来就是访问
使用网关访问时,端口一定要是网关的端口,切记
不使用网关:
使用网关:
一个简单的zuul网关就实现了。