Zuul的使用,路由訪問映射規則


一、Zuul的介紹

Zuul包含了對請求的路由過濾兩個最主要的功能:

      其中路由功能負責將外部請求轉發到具體的微服務實力上,是實現外部訪問統一入口基礎而過濾器功能則負責對請求的處理過程進行干預,是實現請求校驗、服務聚合等功能的基礎。

  Zuul和eureka進行整合,將Zuul自身注冊到Eureka服務治理下的應用,同時從Eureka中獲得其他微服務的消息,也即以后的訪問微服務都是通過Zuul跳轉后獲得的。

注意:Zuul最終還是會注冊到Eureka。

提供=代理+路由+過濾三大功能

二、路由的基本配置

1、新建工程:microservicecloud-zuul-gateway-9527

2、pom.xml文件添加依賴的jar

 <dependencies>
        <!-- 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>
        <!-- actuator監控 -->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-actuator</artifactId>
        </dependency>
        <!-- hystrix容錯 -->
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-hystrix</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-config</artifactId>
        </dependency>
        <!-- 日常標配 -->
        <dependency>
            <groupId>com.atguigu.springcloud</groupId>
            <artifactId>microservicecloud-api</artifactId>
            <version>${project.version}</version>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-jetty</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
        </dependency>
        <!-- 熱部署插件 -->
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>springloaded</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-devtools</artifactId>
        </dependency>
    </dependencies>

 

3、yml文件的配置

server: port: 9527 spring: application: name: microservicecloud-zuul-gateway # zuul注冊到Eureka 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: yufeng-microcloud company.name: www.yufeng.com build.artifactId: $project.artifactId$ build.version: $project.version$

4、hosts的修改

(1)打開 C:\Windows\System32\drivers\etc\hosts 文件;

(2)增加:127.0.0.1 myzuul.com

5、主啟動類,添加@EnableZuulProxy

@SpringBootApplication @EnableZuulProxy public class Zuul_9527_StartSpringCloudApp { public static void main(String[] args) { SpringApplication.run(Zuul_9527_StartSpringCloudApp.class); } }

6、測試

(1)啟動三個eureka集群, 一個microservicecloud-provider-dept-8001,啟動路由網關微服務;

(2)不用路由和啟動路由的結果一樣;

不用路由:http://localhost:8001/dept/get/2

啟用路由:http://myzuul.com:9527/microservicecloud-dept/dept/get/2          

 三、路由訪問映射規則

 以上使用 http://myzuul.com:9527/microservicecloud-dept/dept/get/2 訪問,則暴露出了調用的微服務名為 microservicecloud-dept;為了不暴露出微服務的真正名稱,使用路由訪問映射;

1、在yml文件中增加路由映射

# 路由映射 zuul: routes: mydept: serviceId: microservicecloud-dept path: /mydept/**

serviceId:映射的服務名;path:映射成為的路徑;

在yml修改之前使用:http://myzuul.com:9527/microservicecloud-dept/dept/get/2  訪問;

在yml修改之后使用:http://myzuul.com:9527/mydept/dept/get/2  訪問;

2、此時使用 http://myzuul.com:9527/microservicecloud-dept/dept/get/2  和 http://myzuul.com:9527/mydept/dept/get/2  都可以成功的調用該接口,還是會暴露調用的微服務名為microservicecloud-dept;所以需要去讓使用 http://myzuul.com:9527/microservicecloud-dept/dept/get/2  鏈接不能夠訪問;

(1)因此,需要在yml文件中增加原服務的忽略:

# 路由映射 zuul: ignored-services: microservicecloud-dept routes: mydept: serviceId: microservicecloud-dept path: /mydept/**

ignored-services:特別注意此處的配置。通過配置此選項,限制不能通過訪問服務名去訪問微服務

如果想把其他很多的微服務都通過配置忽略掉真實訪問路徑則直接使用 ”*” 來代替。

(2)重啟微服務

<1> 使用原路徑訪問報錯,http://myzuul.com:9527/microservicecloud-dept/dept/get/2 

 <2> 使用路由映射路徑可以正常訪問:http://myzuul.com:9527/mydept/dept/get/2

 (3)在實際的使用時候,有很多個服務器需要限制不能通過服務名去訪問;則在yml做如下的修改:

# 路由映射 zuul: ignored-services: "*" routes: mydept: serviceId: microservicecloud-dept path: /mydept/**

測試結果與上面的結果一樣;

 

3、設置統一公共前綴

(1)修改yml文件,如下所示

# 路由映射 zuul: prefix: /yufeng ignored-services: "*" routes: mydept: serviceId: microservicecloud-dept path: /mydept/**

(2)測試

<1> 在瀏覽器中打開:http://myzuul.com:9527/mydept/dept/get/2,報錯如下:

 <2> 在瀏覽器中打開:http://myzuul.com:9527/yufeng/mydept/dept/get/2,可以正常訪問;

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM