传统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();
	}
相关推荐
阿里云大数据AI技术7 小时前
阿里云 EMR AI 助手正式发布:从问答工具到全栈智能运维助手
运维·人工智能
SkyWalking中文站1 天前
认识 Horizon UI · 6/17:Trace 探索器
运维·监控·自动化运维
火车叼位1 天前
写给初级开发者:SSL、SSH、HTTPS 与证书体系全解析
运维
小猿姐2 天前
唯品会大规模数据库云原生实践:基于 KubeBlocks 管理数千实例的统一运维之路
运维·elasticsearch·云原生
SkyWalking中文站2 天前
认识 Horizon UI · 5/17:3D 基础设施地图
运维·监控·自动化运维
SkyWalking中文站3 天前
认识 Horizon UI · 1/17:SkyWalking 新一代可观测性控制台
运维·前端·监控
雪梨酱QAQ3 天前
Kubeneters HA Cluster部署
运维
江华森4 天前
Spring Cloud 微服务全栈实战:从 Eureka 到 Docker Compose 一文贯通
运维
江华森4 天前
Matplotlib 数据绘图基础入门
运维
江华森4 天前
NumPy 数值计算基础入门
运维