springboot怎么解决多个deploy执行schedule定时器导致并发问题
发表于:2025-02-04 作者:千家信息网编辑
千家信息网最后更新 2025年02月04日,这篇文章主要讲解了"springboot怎么解决多个deploy执行schedule定时器导致并发问题",文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习"s
千家信息网最后更新 2025年02月04日springboot怎么解决多个deploy执行schedule定时器导致并发问题
这篇文章主要讲解了"springboot怎么解决多个deploy执行schedule定时器导致并发问题",文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习"springboot怎么解决多个deploy执行schedule定时器导致并发问题"吧!
springboot部署多个相同服务deploy,当服务中有定时器时,一旦定时器触发时服务会同时执行,从而产生并发问题。解决方案:
1.在定时器类添加@Profile 注解 指定实例执行定时器。
@Component@Configuration@EnableScheduling // 1.开启定时任务@Profile("deploy01")public class ScheduleTaskService {....}
它操作简单,灵活。只需要添加@Profile注解,但它的局限性也很明显,只有指定服务为deploy01时才会加载定时器处理类,一旦deploy01 挂掉或者未启动就无法执行。所以并不能达到高可用。
2.利用redis 缓存机制
@Scheduled(cron = "0 0 0/1 * * ? ") //每1小时执行一次 public void insertPriRecoverCall() throws InterruptedException { String deployKey="deployName"; redisService.set(deployKey,deployId,1,TimeUnit.HOURS); Object o = redisService.get(deployKey); if (o!=null){ String deployName = o.toString(); if (deployId.equals(deployName)){ logger.info(deployName+" is running ....."); ////业务代码 } } }
先获取服务实例Id,缓存到redis中。redis 是key-value 键值对的缓存机制。在相同key下只会保留一个deployId ,再取出缓存中deployId和服务实例id 比较。相同就继续执行业务代码,不同则直接过滤。这样既可以防止并发问题,又可以实现高可用。
感谢各位的阅读,以上就是"springboot怎么解决多个deploy执行schedule定时器导致并发问题"的内容了,经过本文的学习后,相信大家对springboot怎么解决多个deploy执行schedule定时器导致并发问题这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是,小编将为大家推送更多相关知识点的文章,欢迎关注!
定时器
问题
服务
多个
缓存
相同
实例
学习
业务
代码
内容
机制
注解
不同
明显
任务
只有
同时
小时
就是
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
全球网络安全知名企业
软件开发本科生和研究生
中国邮政网络安全
开展网络安全知识讲座
服务器iom
计算机网络技术与应用专业视频
江苏智能软件开发销售厂家
oncomine数据库怎么了
软件开发包合规报告
国家认可网络安全产业园
http代理服务器设置账号密码
网络安全 课程思政
怎样开展大学生网络安全工作
网络数据库技术发展趋势
挂机宝vps服务器租用
原神服务器登录显示网络错误
计算机三级考试网络技术考啥
如何将图片上传到自己的服务器
杭州fil服务器介绍
苹果手机管理服务器
浙江慧政软件开发
工业软件开发笔记本
办公软件开发公司一般要多少钱
查看服务器激活状态命令
宝山区推广软件开发价钱
正规网络安全运维哪家好
数据库录入功能
ccdc数据库安装
扫描数据库需要什么不同
风雷讯网络技术有限公司招聘