.NET Core + Spring Cloud:API 网关
API 網(wǎng)關(guān)是系統(tǒng)的唯一入口,調(diào)用任何服務(wù)的請求都需要經(jīng)過網(wǎng)關(guān)層,最終才可能到達(dá)目標(biāo)服務(wù),既然是必經(jīng)之路,那我們可以在網(wǎng)關(guān)層進(jìn)行一些通用的操作,如:認(rèn)證、鑒權(quán)、限流、智能路由、緩存、日志、監(jiān)控、超時、熔斷、重試等等,這樣既使整個框架條理清晰,也讓開發(fā)者更多注重功能的邏輯實現(xiàn)。
常見的 API 網(wǎng)關(guān)項目有:Kong、Tyk、Netflix zuul、Ocelot 等。在 Spring Cloud 中,Zuul 是其核心組件,下面將介紹 .NET Core 中通過 Zuul 來進(jìn)行統(tǒng)一 API 調(diào)用。
搭建 Zuul Server
Eureka Server 的搭建請參考 .NET Core + Spring Cloud:服務(wù)注冊與發(fā)現(xiàn)
在 IntelliJ IDEA 中新建項目,選 Spring Initializr 完成項目創(chuàng)建
在 pom.xml 添加 zuul 和 eureka-client ?的依賴,我們將會把 Zuul Server 注冊到 Eureka Server
<dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-netflix-zuul</artifactId> </dependency><dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-netflix-eureka-client</artifactId> </dependency>在啟動類上添加 EnableZuulProxy 注解
@EnableZuulProxy @SpringBootApplication public class EurekaServiceApplication {public static void main(String[] args) {SpringApplication.run(EurekaServiceApplication.class, args);} }修改 application.yml 配置文件(集群模式通過一個類似 gateway.xxx.com 的域名指向多個 Zuul ?Server 實例即可)
spring:application:name: zuul-serviceserver:port: 5555eureka:instance:hostname: server1# 超過這個時間沒收到心跳就剔除這個服務(wù),這個配置一般為服務(wù)刷新時間配置的三倍,默認(rèn)90slease-expiration-duration-in-seconds: 15# 服務(wù)刷新時間,默認(rèn)30slease-renewal-interval-in-seconds: 5client:service-url:defaultZone: http://server1:8001/eureka/,http://server2:8002/eureka/,http://server3:8003/eureka/啟動服務(wù),訪問:http://server1:8001/(請確保 Eureka Server 已啟動),可以發(fā)現(xiàn) Zuul Server 已在 5555 端口啟動
創(chuàng)建 .NET Core 服務(wù)
這里直接基于文章 .NET Core + Spring Cloud:服務(wù)注冊與發(fā)現(xiàn) 中的測試項目,修改 .NET Core 客戶端服務(wù)的配置文件 services:base-service:url
"services": {"base-service": {"url": "http://server1:5555/base-service/" // 原來 http://base-service/} }因為我們的 Zuul Server 是啟動在 server1 的 5555 端口,通過 Zuul 網(wǎng)關(guān)調(diào)用服務(wù)的路由規(guī)則是 http://server1:5555/ + {Application 小寫},而基礎(chǔ)服務(wù)的 Application名稱為 BASE-SERVICE,所以 url 設(shè)置為 http://server1:5555/base-service/
測試
訪問 base-service
通過網(wǎng)關(guān)的路由地址 http://server1:5555/base-service/ 訪問 api/values 接口,多次請求可測試負(fù)載均衡效果
訪問 client-service
通過網(wǎng)關(guān)的路由地址 http://server1:5555/client-service/ 訪問 api/values 接口,而配置文件中的 base-service 設(shè)置的也是網(wǎng)關(guān)地址,所以實際在調(diào)用 base-service 也是通過網(wǎng)關(guān)
總結(jié)
以上是生活随笔為你收集整理的.NET Core + Spring Cloud:API 网关的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: .NET Core + Consul 服
- 下一篇: [开源] .Net ORM FreeSq