springcloud-路由gateway


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溝通,多謝!


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM