spring cloud gateway整合sentinel作網關限流


說明: sentinel可以作為各微服務的限流,也可以作為gateway網關的限流組件。 spring cloud gateway有限流功能,但此處用sentinel來作為替待。

說明:sentinel流控可以放在gateway網關端,也可以放在各微服務端。

1,以父工程為基礎,創建子工程

2,添加pom依賴

     <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-gateway</artifactId>
        </dependency>
        <dependency>
            <groupId>com.alibaba.cloud</groupId>
            <artifactId>spring-cloud-starter-alibaba-sentinel</artifactId>
        </dependency>
        <dependency>
            <groupId>com.alibaba.cloud</groupId>
            <artifactId>spring-cloud-alibaba-sentinel-gateway</artifactId>
        </dependency>
        <dependency>
            <groupId>com.alibaba.cloud</groupId>
            <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
        </dependency>

2,添加配置項

server:
  port: 9092
spring:
  cloud:
    nacos:
      discovery:
        register-enabled: false
        server-addr: localhost:8848
        namespace: c22e5019-0bee-43b1-b80b-fc0b9d847501
    sentinel:
      transport:
        dashboard: localhost:8080
        port: 8719
      scg:
        fallback:
          mode: response
          response-status: 455
          response-body: error!
    gateway:
      routes:
        - id: demo_route
          uri: lb://demo
          predicates:
            - Path=/demo/**
        - id: demo2_test
          uri: lb://demo2
          predicates:
            - Path=/user/**
  application:
    name: gateway-sentinel

scg.fallback為sentinel限流后的響應配置

3,啟動類

@SpringBootApplication
@EnableDiscoveryClient
public class GatewaySentinelApplication {
    public static void main(String[] args) {
        
        SpringApplication.run(GatewaySentinelApplication.class, args);
    }
}

4,啟動后,在sentinel控制台可以看到 gateway-sentinel 應用,可以通過控制台設置流控規則。


免責聲明!

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



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