- Zuul 包含了對請求的路由和過濾兩個最主要的功能;
- 路由功能:負責將外部請求轉發到具體的微服務實例上,是實現外部訪問統一入口的基礎;
- 過濾功能:負責對請求的處理過程進行干預,是實現請求校驗,服務聚合等功能的基礎;
- Zuul 服務最終還是會註冊進Eureka;
1. 代理:Zuul提供外部的請求轉發到具體的微服務實例中的服務
2. 路由:Zuul可以對外部訪問實現統一的入口
3. 過濾:Zuul可以對外部訪問進行干預,如請求校驗、服務聚合等
4. Zuul需要配合Eureka使用,需要在Eureka中註冊並獲得其他微服務的信息
5. 理解:Zuul就像大樓的保安,可以請他找人(代理),找的人在外面叫什麼名字(路由),准不准你進樓(過濾)。因爲保安屬於物業公司,所以保安要在物業公司註冊,所獲得的信息也來源於物業公司(與Eureka的關係)
[Zuul的源碼]: http://github.com/Netflix/zuul
路由基本配置
新建 microservicecloud-zuul-gateway-9527
1. 構建新的Zuul模塊並在pom.xml中加入依賴(Zuul和Eureka必須同時加入)
<!-- zuul 路由網關 -->
<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>
2. 新建application.yml文件並配置(一定要向Eureka註冊,因爲Zuul本身也是一個微服務)server:
port: 9527
spring:
application:
name: microservicecloud-zuul-gateway
eureka:
client:
service-url:
defaultZone: http://eureka7001.com:7001/eureka/,http://eureka7002.com:7002/eureka/,http://eureka7003.com:7003/eureka/
instance:
instance-id: gateway-9527.com
prefer-ip-address: true
info:
app.name: noodles-microcloud
company.name: www.google.com
build.artifactId: $project.artifactId$
build.version: $project.version$
3. 修改hosts文件(非必須,不過能更好看出效果)
127.0.0.0 zuul.com
4. 創建主啓動類,並加入@EnableZuulProxy註解@SpringBootApplication
@EnableZuulProxy
public class Zuul_9527_StartSpringCloudApp {
public static void main(String[] args) {
SpringApplication.run(Zuul_9527_StartSpringCloudApp.class, args);
}
5. 啓動測試,訪問規則:步驟3中指定映射+端口號+微服務名稱+訪問路徑// 啓動:// 三個Eureka集羣
// microservicecloud-provider-dept-8001
// 路由:// 測試訪問:
// 不用路由: http://localhost:8001/dept/get/1
// 使用路由: http://myzuul.com:9527/microservicecloud-dept/dept/get/1
路由訪問映射規則
#### 服務名映射和統一公共前綴
當不向暴露真實的服務名時,可以對服務名進行映射,只需在application.yml中配置即可,==具體作用看註釋==
zuul:
routes:
#dept0是可以自定義的只是作爲區分,沒什麼具體意義
dept0.serviceId: microservicecloud-dept
#路徑也是自定義的,支持通配符
dept0.path: /dept10/**
#需要隱藏的服務名,可以使用通配符,配置之後通過這個微服務名訪問就失效了
ignored-services: microservicecloud-* #所有的失效配置"*"
#設置統一公共前綴,設置後訪問路徑:http://zuul.com:9527/nihao/dept10/dept/3
prefix: /nihao
zuul:
ignored-services: microservicecloud-dept # 將原有路由關閉
routes:
prefix: /test # 設置統一公共前綴, 訪問地址:http://myzuul.com:9527/test/mydept/dept/get/1
mydept.serviceId: microservicecloud-dept
mydept.path: /mydept/**
// 修改之前,訪問地址: http://myzuul.com:9527/microservicecloud-dept/dept/get/1// 修改之後,訪問地址: http://myzuul.com:9527/mydept/dept/get/1
==注:因爲Zuul是針對外部訪問管理的,所以配置了隱藏的服務,在系統中其他模塊進行服務名訪問時依然可以正常運行的,這點可以通過打開consumer模塊進行驗證!==