W3Cschool
恭喜您成為首批注冊用戶
獲得88經(jīng)驗值獎勵
您是否要使用非JVM語言來利用Eureka,Ribbon和Config Server?Spring Cloud Netflix Sidecar的靈感來自Netflix Prana。 它包括一個HTTP API,用于獲取給定服務的所有實例(按主機和端口)。您也可以通過嵌入式Zuul代理來代理服務調(diào)用,該代理從Eureka獲取其路由條目。可以直接通過主機查找或通過Zuul代理訪問Spring Cloud Config服務器。非JVM應用程序應實施運行狀況檢查,以便Sidecar可以向Eureka報告應用程序是啟動還是關閉。
要在項目中包含Sidecar,請使用組ID為org.springframework.cloud
且工件ID為??spring-cloud-netflix-sidecar
的依賴項。
要啟用Sidecar,請使用@EnableSidecar
創(chuàng)建一個Spring Boot應用程序。該注釋包括@EnableCircuitBreaker
,@EnableDiscoveryClient
和@EnableZuulProxy
。
在與非JVM應用程序相同的主機上運行結果應用程序。
要配置側車,請將sidecar.port
和sidecar.health-uri
添加到application.yml
。sidecar.port
屬性是非JVM應用程序偵聽的端口。
這樣Sidecar可以正確地向Eureka注冊應用程序。sidecar.secure-port-enabled
選項提供了一種啟用流量安全端口的方法。sidecar.health-uri
是在非JVM應用程序上可訪問的URI,它模仿Spring Boot運行狀況指示器。
它應該返回類似于以下內(nèi)容的JSON文檔:
health-uri-document。
{ "status":"UP" }
以下application.yml示例顯示了Sidecar應用程序的示例配置:
application.yml。
server: port: 5678 spring: application: name: sidecar sidecar: port: 8000 health-uri: http://localhost:8000/health.json
DiscoveryClient.getInstances()
方法的API為/hosts/{serviceId}
。以下針對/hosts/customers
的示例響應在不同的主機上返回兩個實例:
/ hosts / customers。
[ { "host": "myhost", "port": 9000, "uri": "http://myhost:9000", "serviceId": "CUSTOMERS", "secure": false }, { "host": "myhost2", "port": 9000, "uri": "http://myhost2:9000", "serviceId": "CUSTOMERS", "secure": false } ]
非JVM應用程序(如果Sidecar位于端口5678上)可通過http://localhost:5678/hosts/{serviceId}
訪問此API。
Zuul代理會自動將Eureka中已知的每個服務的路由添加到/<serviceId>
,因此可以在/customers
中使用客戶服務。非JVM應用程序可以在http://localhost:5678/customers
上訪問客戶服務(假設Sidecar正在偵聽5678端口)。
如果Config Server已向Eureka注冊,則非JVM應用程序可以通過Zuul代理對其進行訪問。如果ConfigServer的serviceId
為configserver
并且Sidecar在端口5678上,則可以在http:// localhost:5678 / configserver上對其進行訪問。
非JVM應用程序可以利用Config Server返回YAML文檔的功能。例如,調(diào)用https://sidecar.local.spring.io:5678/configserver/default-master.yml 可能會導致YAML文檔類似于以下內(nèi)容:
eureka: client: serviceUrl: defaultZone: http://localhost:8761/eureka/ password: password info: description: Spring Cloud Samples url: https://github.com/spring-cloud-samples
要在使用HTTP時使運行狀況檢查請求接受所有證書,請將sidecar.accept-all-ssl-certificates
設置為`true。
Copyright©2021 w3cschool編程獅|閩ICP備15016281號-3|閩公網(wǎng)安備35020302033924號
違法和不良信息舉報電話:173-0602-2364|舉報郵箱:jubao@eeedong.com
掃描二維碼
下載編程獅App
編程獅公眾號
聯(lián)系方式:
更多建議: