SpringCloud框架初探(七) :Zuul API路由功能
阿新 • • 發佈:2018-12-13
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路由功能起作用了。