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

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.artifactIdproject.artifactId
build.version: project.versionproject.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/**
在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,可以正常訪問;
在這裏插入圖片描述

發佈了18 篇原創文章 · 獲贊 5 · 訪問量 3萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章