Spring Cloud Netflix多語言/非java語言支援之Sidecar
前言
如何將Python語言提供的服務納入到Spring Cloud管理中來,找到了這個Sidecar元件,發現官方提供一篇文件,對其進行相關翻譯。宣告
:如果在閱讀時發現有誤或有更好的翻譯方式,請及時通知給我。
Sidecar簡介
根據我的理解,邊門是作為一個代理的服務來間接性的讓其他語言可以使用尤里卡等相關元件。通過與Zuul的來進行路由的對映,從而可以做到服務的獲取,然後可以使用色帶,佯對服務進行消費,以及對Config Server的間接性呼叫。(此段內容僅個人理解,只作為參考,歡迎討論,同時有誤請及時指正。)
正文翻譯
以下是原文翻譯,原文地址:https://cloud.spring.io/spring-cloud-netflix/multi/multi__polyglot_support_with_sidecar.html
Eureka,Ribbon以及Config Server?Spring Cloud Netflix Sidecar的設計靈感來自Netflix Prana。它包含一個簡單的http api去獲取一個已知服務的所有例項(例如主機和埠)。你也可以通過嵌入的Zuul代理(Zuul中有一個代理功能)對代理的服務進行呼叫,Zuul從Eureka服務註冊中心獲取所有的路由記錄(路由條目)。通過主機發現(主機查詢)或者Zuul代理可以直接訪問Spring Cloud Config。非jvm需要應該實現一個健康檢查,Sidecar能夠以此來報告給Eureka註冊中心該應用是up還是down狀態。
在你的專案中使用Sidecar,需要新增依賴,其組為org.springframework.cloud
spring-cloud-netflix-sidecar
。(這是以maven依賴的方式)
啟用Sidecar,建立一個Spring Boot應用程式,並在在應用主類上加上@EnableSidecar
註解。該註解包含@EnableCircuitBreaker
, @EnableDiscoveryClient
以及。@EnableZuulProxy
將生成的應用程式執行到與非jvm應用程式相同的主機上。(這句不太會翻譯,我的理解為:在與非JVM應用程式相同的主機上執行生成的應用程式)注:這裡的生成應該是通過代理產生的服務。
配置的Sidecar,在application.yml新增中sidecar.port
sidecar.health-uri
。sidecar.port
屬性是非JRE程式監聽的埠號,這就是邊門可以正確註冊應用到尤里卡的原因。sidecar.health-uri
是非JRE應用提供的一個對外暴露的可訪問的URI地址,在該地址對應的介面中需要實現一個模擬Spring Boot健康檢查指示器的功能。它需要返回如下的json文件。(注:通過返回一個json,其用狀態欄位來標識你的應用的服務狀態,是up還是down, sidecar會將該狀態報告給eureka註冊中心從而實現你的服務的狀態可用情況。簡單的說就是用來控制sidecar代理服務的狀態!)health-uri-document。
健康-URI文件。(癒合-URI指向的介面地址需要返回的JSON文件)
{
"status":"UP"
}
這裡是一個邊門應用程式的application.yml配置示例:
application.yml
server:
port: 5678
spring:
application:
name: sidecar
sidecar:
port: 8000
health-uri: http://localhost:8000/health.json
API DiscoveryClient.getInstances()
所對應的訪問方式是/hosts/{serviceId}
,的英文這訪問/hosts/customers
後的響應示例,它返回了兩個不同主機上的例項(可以看到主機地址不一樣)。
非JRE程式可以訪問這個API,如果車斗的埠號為5678,那麼完整url則為:http://localhost:5678/hosts/{serviceId}
。
/主機/客戶。
[
{
"host": "myhost",
"port": 9000,
"uri": "http://myhost:9000",
"serviceId": "CUSTOMERS",
"secure": false
},
{
"host": "myhost2",
"port": 9000,
"uri": "http://myhost2:9000",
"serviceId": "CUSTOMERS",
"secure": false
}
]
Zuul代理會自動為每個在Eureka註冊中心上的服務新增/serviceId
路由到上,所以上面那個客戶的服務可以通過/customers
訪問。非Jre應用可以通過http://localhost:5678/customers
來訪問客戶服務(假設Sidecar的監聽埠為5678)
如果Config Server註冊到了Eureka,非jre應用就可以通過Zuul代理訪問它。如果ConfigServer的serviceId為並並configserver
Sidecar的埠為5678,那麼可以通過http:// localhost:5678 / configserver的方式來訪問Config Server。
非Jvm應用可以利用Config Server的能力來獲取Config Server返回的YAML文件,通過訪問http://sidecar.local.spring.io:5678/configserver/default-master.yml就可以獲取到類似下面的YAML文件結果
eureka:
client:
serviceUrl:
defaultZone: http://localhost:8761/eureka/
password: password
info:
description: Spring Cloud Samples
url: https://github.com/spring-cloud-samples
所以將非JVM應用通過Sidecar接入Spring Cloud微服務叢集的整體架構,大致就如下圖:
本文參照:https://www.cnblogs.com/YrlixJoe/p/7509655.html
更多精彩內容,請關注博主公眾號