一、问题描述

在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定时任务重复执行两次解决方案相关推荐

  1. 预发环境与生产环境共享数据库时定时任务重复执行问题解决

    背景: 为保证预发环境的真实性,预发与生产环境往往共享数据库,在定时任务列表中,预发与生产环境都会从任务列表中获取定时任务,然后执行,这会导致定时任务会执行重复. 解决方法: 在job中增加一个环境变 ...

  2. Android底部导航栏切换页面填坑

    ** Android底部导航栏切换页面填坑 ** 这个效果的实现关键点就是给选项赋予两种状态,focused和normal,在主程序中用监听判断是否被选中,就给被选中的选项设focused为true, ...

  3. Android Studio 插件开发详解四:填坑

    转载请标明出处:http://blog.csdn.net/zhaoyanjun6/article/details/78265540 本文出自[赵彦军的博客] 系列目录 Android Gradle使用 ...

  4. 在ThinkPad X280加装M.2硬盘上安装 Ubuntu 18.04.3 填坑记录

    填坑背景 用了一段时间的X280后,突然想在M.2接口上加装一个 NVMe 2242 的SSD,发现 Lenovo 的BIOS设置的非常奇特.能够检测到这个硬盘,但是启动项里就是不能识别!或许是直接就 ...

  5. 【填坑】ESP32 bootloader初探(上)

    前言 大名鼎鼎的乐鑫ESP8266 WIFI模组你应该不陌生,不用我多说了.在这之后乐鑫还更迭了更多高性能的芯片型号,比如这次我要记录的ESP32-C3,搭载近期很火的RISC-V指令集处理器,支持2 ...

  6. 【填坑之旅】手把手教你如何用AndroidStudio上传自己的library到Jcenter库

    [填坑之旅]手把手教你如何用AndroidStudio上传自己的library到Jcenter库 前言:我们在使用AndroidStudio的时候,会经常用到第三方的代码库.引入第三方库的方式无非就是 ...

  7. 深度学习框架(Pytorch)+ 机器人(ROS):ROS melodic 上安装 Turtlebot2 —> 安装 hokuyo 激光雷达 —> Python 3 的虚拟环境中调用 ROS 填坑记录

    复现论文需要ubuntu+ros+turtlebot2+hokuyo的配置,这里有一个关于turtlebot的教程: Learn TurtleBot and ROS 关于 turtlebot 的各种软 ...

  8. SpringCloud、SpringBoot2.0 整合Oauth2 (四) 配置文件快速配置url过滤

    SpringBoot2.0 整合Oauth2 (四) 配置文件快速配置url过滤 文章目录 SpringBoot2.0 整合Oauth2 (四) 配置文件快速配置url过滤 1.添加url过滤配置 2 ...

  9. 在 Windows 上测试 Redis Cluster的集群填坑笔记

    redis 集群实现的原理请参考http://www.tuicool.com/articles/VvIZje 集群环境至少需要3个节点.推荐使用6个节点配置,即3个主节点,3个从节点. 新建6个文件夹 ...

  10. 传统行业转型微服务的挖坑与填坑

    原文:传统行业转型微服务的挖坑与填坑 一.微服务落地是一个复杂问题,牵扯到IT架构,应用架构,组织架构多个方面 在多家传统行业的企业走访和落地了微服务之后,发现落地微服务是一个非常复杂的问题,甚至都不 ...

最新文章

  1. Android应用程序安全改进:回顾2016年
  2. H3C S6800交换机基本配置命令
  3. 【Pandas】apply,applymap和map的区别
  4. springboot 中根据数据库表生成所有表的model,mapper和xml文件
  5. bzoj 4515: [Sdoi2016]游戏
  6. pku 2418 Hardwood Species 字典树
  7. ffmpeg的新东东:AVFilter
  8. 非对称加密, 助记词, PIN, WIF
  9. 【今日CV 视觉论文速览】16 Nov 2018
  10. 理解_授权数据模型_Spring Security OAuth2.0认证授权---springcloud工作笔记112
  11. LVM: Logical Volume Manager 逻辑卷管理
  12. 【热门主题:动漫进击巨人xp主题】
  13. Java带有效期的Map
  14. 四级词汇——不择手段记单词new
  15. MIT 6.824 lab3 KVRaft
  16. Wireshark 网卡出错 The capture session could not be initiated on interface ‘en0‘
  17. 阿里云服务搭建微信小程序开发环境
  18. mysql表文件与结构_MySQL文件结构、逻辑架构及sql执行流程分析
  19. win11忘记当前密码怎么办
  20. node.js 从基础到操作数据库

热门文章

  1. Snmp4j编程简介之一
  2. 系统分析与设计课程总结
  3. 局域网打印机怎么连接_怎么连接同事已共享的打印机?
  4. 面向对象17:抽象类和抽象方法、创建抽象类的匿名子类对象、模板方法设计模式
  5. 并查集(ACWING三道题)
  6. 文本分类之一:语言模型
  7. html如何加入浮动客服,css如何实现客服悬浮效果
  8. pandas 调用mysql函数_pandas的连接函数concat()函数的具体使用方法
  9. list是否包含字符串_Python创建list
  10. php连接mysql配置环境变量_Win7 64位操作系统下配置PHP+MySql+Apache环境(转)