centos7 rc.local脚本执行不成功

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了centos7 rc.local脚本执行不成功相关的知识,希望对你有一定的参考价值。

腾讯云 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脚本执行不成功的主要内容,如果未能解决你的问题,请参考以下文章

centos 开机启动执行某个脚本(rc.local)

centos 7 rc.local 不启动

Centos7系统rc.local不起作用问题

Centos 7关于rc.local脚本命令开机不执行及指定用户启动的解决方法

7.centos7开机启动执行脚本《Mr.Robot》

Linux开机启动文件rc.local无法执行怎么办