什么是Zuul?
- Zuul包含了对请求的路由和过滤两个最主要的功能:
- 其中路由功能负责将外部请求转发到具体的微服务实例上,是实现外部访问统一入口的基础。
- 而过滤器功能则负责对请求的处理过程进行干预,是实现请求校验,服务聚合等功能的基础。
- Zuul和Eureka进行整合,将Zuul自身注册为Eureka服务治理下的应用,同时从Eureka中获得其他微服务的消息,也即以后的访问微服务都是通过Zuul跳转后获得。
- 注意:Zuul服务最终还是会注册进Eureka
- 提供:代理 + 路由 + 过滤 三大功能!
Zuul能干嘛?
- 路由
- 过滤
Zuul测试:
- 修改host文件,模拟不同的服务器
1. 建立Moudle,添加依赖
<dependencies>
<dependency>
<groupId>com.qk</groupId>
<artifactId>springcloud-01-api</artifactId>
<version>1.0-SNAPSHOT</version>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<!--ribbon-->
<!-- https://mvnrepository.com/artifact/org.springframework.cloud/spring-cloud-starter-ribbon -->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-ribbon</artifactId>
<version>1.4.7.RELEASE</version>
</dependency>
<!--消费方从服务注册中心获知有哪些地址可用:因此也需要Eureka-->
<!--Eureka客户端-->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-eureka</artifactId>
<version>1.4.7.RELEASE</version>
</dependency>
<!--Hystrix-->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-hystrix</artifactId>
<version>1.4.7.RELEASE</version>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-hystrix-dashboard</artifactId>
<version>1.4.7.RELEASE</version>
</dependency>
<!--zuul-->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-zuul</artifactId>
<version>1.4.7.RELEASE</version>
</dependency>
</dependencies>
2. 编写配置文件
server:
port: 9527
spring:
application:
name: springcloud-zull
eureka:
client:
service-url:
defaultZone: http://eureka7001.com:7001/eureka/,http://eureka7002.com:7002/eureka/,http://eureka7003.com:7003/eureka/
instance:
instance-id: gateway9527.com
prefer-ip-address: false
3. 主启动类添加注解启动
@SpringBootApplication
@EnableZuulProxy
public class ZuulApplication_9527 {
public static void main(String[] args) {
SpringApplication.run(ZuulApplication_9527.class,args);
}
}
4. 测试
- 启动Eureka集群
- 启动8002服务提供者,注册到注册中心
- 启动zuul,注册到注册中心
- 访问注册中心,查看服务是否注册成功
- 查看结果:
- 不用路由 :http://localhost:8002/dept/get/2
- 使用路由 :http://myzuul.com:9527/springcloud-provider-dept/dept/get/2(网关 / 微服务名字 / 具体的服务)
路由访问映射规则
- 问题:http://myzuul.com:9527/springcloud-provider-dept/dept/get/2 这样去访问的话,就暴露了我们真实微服务的名称!这不是我们需要的!怎么处理呢?
解决方法:修改配置文件,增加路由映射
zuul:
routes:
myqk.serviceId: SPRINGCLOUD-PROVIDER-DEPT #可以自定义映射关系,但必须有serviceId和path
myqk.path: /qk/**
- 配置前访问:http://myzuul.com:9527/springcloud-provider-dept/dept/get/2
- 配置后访问:http://myzuul.com:9527/qk/dept/get/2
- 问题,现在访问原路径依旧可以访问!这不是我们所希望的!
- 继续添加配置文件,忽略服务名访问
zuul:
routes:
myqk.serviceId: SPRINGCLOUD-PROVIDER-DEPT #可以自定义映射关系,但必须有serviceId和path
myqk.path: /qk/**
ignored-services: springcloud-provider-dept #经测试,忽略服务名要转换成小写才生效,但是映射路径的大小写都不影响
- 有多个需要隐藏,怎么办呢?
- 继续添加通用配置
zuul:
routes:
myqk.serviceId: SPRINGCLOUD-PROVIDER-DEPT #可以自定义映射关系,但必须有serviceId和path
myqk.path: /qk/**
ignored-services: "*" #经测试,忽略服务名要转换成小写才生效,但是映射路径的大小写都不影响
设置统一公共前缀
zuul:
routes:
myqk.serviceId: SPRINGCLOUD-PROVIDER-DEPT #可以自定义映射关系,但必须有serviceId和path
myqk.path: /qk/**
ignored-services: "*" #经测试,忽略服务名要转换成小写才生效,但是映射路径的大小写都不影响
prefix: /me
- 设置前缀以后:http://myzuul.com:9527/me/qk/dept/get/2
- 不加前缀就访问不了