使用Consul或者Eureka作为注册中心时,微服务如何获取自身服务基本信息
本文简要介绍在SpringCloud框架下,使用Eureka或者Consule时,如何获取服务自身基本信息(也可以使用对象类获取其他服务或者所有服务的信息)。问题来源我们在开发微服务中有时候需要将微服务自身一下信息记录下来供debug或者功能使用。例如一个user-service服务有多个实例在运行,但个个别实例又问题,我就需要在日志记录user-service的具体实例作为排查依据。或者我们..
本文简要介绍在SpringCloud框架下,使用Eureka或者Consule时,如何获取服务自身基本信息(也可以使用对应对象类获取其他服务或者所有服务的信息)。
问题来源
使用微服务时,有时候需要将微服务自身一些信息记录下来供debug或者业务功能使用。例如一个user-service服务有多个实例在运行,但个别实例有问题,我们就需要在日志记录user-service的具体实例作为排查依据。或者我们的服务worker-service有多个实例,然后一部分工作会分配到workerA,一部分会分配到workerB,我们需要在数据库或者其他记录当前这些工作在哪个实例上?如果我们重启workerA会影响哪些工作?如果需要取消任务,只能调用workerA的ip和端口(如果worker-service没有实现集群模式,只能去对应服务实例上取消任务)。
注意:
本文基于consul 1.1.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方法。
EurekaInstanceConfig接口
最终效果
完整代码在这里,欢迎加星,fork。
更多推荐
所有评论(0)