spring cloud中 单节点定时任务

在微服务环境中,确保单节点执行定时任务是必要的,例如用于缓存预热和清理。本文介绍了三种策略:使用分布式锁(如Redis的setNx)、通过MySQL的X锁更新状态字段以及依赖Spring Cloud注册中心来控制只有一个节点执行任务。
摘要由CSDN通过智能技术生成

在微服务多节点部署中,定时任务的执行比单节点部署稍复杂些,有时需保证有且仅有一个节点执行,如缓存数据预热,清理缓存等。

可有如下实现方式:

1、分布式锁:

执行的节点在定时任务调起时加分布式锁,如redis的setNx;

2、mysql 的X锁

可在表中加个状态的枚举字段state。

执行update tb set state = t2 where state = t1; update 的结果为1时表示获得执行,为0则不需执行。

3、spring cloud 中,可根据注册中心中的节点,仅有一个节点执行。

//
 public static String getHostIpv4(){
        try{
            Enumeration<NetworkInterface> allNetInterfaces = NetworkInterface.getNetworkInterfaces();
            while (allNetInterfaces.hasMoreElements()){
                NetworkInterface netInterface = (NetworkInterface) allNetInterfaces.nextElement();
                Enumeration<InetAddress> addresses = netInterface.getInetAddresses();
                while (addresses.hasMoreElements()){
                    InetAddress ip = (InetAddress) addresses.nextElement();
                    if (ip != null
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值