SpringCloud Polyglot支持Sidecar
您是否要使用非JVM语言来利用Eureka,Ribbon和Config Server?Spring Cloud Netflix Sidecar的灵感来自Netflix Prana。 它包括一个HTTP API,用于获取给定服务的所有实例(按主机和端口)。您也可以通过嵌入式Zuul代理来代理服务调用,该代理从Eureka获取其路由条目。可以直接通过主机查找或通过Zuul代理访问Spring Cloud Config服务器。非JVM应用程序应实施运行状况检查,以便Sidecar可以向Eureka报告应用程序是启动还是关闭。
要在项目中包含Sidecar,请使用组ID为org.springframework.cloud
且工件ID为spring-cloud-netflix-sidecar
的依赖项。
要启用Sidecar,请使用@EnableSidecar
创建一个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运行状况指示器。
它应该返回类似于以下内容的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文档的功能。例如,调用https://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
要在使用HTTP时使运行状况检查请求接受所有证书,请将sidecar.accept-all-ssl-certificates
设置为`true。
更多建议: