传统JavaWeb项目集成consul注册中心

​Consul‌是由‌HashiCorp‌开发的一款开源工具,专注于分布式系统的服务发现和配置管理。Consul提供了多种关键功能,包括服务注册与发现、健康检查、键值存储、多数据中心支持等,特别适用于微服务架构中的服务治理‌。本文演示老项目如ssh,ssm等项目需要通过java api的方式来集成consul注册中心,先引入依赖

java 复制代码
<dependency>
 <groupId>com.ecwid.consul</groupId>
 <artifactId>consul-api</artifactId>
 <version>1.4.5</version>
</dependency>

编写一个监听器,在监听其中将服务注册到consul里面

java 复制代码
import javax.servlet.ServletContextEvent;
import javax.servlet.ServletContextListener;
import com.ecwid.consul.v1.ConsulClient;
import com.ecwid.consul.v1.agent.model.NewService;

public class ConsulRegistrationListener implements ServletContextListener {
	private static ConsulClient consulClient = null;
	private static String consulServiceId = null;

	@Override
	public void contextInitialized(ServletContextEvent context) {
		logger.debug("starting service register...");
		Thread thread = new Thread(()->{
			try {
				initConsulClient();
			} catch (Exception e) {
				e.printStackTrace();
			}
		},"Registry-Thread");
		thread.start();
	}

	@Override
	public void contextDestroyed(ServletContextEvent context) {
		consulClient.agentServiceDeregister(consulServiceId);
	}

	private void initConsulClient() {
        consulServiceId = "xxx-service:8083";
        consulClient = new ConsulClient("127.0.0.1", "8500");
        NewService newService = new NewService();
        newService.setId(consulServiceId);
        newService.setName("xxx-service");
        newService.setPort("8083");
        newService.setAddress("127.0.0.1");
        NewService.Check check = new NewService.Check();
        check.setTtl("10s");
        check.setDeregisterCriticalServiceAfter("15s");
        newService.setCheck(check);
        consulClient.agentServiceRegister(newService);
        Thread thread = new Thread(() -> {
            while (true) {
                try {
                    consulClient.agentCheckPass("service:" + consulServiceId);
                    Thread.sleep(5000);
                } catch (Exception e) {
                    e.printStackTrace();
                }
            }
        }, "Consul-Health-Check");
        thread.start();
	}
}

在常用工具类中可添加通过服务名获取服务url相关的方法

java 复制代码
	/**
	 * 获取Consul中的服务的url
	 *
	 * @param serviceName
	 * @return
	 */
	private static String getServiceUrlFromConsul(String serviceName) {
		List<HealthService> serviceList = getServiceFromConsul(serviceName);
		int size = serviceList.size();
		HealthService healthService = serviceList.get(random.nextInt(100) % size);
		String address = healthService.getNode().getAddress();
		Integer port = healthService.getService().getPort();
		return "http://" + address + ":" + port;
	}

	/**
	 * 获取Consul中的服务
	 *
	 * @param serviceName
	 * @return
	 */
	private static List<HealthService> getServiceFromConsul(String serviceName) {
		HealthServicesRequest request = HealthServicesRequest.newBuilder().setPassing(true).setQueryParams(QueryParams.DEFAULT).build();
		Response<List<HealthService>> healthServices = consulClient.getHealthServices(serviceName, request);
		return healthServices.getValue();
	}
相关推荐
sxgzzn几秒前
如何有效提升开关柜与电缆的故障监测能力?
运维·电缆绝缘监测·电缆在线监测·局部放电在线监测·局放在线监测
WinyQ02 分钟前
【DeepStream】整合出现的问题
linux·运维·网络
坐怀不乱杯魂6 分钟前
Linux 基础IO
linux·运维·服务器
小魏每天都学习7 分钟前
【网络拓扑部署-网络设备-网络安全】
运维·网络
南棱笑笑生9 分钟前
20260123让天启AIO-3576Q38开发板在天启Buildroot下读写TF卡
linux·运维·服务器·rockchip
噎住佩奇17 分钟前
PVC和PV等概念解释
linux·运维·服务器
lvbinemail18 分钟前
配置jenkins.service
java·运维·jenkins·systemctl
無限神樂31 分钟前
docker compose简介
运维·docker·容器
ELI_He99932 分钟前
gpg使用记录
linux·运维·服务器
zzh_my35 分钟前
centos yum 安装软件报错
linux·运维·centos