【linux】【tomcat】linux下定时重启tomcat 【CentOS 6.4】【CentOS 7.6】 =====================CentOS 6.4=================== 一.创建脚本文件,本脚本文件用于停止,重启tomcat运行的java进程,并设置脚本文件权限 二.修改定时任务配置,添加本脚本到定时任务配置中,启动定时任务 CentOS 6 使用cron定时任务,报错:Redirecting to /bin/systemctl restart crond.service ========================CentOS  7.6======================= 一.cron任务的自启动相关命令 二.cron服务是否启动相关命令【区别于自启动】 三.操作定时任务 四.查看定时任务的执行日志 五.最后总结 六.cron任务不执行,问题排查

【linux】【tomcat】linux下定时重启tomcat 【CentOS 6.4】【CentOS 7.6】
=====================CentOS 6.4===================
一.创建脚本文件,本脚本文件用于停止,重启tomcat运行的java进程,并设置脚本文件权限
二.修改定时任务配置,添加本脚本到定时任务配置中,启动定时任务
CentOS 6 使用cron定时任务,报错:Redirecting to /bin/systemctl restart crond.service
========================CentOS  7.6=======================
一.cron任务的自启动相关命令
二.cron服务是否启动相关命令【区别于自启动】
三.操作定时任务
四.查看定时任务的执行日志
五.最后总结
六.cron任务不执行,问题排查

本章内容以CentOS 6.4   和   CentOS  7.6  两个版本为例。[6和7的命令不同]

【linux】【tomcat】linux下定时重启tomcat 【CentOS 6.4】【CentOS 7.6】
=====================CentOS 6.4===================
一.创建脚本文件,本脚本文件用于停止,重启tomcat运行的java进程,并设置脚本文件权限
二.修改定时任务配置,添加本脚本到定时任务配置中,启动定时任务
CentOS 6 使用cron定时任务,报错:Redirecting to /bin/systemctl restart crond.service
========================CentOS  7.6=======================
一.cron任务的自启动相关命令
二.cron服务是否启动相关命令【区别于自启动】
三.操作定时任务
四.查看定时任务的执行日志
五.最后总结
六.cron任务不执行,问题排查

步骤:

一.创建脚本文件,本脚本文件用于停止,重启tomcat运行的java进程,并设置脚本文件权限

1.新建脚本文件tomcat.sh

【注意文件创建的路径】

【查看当前路径的命令:   pwd】

创建文件命令:

vi tomcat.sh

2.粘贴脚本文件文本内容到文件中:

【注意,标红部分需要自己修改为自己服务器上的对应地址】

【查看linux服务器上JAVA_HOME命令:  echo $JAVA_HOME 】

【关键一行:

ps -ef|grep java | grep catalina | awk '{print $2}

可以准确定位到当前正在tomcat下启动运行的java进程,而不是安装的java,参考地址:https://www.cnblogs.com/sxdcgaq8080/p/10734752.html

#!/bin/bash
. /etc/profile

export JAVA_HOME=/usr/local/jdk1.7.0_79
export JRE_HOME=$JAVA_HOME/jre

tomcatPath="/backup/tomcat7"
binPath="$tomcatPath/bin"
echo "[info][$(date +'%F %H:%M:%S')]正在监控tomcat,路径:$tomcatPath"
pid=`ps -ef|grep java | grep catalina | awk '{print $2}'`
if [ -n "$pid" ]; then
echo "[info][$(date +'%F %H:%M:%S')]正在运行的tomcat进程为:$pid"
echo "[info][$(date +'%F %H:%M:%S')]tomcat已经启动,准备使用shutdown命令关闭..."
$binPath"/shutdown.sh"
sleep 2
pid=`ps -ef|grep java | grep catalina | awk '{print $2}'`
if [ -n "$pid" ]; then
echo "[info][$(date +'%F %H:%M:%S')]使用shutdown命令关闭失败,准备kill进程..."
kill -9 $pid
echo "[info][$(date +'%F %H:%M:%S')]kill进程完毕!"
sleep 1
else
echo "[info][$(date +'%F %H:%M:%S')]使用shutdown命令关闭成功!"
fi
else
echo "[info][$(date +'%F %H:%M:%S')]tomcat未启动!"
fi
echo "[info][$(date +'%F %H:%M:%S')]准备启动tomcat..."
$binPath"/startup.sh"

3.修改脚本文件tomcat.sh 可操作权限

命令:

chmod 777 tomcat.sh

二.修改定时任务配置,添加本脚本到定时任务配置中,启动定时任务

1.修改定时任务配置

命令:

crontab -e

将上面的脚本文件路径,以及定时任务配置粘贴到配置文件中:

58 10  * * * /backup/tomcat7/tomcat.sh

【本配置说明:  每天10:58分   执行脚本文件,脚本文件路径在:/backup/tomcat7/tomcat.sh】

【关于定时任务的配置说明,请自行查阅】

【最后要说明的一点:本命令操作与vi操作文本命令一样】

【linux】【tomcat】linux下定时重启tomcat 【CentOS 6.4】【CentOS 7.6】
=====================CentOS 6.4===================
一.创建脚本文件,本脚本文件用于停止,重启tomcat运行的java进程,并设置脚本文件权限
二.修改定时任务配置,添加本脚本到定时任务配置中,启动定时任务
CentOS 6 使用cron定时任务,报错:Redirecting to /bin/systemctl restart crond.service
========================CentOS  7.6=======================
一.cron任务的自启动相关命令
二.cron服务是否启动相关命令【区别于自启动】
三.操作定时任务
四.查看定时任务的执行日志
五.最后总结
六.cron任务不执行,问题排查

2.操作定时任务

关闭定时任务命令:

service crond stop

【linux】【tomcat】linux下定时重启tomcat 【CentOS 6.4】【CentOS 7.6】
=====================CentOS 6.4===================
一.创建脚本文件,本脚本文件用于停止,重启tomcat运行的java进程,并设置脚本文件权限
二.修改定时任务配置,添加本脚本到定时任务配置中,启动定时任务
CentOS 6 使用cron定时任务,报错:Redirecting to /bin/systemctl restart crond.service
========================CentOS  7.6=======================
一.cron任务的自启动相关命令
二.cron服务是否启动相关命令【区别于自启动】
三.操作定时任务
四.查看定时任务的执行日志
五.最后总结
六.cron任务不执行,问题排查

启动定时任务命令:

service crond start

【linux】【tomcat】linux下定时重启tomcat 【CentOS 6.4】【CentOS 7.6】
=====================CentOS 6.4===================
一.创建脚本文件,本脚本文件用于停止,重启tomcat运行的java进程,并设置脚本文件权限
二.修改定时任务配置,添加本脚本到定时任务配置中,启动定时任务
CentOS 6 使用cron定时任务,报错:Redirecting to /bin/systemctl restart crond.service
========================CentOS  7.6=======================
一.cron任务的自启动相关命令
二.cron服务是否启动相关命令【区别于自启动】
三.操作定时任务
四.查看定时任务的执行日志
五.最后总结
六.cron任务不执行,问题排查

重启定时任务命令:

service crond restart

查看定时任务列表:

crontab -l

查看定时任务执行日志:

tail -f -n 200 /var/spool/mail/root

【linux】【tomcat】linux下定时重启tomcat 【CentOS 6.4】【CentOS 7.6】
=====================CentOS 6.4===================
一.创建脚本文件,本脚本文件用于停止,重启tomcat运行的java进程,并设置脚本文件权限
二.修改定时任务配置,添加本脚本到定时任务配置中,启动定时任务
CentOS 6 使用cron定时任务,报错:Redirecting to /bin/systemctl restart crond.service
========================CentOS  7.6=======================
一.cron任务的自启动相关命令
二.cron服务是否启动相关命令【区别于自启动】
三.操作定时任务
四.查看定时任务的执行日志
五.最后总结
六.cron任务不执行,问题排查

3.查看tomcat下运行的java进程是否已经重启

查看命令:

ps -ef|grep java

可以从下图看到,正在运行的新的java进程是在10:58 启动的【说明java进程重启成功】

【linux】【tomcat】linux下定时重启tomcat 【CentOS 6.4】【CentOS 7.6】
=====================CentOS 6.4===================
一.创建脚本文件,本脚本文件用于停止,重启tomcat运行的java进程,并设置脚本文件权限
二.修改定时任务配置,添加本脚本到定时任务配置中,启动定时任务
CentOS 6 使用cron定时任务,报错:Redirecting to /bin/systemctl restart crond.service
========================CentOS  7.6=======================
一.cron任务的自启动相关命令
二.cron服务是否启动相关命令【区别于自启动】
三.操作定时任务
四.查看定时任务的执行日志
五.最后总结
六.cron任务不执行,问题排查

CentOS 6 使用cron定时任务,报错:Redirecting to /bin/systemctl restart crond.service

 可以查询下面的CentOS 7 使用cron定时任务相关操作。

========================CentOS  7.6=======================

 【linux】【tomcat】linux下定时重启tomcat 【CentOS 6.4】【CentOS 7.6】
=====================CentOS 6.4===================
一.创建脚本文件,本脚本文件用于停止,重启tomcat运行的java进程,并设置脚本文件权限
二.修改定时任务配置,添加本脚本到定时任务配置中,启动定时任务
CentOS 6 使用cron定时任务,报错:Redirecting to /bin/systemctl restart crond.service
========================CentOS  7.6=======================
一.cron任务的自启动相关命令
二.cron服务是否启动相关命令【区别于自启动】
三.操作定时任务
四.查看定时任务的执行日志
五.最后总结
六.cron任务不执行,问题排查

一.cron任务的自启动相关命令

1.检测cron定时服务是否自启用

systemctl is-enabled crond.service

结果展示如下:

enable表示已启用自启动
disable标识未启用自启动

2.如果未启用,则开启cron自启用

systemctl enable crond.service

3.如果已经启用,想要cron关闭自启动

systemctl disable crond.service

【linux】【tomcat】linux下定时重启tomcat 【CentOS 6.4】【CentOS 7.6】
=====================CentOS 6.4===================
一.创建脚本文件,本脚本文件用于停止,重启tomcat运行的java进程,并设置脚本文件权限
二.修改定时任务配置,添加本脚本到定时任务配置中,启动定时任务
CentOS 6 使用cron定时任务,报错:Redirecting to /bin/systemctl restart crond.service
========================CentOS  7.6=======================
一.cron任务的自启动相关命令
二.cron服务是否启动相关命令【区别于自启动】
三.操作定时任务
四.查看定时任务的执行日志
五.最后总结
六.cron任务不执行,问题排查

【linux】【tomcat】linux下定时重启tomcat 【CentOS 6.4】【CentOS 7.6】
=====================CentOS 6.4===================
一.创建脚本文件,本脚本文件用于停止,重启tomcat运行的java进程,并设置脚本文件权限
二.修改定时任务配置,添加本脚本到定时任务配置中,启动定时任务
CentOS 6 使用cron定时任务,报错:Redirecting to /bin/systemctl restart crond.service
========================CentOS  7.6=======================
一.cron任务的自启动相关命令
二.cron服务是否启动相关命令【区别于自启动】
三.操作定时任务
四.查看定时任务的执行日志
五.最后总结
六.cron任务不执行,问题排查

附录:

linux系统自带服务的启动文件和状态

二.cron服务是否启动相关命令【区别于自启动】

1.查看cron服务的启动状态

[只有cron的状态是active  running的,才表示cron服务是启动的]

systemctl status crond.service

 【linux】【tomcat】linux下定时重启tomcat 【CentOS 6.4】【CentOS 7.6】
=====================CentOS 6.4===================
一.创建脚本文件,本脚本文件用于停止,重启tomcat运行的java进程,并设置脚本文件权限
二.修改定时任务配置,添加本脚本到定时任务配置中,启动定时任务
CentOS 6 使用cron定时任务,报错:Redirecting to /bin/systemctl restart crond.service
========================CentOS  7.6=======================
一.cron任务的自启动相关命令
二.cron服务是否启动相关命令【区别于自启动】
三.操作定时任务
四.查看定时任务的执行日志
五.最后总结
六.cron任务不执行,问题排查

2.启动cron服务[命令没有提示]

systemctl start crond.service

3.停止cron服务[命令没有提示]

systemctl stop crond.service

4.重启cron服务[命令没有提示]

systemctl restart crond.service

5.重新加载cron服务[命令没有提示]

systemctl reload crond.service

【linux】【tomcat】linux下定时重启tomcat 【CentOS 6.4】【CentOS 7.6】
=====================CentOS 6.4===================
一.创建脚本文件,本脚本文件用于停止,重启tomcat运行的java进程,并设置脚本文件权限
二.修改定时任务配置,添加本脚本到定时任务配置中,启动定时任务
CentOS 6 使用cron定时任务,报错:Redirecting to /bin/systemctl restart crond.service
========================CentOS  7.6=======================
一.cron任务的自启动相关命令
二.cron服务是否启动相关命令【区别于自启动】
三.操作定时任务
四.查看定时任务的执行日志
五.最后总结
六.cron任务不执行,问题排查

三.操作定时任务

1.定时任务的编辑

crontab -e

编辑内容和centos6 一样。表示每天7.30  执行 /mnt/apps/tomcat/tomcat.sh 路径下的脚本

30 07  * * * /mnt/apps/tomcat/tomcat.sh

如果在上面,已经把定时任务cron启动了,编辑定时任务后,会有提示

【linux】【tomcat】linux下定时重启tomcat 【CentOS 6.4】【CentOS 7.6】
=====================CentOS 6.4===================
一.创建脚本文件,本脚本文件用于停止,重启tomcat运行的java进程,并设置脚本文件权限
二.修改定时任务配置,添加本脚本到定时任务配置中,启动定时任务
CentOS 6 使用cron定时任务,报错:Redirecting to /bin/systemctl restart crond.service
========================CentOS  7.6=======================
一.cron任务的自启动相关命令
二.cron服务是否启动相关命令【区别于自启动】
三.操作定时任务
四.查看定时任务的执行日志
五.最后总结
六.cron任务不执行,问题排查

2.查看已编辑的定时任务

crontab -l

【linux】【tomcat】linux下定时重启tomcat 【CentOS 6.4】【CentOS 7.6】
=====================CentOS 6.4===================
一.创建脚本文件,本脚本文件用于停止,重启tomcat运行的java进程,并设置脚本文件权限
二.修改定时任务配置,添加本脚本到定时任务配置中,启动定时任务
CentOS 6 使用cron定时任务,报错:Redirecting to /bin/systemctl restart crond.service
========================CentOS  7.6=======================
一.cron任务的自启动相关命令
二.cron服务是否启动相关命令【区别于自启动】
三.操作定时任务
四.查看定时任务的执行日志
五.最后总结
六.cron任务不执行,问题排查

3.删除已编辑的所有定时任务

crontab -r

【linux】【tomcat】linux下定时重启tomcat 【CentOS 6.4】【CentOS 7.6】
=====================CentOS 6.4===================
一.创建脚本文件,本脚本文件用于停止,重启tomcat运行的java进程,并设置脚本文件权限
二.修改定时任务配置,添加本脚本到定时任务配置中,启动定时任务
CentOS 6 使用cron定时任务,报错:Redirecting to /bin/systemctl restart crond.service
========================CentOS  7.6=======================
一.cron任务的自启动相关命令
二.cron服务是否启动相关命令【区别于自启动】
三.操作定时任务
四.查看定时任务的执行日志
五.最后总结
六.cron任务不执行,问题排查

四.查看定时任务的执行日志

1.查看cron执行日志

tail -f -n 200 /var/log/cron

【linux】【tomcat】linux下定时重启tomcat 【CentOS 6.4】【CentOS 7.6】
=====================CentOS 6.4===================
一.创建脚本文件,本脚本文件用于停止,重启tomcat运行的java进程,并设置脚本文件权限
二.修改定时任务配置,添加本脚本到定时任务配置中,启动定时任务
CentOS 6 使用cron定时任务,报错:Redirecting to /bin/systemctl restart crond.service
========================CentOS  7.6=======================
一.cron任务的自启动相关命令
二.cron服务是否启动相关命令【区别于自启动】
三.操作定时任务
四.查看定时任务的执行日志
五.最后总结
六.cron任务不执行,问题排查

五.最后总结

如上述命令,整个cron操作步骤如下

1>编辑了.sh脚本,并保存,记录.sh文件所在路径【一定确保.sh脚本可用,可以尝试在编辑完成.sh文件后,直接./tomcat.sh  执行脚本文件,查看是否可以正常执行】

2>查看并设置cron为自启动

3>查看并启动cron服务,使状态为running

4>编辑并查看cron服务,注意路径和定时格式,确保cron服务编辑成功

5>最后在编辑完成cron服务后,重新加载或重启cron服务,确保cron服务状态是running的

6>最后可以通过查看cron执行日志,确保cron是否执行

7>如果cron任务不执行,确保linux服务器系统 时间 和时区 是否正常

六.cron任务不执行,问题排查

如上,已经确保  第五点中所有 步骤都正确执行了。但是cron定时任务一直没有执行。

我这里出现的原因,是因为服务器的时区设置不正确。

正确的时区应该是

CST

如果你的时区是

UTC

或者其他,就导致时间和时区不正确。

我设置的定时任务是17.05执行,结果等到了17.05,定时任务不执行,因为此刻的系统时间是05.05

解决方法:

https://www.cnblogs.com/sxdcgaq8080/p/11155232.html

=================================================

参考地址:

https://blog.csdn.net/abcdad/article/details/69239249

定时启动开启后,无效解决方案:

https://blog.csdn.net/zxc_user/article/details/82634370