这里写自定义目录标题
Tomcat自启动脚本配置
通过VIM添加tomcat-monitor.sh脚本
添加下面命令到脚本中
# 获取tomcat进程ID
TomcatID=$(ps -ef |grep tomcat |grep -w 'org.apache.catalina.startup.Bootstrap'|grep -v 'grep'|awk '{print $2}')
# tomcat启动程序(这里注意tomcat实际安装的路径)
StartTomcat=/data/tomcat8/bin/startup.sh
TomcatCache=/data/tomcat8/work
#定义要监控的页面地址
WebUrl=http://192.168.195.10:8080/
#日志输
GetPageInfo=/data/monitor/monitorlogs/TomcatMonitor.Info
TomcatMonitorLog=/data/monitor/monitorlogs/TomcatMonitor.log
Monitor()
{
echo "[info]开始监控tomcat...[$(date +'%F %H:%M:%S')]"
if [ $TomcatID ];then # 这里判断TOMCAT进程是否存在
echo "[info]当前tomcat进程ID为:$TomcatID,继续检测页面..."
# 检测是否启动成功(成功的话页面会返回状态"200")
TomcatServiceCode=$(curl -s -o $GetPageInfo -m 10 --connect-timeout 10 $WebUrl -w %{http_code})
if [ $TomcatServiceCode -eq 200 ];then
echo "[info]页面返回码为$TomcatServiceCode,tomcat运行正常,测试页面正常......"
echo "" > $GetPageInfo # 清空GetPageInfo
else
echo "[error]tomcat页面出错,请注意......状态码为$TomcatServiceCode,错误日志已输出到$GetPageInfo"
echo "[error]页面访问出错,开始重启tomcat"
kill -9 $TomcatID # 杀掉原tomcat进程
sleep 3 #等待3秒
# rm -rf $TomcatCache # 清理tomcat缓存
$StartTomcat
sleep 300 #等待5分钟
fi
else
echo "[error]tomcat进程不存在!tomcat开始自动重启..."
echo "[info]$StartTomcat,请稍候......"
# rm -rf $TomcatCache
$StartTomcat
sleep 300 #等待5分钟
fi
echo "------------------------------"
}
Monitor >>$TomcatMonitorLog
给文件赋可执行权限
chmod +x tomcat-monitor.sh
执行脚本文件
./tomcat-monitor.sh
关闭tomcat,通过运行脚本,tomcat可以启动
添加定时任务
通过命令打开定时任务
crontab -e
添加命令
*/1 * * * * /data/monitor/tomcat-monitor.sh #定义每分钟检查tomcat,如果关闭就重启
运行可能会出现如图异常
解决办法
编辑tomcatsetclasspath.sh文件
vim /data/tomcat8/bin/setclasspath.sh
加入以下命令
export JAVA_HOME=/usr/local/apps/jdk1.8/
export JRE_HOME=/usr/local/apps/jdk1.8/jre
一分钟后查案运行脚本可看到
正常运行情况
Springboot自启动脚本
操作流程和tomcat自启动脚本运行类似。
有两点区别:
Spring boot的执行脚本
```powershell
ProjectName=Security
2 #定义要监控的页面地址
3 WebUrl=http://192.168.195.10/
4 #文件位置
5 File="luban.jar"
6 SecurityID=$(ps -ef | grep luban.jar | grep -v 'grep' | awk '{ print $2 }')
7 # ${ProjectName}启动程序(这里注意项目启动文件实际存放的路径)
8 StartSecurity=/data/ssp/ssp-security/start.sh #日志输出
9 # StartSecurity=nohup java -Xms1024m -Xmx2048m -jar /data/ssp/ssp-security/luban.jar >> /data/monitor/SecurityMonitorlogs/start.out 2>&1 & #日志输出
10 GetPageInfo=/data/monitor/SecurityMonitorlogs/SecurityMonitor.Info
11 SecurityMonitorLog=/data/monitor/SecurityMonitorlogs/SecurityMonitor.log
12 Monitor()
13 {
14 echo "[info]开始监控$ProjectName...[$(date +'%F %H:%M:%S')]"
15 if [ $SecurityID ];then # 这里判断项目进程是否存在
16 echo "[info]当前$ProjectName 进程ID为:$SecurityID,继续检测页面..."
17 # 检测是否启动成功(成功的话页面会返回状态"200")
18 SecurityServiceCode=$(curl -s -o $GetPageInfo -m 10 --connect-timeout 10 $WebUrl -w %{http_code})
19 if [ ${SecurityServiceCode} -eq 200 ];then
20 echo "[info]页面返回码为$SecurityServiceCode,$ProjectName 运行正常,测试页面正常......"
21 echo "" > $GetPageInfo # 清空GetPageInfo
22 else
23 echo "[error]$WebUrl 页面出错,请注意......状态码为$SecurityServiceCode,错误日志已输出到$GetPageInfo"
24 echo "[error]页面访问出错,开始重启$ProjectName"
25 kill -9 ${SecurityID} # 杀掉原${ProjectName}进程
26 sleep 3 #等待3秒
27
28 $StartSecurity
29 sleep 300 #等待5分钟
30 fi
31 else
32 echo "[error]$ProjcetName 进程不存在!开始自动重启..."
33 echo "[info]$StartSecurity,请稍候......"
34 $StartSecurity
35 sleep 300 #等待5分钟
36 fi
37 echo '------------------------------'
38 }
39 Monitor >>$SecurityMonitorLog
上面命令中引用了一个start.sh启动项目的脚本
start.sh脚本
source /etc/profile
nohup java -Xms1024m -Xmx2048m -jar /data/ssp/ssp-security/luban.jar >> /data/monitor/SecurityMonitorlogs/start.out 2>&1 &
注:source/etc/profile命令必须添加,否则可能会报异常
nohup: failed to run command ‘java’: No such file or directory
参考连接https://blog.youkuaiyun.com/lixld/article/details/88054563
问题交流群,不定期分享各种技术文档:
QQ群号:464512055
群二维码:
这是一个神器的二维码,扫描之后你会少掉一块钱。