1. 程式人生 > >SpringCloud框架初探(七) :Zuul API路由功能

SpringCloud框架初探(七) :Zuul API路由功能

API閘道器是一個更為智慧的應用伺服器,它的定義類似於面向物件設計模式中的Facade模式,它的存在就像是整個微服務架構系統的門面一樣,所有的外部客戶端訪問都需要經過它來進行排程和過濾。它除了要實現請求路由、 負載均衡、 校驗過濾等功能之外,還需要更多能力,比如與服務治理框架的結合、請求轉發時的熔斷機制、服務的聚合等一系列高階功能。在SpringCloud中了提供了基於NetflixZuul實現的API閘道器元件Spring Cloud Zuul。

簡單來說,就是既具備路由轉發功能,又具備過濾器功能,比如將/aaa/**路徑請求轉發到service-a服務上,將/bbb/***路徑請求轉發到service-b服務上,比如過濾,對請求引數的資訊進行過濾,不符合的進行過濾攔截等。

搭建Zuul閘道器服務:

pom.xml中加入:

<dependency>
	<groupId>org.springframework.cloud</groupId>
	<artifactId>spring-cloud-starter-zuul</artifactId>
</dependency>

@EnableZuulProxy啟用Zuul閘道器服務

@SpringBootApplication
@EnableEurekaClient
@EnableZuulProxy
public class SpringcloudzuulApplication {

  public static void main(String[] args) {
    SpringApplication.run(SpringcloudzuulApplication.class, args);
  }
}

yml配置檔案:

server:
  port: 5580  #埠號
 
spring:
  application:
    name: service-zuul  #服務註冊中心測試名
 
zuul:
  routes:
    api-a:
      path: /user/**
      serviceId: provider-user  #如果是/user/**路徑下的請求,則跳轉到provider-user
    api-b:
      path: /book/**
      serviceId: provider-book  #如果是/book/**路徑下的請求,則跳轉到provider-book
 
eureka:
  client:
    serviceUrl:
      defaultZone: http://user:
[email protected]
:8761/eureka

啟動Eureka註冊中心伺服器,啟動Eureka服務提供者provider-user,啟動Eureka服務提供者provider-book,啟動spring-cloud-zuul閘道器服務。

在這裡插入圖片描述

在這裡插入圖片描述

說明Zuul路由功能起作用了。