码迷,mamicode.com
首页 > 其他好文 > 详细

centos7 rc.local脚本执行不成功

时间:2017-08-22 20:53:24      阅读:1499      评论:0      收藏:0      [点我收藏+]

标签:date   cloud   read   star   tencent   全局变量   oca   mon   smp   

腾讯云 centos7   配置文件/etc/rc.local的内容如下:

#!/bin/sh
#secu_agent init monitor, install at Thu Aug 3 11:19:41 CST 2017
/usr/local/sa/agent/init_check.sh > /dev/null 2>&1
/usr/sbin/ntpdate ntpupdate.tencentyun.com >/dev/null 2>&1 &
/usr/local/qcloud/rps/set_rps.sh >/tmp/setRps.log 2>&1
/usr/local/qcloud/irq/net_smp_affinity.sh >/tmp/net_affinity.log 2>&1
/mnt/script/push_restart.sh > /dev/null 2>&1

目的是开机启动push_restart.sh,而push_restart.sh的脚本内容如下: 

#!/bin/sh
#/mnt/apache-tomcat-7.0.63/bin/shutdown.sh
#kill -9 `ps -ef | grep tomcat |awk ‘{print $2}‘`
#ps -ef | grep "push-broker-v1.0.jar"
ps -ef | grep "push-broker-v1.0.jar" | awk ‘{print $2,$8}‘| while read action
do
if [[ $action == *grep* ]];then
echo $action
else
echo $action
echo $action | awk ‘{print $1}‘ | while read pid
do
kill -15 $pid
echo $pid
done
fi
done
nohup java -jar /mnt/push/push-broker-v1.0.jar &

现象是:服务器启动后,要执行的脚本/mnt/script/push_restart.sh没有执行,经检查:/etc/rc.local是有执行权限。后面静下来心来检查,发现是因为全局变量的问题。

因为系统在启动过程的时候,当执行/etc/rc.local的时候,服务器还没完全进入系统,因此 java这个全局变量是不存在,所以语句

nohup java -jar /mnt/push/push-broker-v1.0.jar &      执行当中是存在问题的。

解决方法:which java 检查java命令的绝对路径为/usr/java/jdk1.8.0_77/bin/java,把语句改为绝对路径 nohup  /usr/java/jdk1.8.0_77/bin/java -jar /mnt/push/push-broker-v1.0.jar & 就可以解决问题了!

 

centos7 rc.local脚本执行不成功

标签:date   cloud   read   star   tencent   全局变量   oca   mon   smp   

原文地址:http://www.cnblogs.com/to-be-rich/p/7413466.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!