SpringCloud學習系列之六 ----- 路由網關Zuul基礎使用教程

前言

在上篇中介紹了SpringCloud Config的完美使用版本,本篇則介紹基於SpringCloud(基於SpringBoot2.x,.SpringCloud Finchley版)中的路由網關(SpringCloud Zuul)的使用教程。git

SpringCloud Zuul

介紹

Spring Cloud Zuul 主要的功能是提供負載均衡、反向代理、權限認證、動態路由、監控、彈性、安全等的邊緣服務。其主要做用是爲微服務架構提供了前門保護的做用,同時將權限控制這些較重的非業務邏輯內容遷移到服務路由層面,使得服務集羣主體可以具有更高的可複用性和可測試性。github

通俗一點來講,就是對服務提供一層保護,對外界的請求進行過濾轉發到後端服務中。 這裏咱們能夠經過幾張簡單的示例圖來進行了解.。web

不使用路由網關的示例圖:spring

在這裏插入圖片描述

使用路由網關的示例圖:後端

在這裏插入圖片描述

使用路由網關而且加上註冊中心的示例圖:瀏覽器

在這裏插入圖片描述

從上述的示例圖中,咱們發現加了路由網關以後,其實是將一對多的關係轉變成了一對一的關係,這樣的好處是咱們能夠在網關層進行數據合法校驗、權限認證、負載均衡等統一處理,這樣能夠在很大的程度上節省的人力和物力,可是這種方式也有必定的弊端,就是之後新增了服務或者在服務中新增方法,就會使得網關層可能須要進行改動。幸虧在Spring Cloud 有 Zuul 這樣一個組件,經過eureka將網關和微服務之間相互關聯起來,都會在eureka上進行註冊,這樣Zuul就能感知到哪些服務在線,而且能夠經過配置路由規則將請求自動轉發到指定的後端微服務上,這樣即便後續新增了服務或者在服務中新增了某些方法,那麼只需在Zuul層進行簡單配置便可。安全

開發準備

開發環境bash

  • JDK:1.8
  • SpringBoot:2.0.6.RELEASE
  • SpringCloud:Finchley.SR2

注:不必定非要用上述的版本,能夠根據狀況進行相應的調整。須要注意的是SpringBoot2.x之後,jdk的版本必須是1.8以上!架構

服務端

因爲咱們這裏是使用的第三種模式,因此須要使用到Eureka註冊中心,所以這裏咱們也順便弄一個註冊中心服務。 註冊中心這塊配置和代碼和以前springcloud-config配置基本同樣便可。註冊中心新項目的的名稱爲springcloud-zuul-eurekaapp

註冊中心pom配置、application.properties配置和代碼以下:

pom:

<dependencies>
	<dependency>
		<groupId>org.springframework.cloud</groupId>
		<artifactId>spring-cloud-starter-netflix-eureka-server</artifactId>
	</dependency>
複製代碼

application.properties:

spring.application.name=springcloud-zuul-eureka
server.port=8006
eureka.client.register-with-eureka=false
eureka.client.fetch-registry=false
eureka.client.serviceUrl.defaultZone=http://localhost:${server.port}/eureka/
複製代碼

代碼:

@EnableEurekaServer
	@SpringBootApplication
	public class ZuulApplication {
	  public static void main(String[] args) {
	      SpringApplication.run(ZuulApplication.class, args);
	      System.out.println("zuul註冊中心服務啓動...");
	  }
	}

複製代碼

註冊中心服務配置完成以後,咱們在新增一個Zuul服務,該服務的名稱爲springcloud-zuul-gateway,該服務的 pom配置、application.properties配置和代碼以下:

pom:

<dependencies>
	<dependency>
		<groupId>org.springframework.cloud</groupId>
		<artifactId>spring-cloud-starter</artifactId>
	</dependency>
	<dependency>
		<groupId>org.springframework.cloud</groupId>
		<artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
	</dependency>	
	<dependency>
        <groupId>org.springframework.cloud</groupId>
        <artifactId>spring-cloud-starter-netflix-zuul</artifactId>
    </dependency>
</dependencies>
複製代碼

application.properties:

spring.application.name=springcloud-zuul-gateway
server.port = 9009
eureka.client.serviceUrl.defaultZone=http://localhost:8006/eureka/

zuul.routes.hello.path = /hello/**
zuul.routes.hello.url = http://localhost:9010/hello
zuul.routes.hi.path = /hi/**
zuul.routes.hi.url = http://localhost:9011/hi
複製代碼

配置說明:

  • spring.application.name: 這個是指定服務名稱。
  • server.port:服務指定的端口。
  • eureka.client.serviceUrl.defaultZone: 這個是設置與Eureka Server交互的地址,客戶端的查詢服務和註冊服務都須要依賴這個地址。
  • zuul.routes.{route}.path:自定義路由的規則,經過path配置路徑進行過濾;
  • zuul.routes.{route}.url: 自定義路由的規則,訪問上述的路徑會轉發到該配置的地址;

注:上述的zuul.routes.{route}.pathzuul.routes.{route}.url通常來講是做爲傳統的方式進行配置,是不依賴於Eureka,是屬於一對一的配置。例如,訪問:http://localhost:9009/hello/pancm 的話就會跳轉到http://localhost:9010/hello/pancm 地址上。

代碼:

@SpringBootApplication
@EnableDiscoveryClient
@EnableZuulProxy   
public class ZuulApplication {
	public static void main(String[] args) {
		SpringApplication.run(ZuulApplication.class, args);
		 System.out.println("zuul 服務啓動...");
	}
}
	
複製代碼

客戶端

這裏咱們也須要建立兩個客戶端服務,來進行驗證Zuul路由網關是否生效。 建立兩個客戶端服務,名稱分別爲springcloud-zuul-server1springcloud-zuul-server2,兩個pom文件的配置以下:

<dependencies>
	<dependency>
		<groupId>org.springframework.boot</groupId>
		<artifactId>spring-boot-starter-web</artifactId>
	</dependency>
    <dependency>
        <groupId>org.springframework.cloud</groupId>
        <artifactId>spring-cloud-starter</artifactId>
    </dependency>
    <dependency>
        <groupId>org.springframework.cloud</groupId>
        <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
    </dependency>
</dependencies>
複製代碼

兩個application.properties配置文件也基本相同,除了名稱和端口不一致。

springcloud-zuul-server1application.properties配置:

spring.application.name=springcloud-zuul-server1
server.port=9010
eureka.client.serviceUrl.defaultZone=http://localhost:8006/eureka/
複製代碼

springcloud-zuul-server2application.properties配置:

spring.application.name=springcloud-zuul-server2
server.port=9011
eureka.client.serviceUrl.defaultZone=http://localhost:8006/eureka/
複製代碼

springcloud-zuul-server1服務的代碼:

主類

@SpringBootApplication
@EnableDiscoveryClient
public class ZuulServerApplication1 {
	public static void main(String[] args) {
		SpringApplication.run(ZuulServerApplication1.class, args);
		  System.out.println("zuul 第一個服務啓動...");
	}
}
複製代碼

控制層:

@RestController public class ConsumerController {

@RequestMapping("/hello/{name}")
public String index(@PathVariable String name) {
    return name+",Hello World!";
}
複製代碼

}

springcloud-zuul-server2服務的代碼:

主類

@SpringBootApplication
@EnableDiscoveryClient
public class ZuulServerApplication2 {
	public static void main(String[] args) {
		SpringApplication.run(ZuulServerApplication2.class, args);
		  System.out.println("zuul 第二個服務啓動...");
	}
}
複製代碼

控制層:

@RestController
public class ConsumerController {

	@RequestMapping("/hi")
    public String index(@RequestParam String name) {
        return name+",hi!";
    }
}
複製代碼

注:這裏故意將兩個服務的接口參數請求和返回值弄成不同,以便對Zull的功能進行多方面測試。

測試

完成上述的代碼開發後,咱們來進行測試springcloud-zuul是否能夠地址過濾轉發功能。 首先依次啓動springcloud-zuul-eurekaspringcloud-zuul-gatewayspringcloud-zuul-server1springcloud-zuul-server2這四個項目。其中9009是服務springcloud-zuul-gateway的端口,9010是第一個客戶端springcloud-zuul-server1的端口,9011是第二個客戶端springcloud-zuul-server2的端口。 啓動成功以後,在瀏覽器輸入:

http://localhost:9010/hello/pancm

界面返回:

pancm,hello world!!
複製代碼

在瀏覽器輸入:

http://localhost:9011/hi?name=pancm

界面返回:

pancm,hi!
複製代碼

能夠看出程序正常啓動,而且客戶端的接口返回正確! 那麼咱們再來使用一樣路徑來訪問zuul,由於是在本地進行測試,所以只須要更改下端口就能夠了,將上述在瀏覽器訪問的地址的端口自都改爲9009。

在瀏覽器輸入:

http://localhost:9009/hello/pancm

界面返回:

pancm,Hello World!
複製代碼

在瀏覽器輸入:

http://localhost:9009/hi?name=pancm

界面返回:

pancm,hi!
複製代碼

示例圖:

在這裏插入圖片描述
在這裏插入圖片描述
在這裏插入圖片描述
在這裏插入圖片描述

在這裏插入圖片描述

從上述示例中,咱們能夠得出zuul路由網關已經生效了,成功的幫咱們的請求進行了轉發!

其餘

總結

本篇文章主要介紹了關於zuul的基本使用,使用的方式也是單例的,一個路由規則對應一個地址,按照上述的三幅示例圖來講,主要是介紹了第二種。介於篇幅問題,經過Eureka註冊中心方式實現、zuul的詳細配置、 以及zuul的核心模塊過濾器還未講解,這些留在下一篇再來說解。

項目地址

基於SpringBoot2.x、SpringCloud的Finchley版本開發的地址:github.com/xuwujing/sp…

若是感受項目不錯,但願能給個star,謝謝!

音樂推薦

這首純音樂聽起來有種似曾相識的感受,但仔細聽下來,又並不是是本身熟悉的一首。不過真是由於這樣,纔有感受吧。

原創不易,若是感受不錯,但願留言推薦!您的支持是我寫做的最大動力! 版權聲明: 做者:虛無境 博客園出處:www.cnblogs.com/xuwujing CSDN出處:blog.csdn.net/qazwsxpcm     我的博客出處:www.panchengming.com

相關文章
相關標籤/搜索