本文简要介绍在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。

在这里插入图片描述

Logo

权威|前沿|技术|干货|国内首个API全生命周期开发者社区

更多推荐