传统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();
	}
相关推荐
abigriver6 小时前
打造 Linux 离线大模型级语音输入法:Whisper.cpp + 3090 显卡加速与 Rime 中英混输终极调优指南
linux·运维·whisper
charlie1145141918 小时前
嵌入式Linux驱动开发pinctrl篇(1)——从寄存器到子系统:驱动演进之路
linux·运维·驱动开发
Agent手记8 小时前
异常考勤智能预警与处理与流程优化方案 | 基于企业级Agent的超自动化实战教程
运维·人工智能·ai·自动化
cen__y8 小时前
Linux12(Git01)
linux·运维·服务器·c语言·开发语言·git
dapeng-大鹏10 小时前
KVM+LVM 零停机在线扩容 Ubuntu 根分区:从磁盘添加到逻辑卷扩展完整
linux·运维·ubuntu·磁盘空间扩展
乐维_lwops10 小时前
案例解读|运维监控助力某大型卷烟厂构建高效运维监控体系
运维·运维案例
JiaWen技术圈11 小时前
网站用户注册行为验证码方案
运维·安全
仙柒41511 小时前
Docker存储原理
运维·docker·容器
DolphinDB11 小时前
漫长人工,耗费存储?用 BackupRestore 模块一站式解决跨环境数据同步难题
运维·后端·架构
神奇椰子13 小时前
[特殊字符] 服务器搭建网站完整教程
运维·服务器