SpringBoot2.x填坑(四):生产上SpringBoot2.x Scheduled定时任务重复执行两次解决方案
一、问题描述
在SpringBoot2.x 的项目上写了个定时任务,每天凌晨1点执行,那么令人费解的是:定时任务在服务器上总是执行两次,这个bug就闹大了,但是在本机调试始终只执行一次,查了很多原因都说是实例化bean两次的问题,但是看了很多解决方案都没有解决…
如下面代码块:
@Scheduled(cron = "0 0 1 * * ?") //每天凌晨一点执行public void testTask() {LOGGER.info("进入testTask调度服务,{}", new Date());//执行业务操作......}
输出日志如下:
[2019-02-26 01:00:00.144] [level: INFO] [Thread: pool-16-thread-1] [ Class:com.xxxx.xxxx.task. testTask >> Method: policyWorkNotesYesterdayTask:34 ]
INFO:进入testTask调度服务,Tue Feb 26 01:00:00 UTC 2019[2019-02-26 01:00:00.155] [level: INFO] [Thread: pool-16-thread-1] [ Class:com.xxxx.xxxx.task. testTask >> Method: testTask:83 ]
INFO:进入testTask调度服务,Tue Feb 26 01:00:00 UTC 2019
执行了两次,并且数据库增加了相同的两次业务记录。
二、问题原因调试分析
问题排查:本地开发和测试都没有问题,说明代码是没有问题的,唯一的差别是本地springboot启动用的内置tomcat容器,服务器上是发布到tomcat下 Webapps 目录,那么问题最有可能出现在这里!
三、Tomcat运行原理分析
Tomcat的Webapps目录是Tomcat默认的应用目录,当服务器启动时,会加载所有这个目录下的应用。也可以将JSP程序打包成一个war包放在目录下,服务器会自动解开这个war包,并在这个目录下生成一个同名的文件夹。一个war包就是有特性格式的jar包,它是将一个Web程序的所有内容进行压缩得到。
项目部署在服务器tomcat的webapps目录里,导致项目被tomcat初始化了2次,部署成功了2次,一次访问路径是项目名的,一次访问路径是/。而本地的开发工具项目部署在wptwebapps不在webapps里,webapps为tomcat默认目录,里面的war包会自动被解压,项目会自动被部署。
五、解决方案
在Tomcat/conf/server.xml下面找到Host这行代码:
<Host name="localhost" appBase="webapps" unpackWARs="true" autoDeploy="true"> <Valve className="org.apache.catalina.valves.AccessLogValve" directory="logs" prefix="localhost_access_log" suffix=".txt" pattern="%h %l %u %t "%r" %s %b" />
</Host>
配置Tomcat启动项目路径为外部路径(例如项目名为TaskService,在Tomcat目录下创建Task目录),修改配置如下:
<Host name="localhost" appBase="" unpackWARs="true" autoDeploy="true"> <Valve className="org.apache.catalina.valves.AccessLogValve" directory="logs" prefix="localhost_access_log" suffix=".txt" pattern="%h %l %u %t "%r" %s %b" />
<Context docBase="/usr/local/src/tomcat/Task" path="/" reloadable="true" />
</Host>
好了,赶紧重启Tomcat 试试吧!
贡献者
- IT实战联盟-Line
更多精彩内容可以关注“IT实战联盟”公众号哦~~~
SpringBoot2.x填坑(四):生产上SpringBoot2.x Scheduled定时任务重复执行两次解决方案相关推荐
- 预发环境与生产环境共享数据库时定时任务重复执行问题解决
背景: 为保证预发环境的真实性,预发与生产环境往往共享数据库,在定时任务列表中,预发与生产环境都会从任务列表中获取定时任务,然后执行,这会导致定时任务会执行重复. 解决方法: 在job中增加一个环境变 ...
- Android底部导航栏切换页面填坑
** Android底部导航栏切换页面填坑 ** 这个效果的实现关键点就是给选项赋予两种状态,focused和normal,在主程序中用监听判断是否被选中,就给被选中的选项设focused为true, ...
- Android Studio 插件开发详解四:填坑
转载请标明出处:http://blog.csdn.net/zhaoyanjun6/article/details/78265540 本文出自[赵彦军的博客] 系列目录 Android Gradle使用 ...
- 在ThinkPad X280加装M.2硬盘上安装 Ubuntu 18.04.3 填坑记录
填坑背景 用了一段时间的X280后,突然想在M.2接口上加装一个 NVMe 2242 的SSD,发现 Lenovo 的BIOS设置的非常奇特.能够检测到这个硬盘,但是启动项里就是不能识别!或许是直接就 ...
- 【填坑】ESP32 bootloader初探(上)
前言 大名鼎鼎的乐鑫ESP8266 WIFI模组你应该不陌生,不用我多说了.在这之后乐鑫还更迭了更多高性能的芯片型号,比如这次我要记录的ESP32-C3,搭载近期很火的RISC-V指令集处理器,支持2 ...
- 【填坑之旅】手把手教你如何用AndroidStudio上传自己的library到Jcenter库
[填坑之旅]手把手教你如何用AndroidStudio上传自己的library到Jcenter库 前言:我们在使用AndroidStudio的时候,会经常用到第三方的代码库.引入第三方库的方式无非就是 ...
- 深度学习框架(Pytorch)+ 机器人(ROS):ROS melodic 上安装 Turtlebot2 —> 安装 hokuyo 激光雷达 —> Python 3 的虚拟环境中调用 ROS 填坑记录
复现论文需要ubuntu+ros+turtlebot2+hokuyo的配置,这里有一个关于turtlebot的教程: Learn TurtleBot and ROS 关于 turtlebot 的各种软 ...
- SpringCloud、SpringBoot2.0 整合Oauth2 (四) 配置文件快速配置url过滤
SpringBoot2.0 整合Oauth2 (四) 配置文件快速配置url过滤 文章目录 SpringBoot2.0 整合Oauth2 (四) 配置文件快速配置url过滤 1.添加url过滤配置 2 ...
- 在 Windows 上测试 Redis Cluster的集群填坑笔记
redis 集群实现的原理请参考http://www.tuicool.com/articles/VvIZje 集群环境至少需要3个节点.推荐使用6个节点配置,即3个主节点,3个从节点. 新建6个文件夹 ...
- 传统行业转型微服务的挖坑与填坑
原文:传统行业转型微服务的挖坑与填坑 一.微服务落地是一个复杂问题,牵扯到IT架构,应用架构,组织架构多个方面 在多家传统行业的企业走访和落地了微服务之后,发现落地微服务是一个非常复杂的问题,甚至都不 ...
最新文章
- Android应用程序安全改进:回顾2016年
- H3C S6800交换机基本配置命令
- 【Pandas】apply,applymap和map的区别
- springboot 中根据数据库表生成所有表的model,mapper和xml文件
- bzoj 4515: [Sdoi2016]游戏
- pku 2418 Hardwood Species 字典树
- ffmpeg的新东东:AVFilter
- 非对称加密, 助记词, PIN, WIF
- 【今日CV 视觉论文速览】16 Nov 2018
- 理解_授权数据模型_Spring Security OAuth2.0认证授权---springcloud工作笔记112
- LVM: Logical Volume Manager 逻辑卷管理
- 【热门主题:动漫进击巨人xp主题】
- Java带有效期的Map
- 四级词汇——不择手段记单词new
- MIT 6.824 lab3 KVRaft
- Wireshark 网卡出错 The capture session could not be initiated on interface ‘en0‘
- 阿里云服务搭建微信小程序开发环境
- mysql表文件与结构_MySQL文件结构、逻辑架构及sql执行流程分析
- win11忘记当前密码怎么办
- node.js 从基础到操作数据库
热门文章
- Snmp4j编程简介之一
- 系统分析与设计课程总结
- 局域网打印机怎么连接_怎么连接同事已共享的打印机?
- 面向对象17:抽象类和抽象方法、创建抽象类的匿名子类对象、模板方法设计模式
- 并查集(ACWING三道题)
- 文本分类之一:语言模型
- html如何加入浮动客服,css如何实现客服悬浮效果
- pandas 调用mysql函数_pandas的连接函数concat()函数的具体使用方法
- list是否包含字符串_Python创建list
- php连接mysql配置环境变量_Win7 64位操作系统下配置PHP+MySql+Apache环境(转)