使用Consul或者Eureka作为注册中心时,微服务如何获取自身服务基本信息

本文简要介绍在SpringCloud框架下,使用Eureka或者Consule时,如何获取服务自身基本信息(也可以使用对象类获取其他服务或者所有服务的信息)。

问题来源

我们在开发微服务中有时候需要将微服务自身一下信息记录下来供debug或者功能使用。例如一个user-service服务有多个实例在运行,但个个别实例又问题,我就需要在日志记录user-service的具体实例作为排查依据。或者我们的服务worker-service有多个实例,然后一部分工作会分配到workerA,一部分会分配到workerB,我们需要在数据库或者其他记录当前这些工作在哪个实例?,我们如果重启workerA会影响哪些工作?如果需要取消任务执行,只能调用workerA的ip和端口(如果worker-service没有实现集群模式,只能去对应服务实例上取消任务)。

注意
本文基于consul 1.2.0, SpringCloud Finchley.RELEASE, SpringBoot 2.0.1

如何解决

SpringClould为我们提供了几个主要类
查询自身服务注册信息
Registration类 通用的,无论是使用Eureka还是Consul作为注册中心都能使用。
ConsulRegistration类, 当Consul作为注册中心使用。
EurekaInstanceConfig接口, 当Eureka作为注册中心使用。

查询其他服务的信息
DiscoveryClient类,通用的,无论是使用Eureka还是Consul作为注册中心都能使用。
ConsulDiscoveryClient类,当Consul作为注册中心使用。

查看源代码可以发现ConsulRegistration继承了Registration,新添加getInstanceId方法和getService方法。


ConsulDiscoveryClient继承了DiscoveryClient,新添加getInstances(final String serviceId,
final QueryParams queryParams)方法和getAllInstances方法。


ConsulDiscoveryClient.png

EurekaInstanceConfig接口


EurekaInstanceConfig.png

最终效果

完整代码在这里,欢迎加星,fork。

StartLog.png

你可能感兴趣的:(使用Consul或者Eureka作为注册中心时,微服务如何获取自身服务基本信息)