SpringCloud之Zuul(路由網關)

  • 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模塊進行驗證!==

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章