1. 場景描述
springcloud剛推出的時候用的是netflix全家桶,路由用的zuul(springcloud-路由Zull),但是據說zull1.0在大資料量訪問的時候存在較大效能問題,2.0就沒整合到springcloud中了,springcloud推出了自己的路由-springcloud gateway,親兒子,目前官網主推。
netfelix的zull路由:
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-zuul</artifactId>
</dependency>
2. 解決方案
2.1 新建springboot專案
在springcloud專案中,新建的專案全部是基於springboot的(springboot與springcloud的關係),新建springboot專案再囉嗦一遍吧(springboot專案快速搭建)
2.1.1 new->project
next->next 更改下專案名稱。
2.1.2 選擇元件
(1)註冊中心客戶端
(2) 選擇springcloud gateway
next->next, 完成。
2.2 類目錄圖
開始介紹springcloud-gateway,為了區分上一篇的關於zull的介紹,專案名稱設定為springgate。
2.3 重點還是三個檔案
2.3.1 pom.xml
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.1.5.RELEASE</version>
<relativePath/> <!-- lookup parent from repository -->
</parent>
<groupId>com.yutong</groupId>
<artifactId>springgateway</artifactId>
<version>0.0.1-SNAPSHOT</version>
<name>springgateway</name>
<description>Demo project for Spring Boot</description>
<properties>
<java.version>1.8</java.version>
<spring-cloud.version>Greenwich.SR1</spring-cloud.version>
</properties>
<dependencies>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-gateway</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
</dependencies>
<dependencyManagement>
<dependencies>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-dependencies</artifactId>
<version>${spring-cloud.version}</version>
<type>pom</type>
<scope>import</scope>
</dependency>
</dependencies>
</dependencyManagement>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
</build>
</project>
說明,重點就兩個starter:
(1)gateway,不同於zull,這個是直接位於spring-cloud下面,是springcloud的嫡系部隊。
(2)註冊中心客戶端,不多說了
2.3.2 啟動類application
package com.yutong.springgateway;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.gateway.route.RouteLocator;
import org.springframework.cloud.gateway.route.builder.RouteLocatorBuilder;
import org.springframework.context.annotation.Bean;
@SpringBootApplication
public class SpringgatewayApplication {
@Value("${test.uri}")
private String uri;
@Bean
public RouteLocator customRouteLocator(RouteLocatorBuilder builder) {
return builder.routes()
//basic proxy
.route(r -> r.path("/**")
.uri(uri)
).build();
}
public static void main(String[] args) {
SpringApplication.run(SpringgatewayApplication.class, args);
}
}
說明:
(1)不同於路由zull,需要zull的標籤,這裡只需要springboot的啟動標籤@SpringBootApplication就可以了。
(2)增加@Bean標籤,RouteLocator 是路由規則,這個稍微複雜點,示例中只做了簡單配置,路由規則用於過濾控制路由等,可根據具體需求,參考路由規則API進行設定。
2.3.3 配置類application.yml
test:
uri: lb://client
spring:
application:
name: springgateway
cloud:
gateway:
discovery:
locator:
lower-case-service-id: true
eureka:
client:
service-url:
defaultZone: http://localhost:8761/eureka
server:
port: 9000
說明:
(1)第一行的uri在啟動類application中用到,指訪問的客戶端服務,client為註冊中心客戶端服務名稱。
(2)defaultZone為註冊中心地址。
(3) 為了區分介紹zull的專案,name設定為:springgateway
2.3.4 效果圖
(1)註冊中心
(2)路由springcloud gateway訪問
說明:
路由訪問的時候不需要指定客戶端名稱client,因為在gateway啟動類中已經指定過了。
I'm 軟體老王,如果覺得還可以的話,關注下唄!如有不準確或疑問的地方,可通過討論區、QQ溝通,多謝!