欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

詳解Spring Cloud Gateway基于服務(wù)發(fā)現(xiàn)的默認路由規(guī)則

 更新時間:2019年05月29日 09:26:00   作者:lockie_zou  
這篇文章主要介紹了詳解Spring Cloud Gateway基于服務(wù)發(fā)現(xiàn)的默認路由規(guī)則,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧

1.Spring Gateway概述

1.1 什么是Spring Cloud Gateway

Spring Cloud Gateway是Spring官方基于Spring 5.0,Spring Boot 2.0和Project Reactor等技術(shù)開發(fā)的網(wǎng)關(guān),Spring Cloud Gateway旨在為微服務(wù)架構(gòu)提供一種簡單而有效的統(tǒng)一的API路由管理方式。Spring Cloud Gateway作為Spring Cloud生態(tài)系中的網(wǎng)關(guān),目標(biāo)是替代Netflix ZUUL,其不僅提供統(tǒng)一的路由方式,并且基于Filter鏈的方式提供了網(wǎng)關(guān)基本的功能,例如:安全,監(jiān)控/埋點,和限流等。


1.2 Spring Cloud Gateway的功能

Spring Cloud Gateway 的特征:

  • 基于 Spring Framework 5,Project Reactor 和 Spring Boot 2.0
  • 動態(tài)路由
  • Predicates 和 Filters 作用于特定路由
  • 集成 Hystrix 斷路器
  • 集成 Spring Cloud DiscoveryClient
  • 易于編寫的 Predicates 和 Filters
  • 限流
  • 路徑重寫

2. Spring Cloud Gateway的工程流程

客戶端向 Spring Cloud Gateway 發(fā)出請求。然后在 Gateway Handler Mapping 中找到與請求相匹配的路由,將其發(fā)送到 Gateway Web Handler。Handler 再通過指定的過濾器鏈來將請求發(fā)送到我們實際的服務(wù)執(zhí)行業(yè)務(wù)邏輯,然后返回。
過濾器之間用虛線分開是因為過濾器可能會在發(fā)送代理請求之前(“pre”)或之后(“post”)執(zhí)行業(yè)務(wù)邏輯。

2.1 Pre和POST兩種類型的過濾器

3.基于服務(wù)發(fā)現(xiàn)的默認路由規(guī)則

3.1 zuul和gateway的默認路由規(guī)則

3.1.1 zuul的默認路由規(guī)則

說明默認情況下,Zuul會代理所有注冊到Eureka Server的微服務(wù),并且Zuul的路由規(guī)則如下:

http://ZUUL_HOST:ZUUL_PORT/微服務(wù)在Eureka上的serviceId/** 會被轉(zhuǎn)發(fā)到serviceId對應(yīng)的微服務(wù)。

http://localhost:8040/sc-zuul-first-provider/sc/order/2

3.1.2 gateway的默認路由規(guī)則

規(guī)則:http://Gateway_HOST:Gateway_PORT/大寫的serviceId/**

其中微服務(wù)應(yīng)用名默認大寫訪問。

實例代碼:

模塊 說明 端口
eureka-service Eureka Server注冊中心 5000
gateway-service Spring Cloud Gateway Sever 5001
order-service 服務(wù)提供者 5100
user-service 服務(wù)消費者 5200

分別新建上面這四個服務(wù),詳見 spring cloud Finchley環(huán)境搭建

其中g(shù)ateway-service服務(wù)的application.yml配置文件如下:

spring:
 application:
 name: gateway-service
 cloud:  # spring cloud gateway 路由配置方式
 gateway:
  discovery:  #是否與服務(wù)發(fā)現(xiàn)組件進行結(jié)合,通過 serviceId(必須設(shè)置成大寫) 轉(zhuǎn)發(fā)到具體的服務(wù)實例。默認為false,設(shè)為true便開啟通過服務(wù)中心的自動根據(jù) serviceId 創(chuàng)建路由的功能。
  locator:  #路由訪問方式:http://Gateway_HOST:Gateway_PORT/大寫的serviceId/**,其中微服務(wù)應(yīng)用名默認大寫訪問。
   enabled: true
  routes:
  - id: 163      #網(wǎng)關(guān)路由到網(wǎng)易官網(wǎng)
  uri: http://www.163.com/
  predicates:
   - Path=/163/**
#  - id: ORDER-SERVICE   #網(wǎng)關(guān)路由到訂單服務(wù)order-service
#  uri: lb://ORDER-SERVICE
#  predicates:
#   - Path=/ORDER-SERVICE/**
#  - id: USER-SERVICE   #網(wǎng)關(guān)路由到用戶服務(wù)user-service
#  uri: lb://USER-SERVICE
#  predicates:
#   - Pach=/USER-SERVICE/**

server:
 port: 5001


logging:
 level:
 org.springframework.cloud.gateway: trace
 org.springframework.http.server.reactive: debug
 org.springframework.web.reactive: debug
 reactor.ipc.netty: debug


eureka:
 client:
 service-url:
  defaultZone: http://localhost:5000/eureka/

feign:
 hystrix:
 enabled: true

配置項說明:

spring.cloud.gateway.discovery.locator.enabled:是否與服務(wù)發(fā)現(xiàn)組件進行結(jié)合,通過 serviceId 轉(zhuǎn)發(fā)到具體的服務(wù)實例。默認為false,設(shè)為true便開啟通過服務(wù)中心的自動根據(jù) serviceId 創(chuàng)建路由的功能。

eureka.client.service-url.defaultZone: http://localhost:5000/eureka/,指定注冊中心的地址,Spring Cloud Gateway從注冊中心獲取已經(jīng)注冊的服務(wù)列表。

logging.level.org.springframework.cloud.gateway: debug,開啟spring-Cloud-gateway的日志級別為debug,方便debug調(diào)試。

3.3 啟動測試

3.3.1 錯誤的路由規(guī)則訪問

訪問Spring Cloud Gateway對應(yīng)的server,當(dāng)訪問http://localhost:5000/order-service/order/getOrderPort的時候,會出現(xiàn)報錯內(nèi)容如下所示:


正確的Spring Cloud Gateway的默認路由規(guī)則:http://Gateway_HOST:Gateway_PORT/大寫的serviceId/**

3.3.2 Gateway正確的路由規(guī)則測試


以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • 深入理解Spring Boot的日志管理

    深入理解Spring Boot的日志管理

    這篇文章主要給大家深入的介紹了Spring Boot日志管理的相關(guān)資料,文中介紹的很詳細,需要的朋友可以參考借鑒,下面來一起看看吧。
    2017-02-02
  • Spring中常用注解的用法

    Spring中常用注解的用法

    這篇文章主要介紹了Spring中常用注解的用法,Spring注解方式減少了配置文件內(nèi)容,更加便于管理,并且使用注解可以大大提高了開發(fā)效率,注解本身是沒有功能的,和xml一樣,注解和xml都是一種元數(shù)據(jù),元數(shù)據(jù)即解釋數(shù)據(jù)的數(shù)據(jù),也就是所謂的配置,需要的朋友可以參考下
    2023-08-08
  • 在SpringBoot中使用YourKit進行性能調(diào)優(yōu)的教程詳解

    在SpringBoot中使用YourKit進行性能調(diào)優(yōu)的教程詳解

    在應(yīng)用程序的開發(fā)過程中,性能調(diào)優(yōu)是一個重要的環(huán)節(jié),在SpringBoot應(yīng)用程序中,我們可以使用YourKit來進行性能調(diào)優(yōu),YourKit是一款非常強大的Java性能調(diào)優(yōu)工具,在本文中,我們將介紹如何在 SpringBoot應(yīng)用程序中使用YourKit進行性能調(diào)優(yōu)
    2023-06-06
  • 使用java寫的矩陣乘法實例(Strassen算法)

    使用java寫的矩陣乘法實例(Strassen算法)

    這篇文章主要給大家介紹了關(guān)于如何使用java寫的矩陣乘法(Strassen算法)的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-02-02
  • Flink入門級應(yīng)用域名處理示例

    Flink入門級應(yīng)用域名處理示例

    這篇文章主要介紹了一個比較簡單的入門級Flink應(yīng)用,代碼很容易寫,主要用到的算子有FlatMap、KeyBy、Reduce,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-03-03
  • Java使用非覆蓋的方法實現(xiàn)替換PDF中的文本

    Java使用非覆蓋的方法實現(xiàn)替換PDF中的文本

    這篇文章主要為大家詳細介紹了Java如何使用非覆蓋的方法實現(xiàn)替換PDF中的文本,文中的示例代碼講解詳細,感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下
    2024-02-02
  • 一文掌握Spring?中?@Component?和?@Bean?區(qū)別(最新推薦)

    一文掌握Spring?中?@Component?和?@Bean?區(qū)別(最新推薦)

    ?@Component?用于標(biāo)識一個普通的類,@Bean用于配置類里面,在方法上面聲明和配置?Bean?對象,這篇文章主要介紹了Spring?中?@Component?和?@Bean?區(qū)別(最新推薦),需要的朋友可以參考下
    2024-04-04
  • spring boot結(jié)合Redis實現(xiàn)工具類的方法示例

    spring boot結(jié)合Redis實現(xiàn)工具類的方法示例

    這篇文章主要介紹了spring boot結(jié)合Redis實現(xiàn)工具類的方法示例,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-11-11
  • springboot整合mail實現(xiàn)郵箱的發(fā)送功能

    springboot整合mail實現(xiàn)郵箱的發(fā)送功能

    本文分步驟給大家介紹springboot整合mail實現(xiàn)郵箱的發(fā)送功能,代碼簡單易懂,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友參考下吧
    2021-09-09
  • Java concurrency之鎖_動力節(jié)點Java學(xué)院整理

    Java concurrency之鎖_動力節(jié)點Java學(xué)院整理

    這篇文章主要為大家詳細介紹了Java concurrency之鎖的相關(guān)資料,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-06-06

最新評論