聊聊Spring Cloud Gateway網關路由


簡介

Spring Cloud Gateway是Spring Cloud官方推出的第二代網關框架,取代Zuul網關。網關作為流量的,在微服務系統中有着非常作用。
網關常見的功能有

  • 協議轉換,路由轉發
  • 流量聚合,對流量進行監控,日志輸出
  • 可以在網關層做權限的判斷
  • 限流,作為整個系統的前端工程,對流量進行控制
  • 作為系統的前端邊界,外部流量只能通過網關才能訪問系統
  • 緩存

聊聊Spring Cloud Gateway的PrefixPath及StripPrefix功能

如上圖所示,客戶端向Spring Cloud Gateway發出請求。 如果Gateway Handler Mapping確定請求與路由匹配(這個時候就用到predicate),則將其發送到Gateway web handler處理。 Gateway web handler處理請求時會經過一系列的過濾器鏈。 過濾器鏈被虛線划分的原因是過濾器鏈可以在發送代理請求之前或之后執行過濾邏輯。 先執行所有“pre”過濾器邏輯,然后進行代理請求。 在發出代理請求之后,收到代理服務的響應之后執行“post”過濾器邏輯。這跟zuul的處理過程很類似。在執行所有“pre”過濾器邏輯時,往往進行了鑒權、限流、日志輸出等功能,以及請求頭的更改、協議的轉換;轉發之后收到響應之后,會執行所有“post”過濾器的邏輯,在這里可以響應數據進行了修改,比如響應頭、協議的轉換等。
聊聊Spring Cloud Gateway的PrefixPath及StripPrefix功能

增新一個項目 分別是服務提供方provider,消費方comsumer,注冊中心eureka,網關gateway

聊聊Spring Cloud Gateway的PrefixPath及StripPrefix功能

provider

@RequestMapping("/hello")
@RestController
public class HelloController {
    @GetMapping("")
    public String hello(@RequestParam String name) {
        return "Hello, " + name + "!";
    }
}

comsumer

使用Feign調用

@CommonsLog
@RequestMapping("/hello")
@RestController
public class HelloController {

    @Autowired
    HelloFeignService helloRemote;

    @GetMapping("/{name}")
    public String index(@PathVariable("name") String name)  {
        log.info("the name is " + name);
        return helloRemote.hello(name) + "\n" + new Date().toString();
    }
    
}

增加 Hystrix 斷路器

@FeignClient(name = "producer", fallback = HelloFeignProviderHystrix.class)
public interface HelloFeignService {

    /**
     * @param name
     * @return
     */
    @GetMapping("/hello/")
    String hello(@RequestParam(value = "name") String name);

}

gateway

Spring Cloud gateway內置了很多校驗條件謂語(predicate)來實現路由功能。
有兩種方式配置,一種是配置文件application的方式,一種是代碼配置

a.application配置:

spring:
  application:
    name: sc-gateway-server
  cloud:
    gateway:
      discovery:
        locator:
          # 是否可以通過其他服務的serviceId來轉發到具體的服務實例。默認為false
          # 為true,自動創建路由,路由訪問方式:http://Gateway_HOST:Gateway_PORT/大寫的serviceId/**,其中微服務應用名默認大寫訪問
          enabled: true
      routes:
        - id: host_route
          uri: http://httpbin.org:80/get
          predicates:
            - Host=**.csdn.** # 請求域名攜帶csdn的,則轉發
        - id: query_route
          uri: http://httpbin.org:80/get
          predicates:
            - Query=username, zzz* # 請求參數含有username,且值滿足zzz開頭的,則轉發(對值的匹配可以省略)
        - id: header_route
          uri: http://httpbin.org:80/get
          predicates:
            - Header=request, \d+ # 如果請求頭含有request,且為數字,則轉發

b.代碼配置

gateway也提供了代碼的方式配置,比如我們注釋掉上面的application配置,然后建一個配置類

@Configuration
public class GateWayConfig {

  @Bean
  public RouteLocator routeLocator(RouteLocatorBuilder builder) {
    return builder.routes()
            .route(r -> r.path("/fluent/**")
                    .uri("http://httpbin.org:80/get"))
            .build();

  }

}

在上面的代碼中,我們使用了一個router,該router使用host去斷言請求是否進入該路由,當請求的host有“/fluent/**”,都會進入該router,重定向到了“http://httpbin.org:80/get”。

Spring Cloud Gateway內置了許多Predict,這些Predict的源碼在org.springframework.cloud.gateway.handler.predicate包中。

列舉各種Predicate如下圖:
聊聊Spring Cloud Gateway的PrefixPath及StripPrefix功能

啟動項目
聊聊Spring Cloud Gateway的PrefixPath及StripPrefix功能

輸入URL 可以看到轉到了 comsumer 的地址返回了provider的內容
聊聊Spring Cloud Gateway的PrefixPath及StripPrefix功能

項目地址:https://github.com/codeyuyu/SpringCloudTc.git

作者:codeyuyu
鏈接:http://www.imooc.com/article/284048


免責聲明!

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



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