1.Spring Gateway概述
站在用戶(hù)的角度思考問(wèn)題,與客戶(hù)深入溝通,找到尋甸網(wǎng)站設(shè)計(jì)與尋甸網(wǎng)站推廣的解決方案,憑借多年的經(jīng)驗(yàn),讓設(shè)計(jì)與互聯(lián)網(wǎng)技術(shù)結(jié)合,創(chuàng)造個(gè)性化、用戶(hù)體驗(yàn)好的作品,建站類(lèi)型包括:網(wǎng)站制作、網(wǎng)站建設(shè)、企業(yè)官網(wǎng)、英文網(wǎng)站、手機(jī)端網(wǎng)站、網(wǎng)站推廣、域名與空間、雅安服務(wù)器托管、企業(yè)郵箱。業(yè)務(wù)覆蓋尋甸地區(qū)。
1.1 什么是Spring Cloud Gateway
Spring Cloud Gateway
是Spring官方基于Spring 5.0,Spring Boot 2.0和Project Reactor等技術(shù)開(kāi)發(fā)的網(wǎng)關(guān),Spring Cloud Gateway旨在為微服務(wù)架構(gòu)提供一種簡(jiǎn)單而有效的統(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)控/埋點(diǎn),和限流等。
1.2 Spring Cloud Gateway的功能
Spring Cloud Gateway 的特征:
2. Spring Cloud Gateway的工程流程
客戶(hù)端向 Spring Cloud Gateway 發(fā)出請(qǐng)求。然后在 Gateway Handler Mapping 中找到與請(qǐng)求相匹配的路由,將其發(fā)送到 Gateway Web Handler。Handler 再通過(guò)指定的過(guò)濾器鏈來(lái)將請(qǐng)求發(fā)送到我們實(shí)際的服務(wù)執(zhí)行業(yè)務(wù)邏輯,然后返回。
過(guò)濾器之間用虛線(xiàn)分開(kāi)是因?yàn)檫^(guò)濾器可能會(huì)在發(fā)送代理請(qǐng)求之前(“pre”)或之后(“post”)執(zhí)行業(yè)務(wù)邏輯。
2.1 Pre和POST兩種類(lèi)型的過(guò)濾器
3.基于服務(wù)發(fā)現(xiàn)的默認(rèn)路由規(guī)則
3.1 zuul和gateway的默認(rèn)路由規(guī)則
3.1.1 zuul的默認(rèn)路由規(guī)則
說(shuō)明默認(rèn)情況下,Zuul會(huì)代理所有注冊(cè)到Eureka Server的微服務(wù),并且Zuul的路由規(guī)則如下:
http://ZUUL_HOST:ZUUL_PORT/微服務(wù)在Eureka上的serviceId/** 會(huì)被轉(zhuǎn)發(fā)到serviceId對(duì)應(yīng)的微服務(wù)。
http://localhost:8040/sc-zuul-first-provider/sc/order/2
3.1.2 gateway的默認(rèn)路由規(guī)則
規(guī)則:http://Gateway_HOST:Gateway_PORT/大寫(xiě)的serviceId/**
其中微服務(wù)應(yīng)用名默認(rèn)大寫(xiě)訪(fǎng)問(wèn)。
實(shí)例代碼:
模塊 | 說(shuō)明 | 端口 |
---|---|---|
eureka-service | Eureka Server注冊(cè)中心 | 5000 |
gateway-service | Spring Cloud Gateway Sever | 5001 |
order-service | 服務(wù)提供者 | 5100 |
user-service | 服務(wù)消費(fèi)者 | 5200 |
分別新建上面這四個(gè)服務(wù),詳見(jiàn) 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)組件進(jìn)行結(jié)合,通過(guò) serviceId(必須設(shè)置成大寫(xiě)) 轉(zhuǎn)發(fā)到具體的服務(wù)實(shí)例。默認(rèn)為false,設(shè)為true便開(kāi)啟通過(guò)服務(wù)中心的自動(dòng)根據(jù) serviceId 創(chuàng)建路由的功能。 locator: #路由訪(fǎng)問(wèn)方式:http://Gateway_HOST:Gateway_PORT/大寫(xiě)的serviceId/**,其中微服務(wù)應(yīng)用名默認(rèn)大寫(xiě)訪(fǎng)問(wèn)。 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)路由到用戶(hù)服務(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
配置項(xiàng)說(shuō)明:
spring.cloud.gateway.discovery.locator.enabled:是否與服務(wù)發(fā)現(xiàn)組件進(jìn)行結(jié)合,通過(guò) serviceId 轉(zhuǎn)發(fā)到具體的服務(wù)實(shí)例。默認(rèn)為false,設(shè)為true便開(kāi)啟通過(guò)服務(wù)中心的自動(dòng)根據(jù) serviceId 創(chuàng)建路由的功能。
eureka.client.service-url.defaultZone: http://localhost:5000/eureka/,指定注冊(cè)中心的地址,Spring Cloud Gateway從注冊(cè)中心獲取已經(jīng)注冊(cè)的服務(wù)列表。
logging.level.org.springframework.cloud.gateway: debug,開(kāi)啟spring-Cloud-gateway的日志級(jí)別為debug,方便debug調(diào)試。
3.3 啟動(dòng)測(cè)試
3.3.1 錯(cuò)誤的路由規(guī)則訪(fǎng)問(wèn)
訪(fǎng)問(wèn)Spring Cloud Gateway對(duì)應(yīng)的server,當(dāng)訪(fǎng)問(wèn)http://localhost:5000/order-service/order/getOrderPort的時(shí)候,會(huì)出現(xiàn)報(bào)錯(cuò)內(nèi)容如下所示:
正確的Spring Cloud Gateway的默認(rèn)路由規(guī)則:http://Gateway_HOST:Gateway_PORT/大寫(xiě)的serviceId/**
3.3.2 Gateway正確的路由規(guī)則測(cè)試
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持創(chuàng)新互聯(lián)。