bash在SSH部分运行良好时重启mysql,但不在cronjob中运行
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了bash在SSH部分运行良好时重启mysql,但不在cronjob中运行,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含2793字,纯文字阅读大概需要4分钟。
内容图文
我的系统是centos 6.5,
我写了一个简单的bash shell来检查mysql是否崩溃,再次重启服务.我把它放在/home/myspace/mysql.sh chown root:root /home/myspace/mysql.sh然后每分钟由crontab运行.
#!/bin/bash
mysql --host="localhost" --user="root" --password="password" --database="test" --execute="select id from test limit 1"
if [ $? -eq 0 ]; then echo "";
else
/usr/bin/sudo service mysql stop
pkill mysql
/usr/bin/sudo service mysql start
echo "error $(date)" >> /home/myspace/restart_log.txt
fi
现在我有2个问题.
>为什么在我的代码中,如果……其他……不工作?我的意思是mysql服务器没有问题,它可以执行“从测试限制1中选择id”并获得结果,但脚本仍在其他情况下运行代码.
>在/ var / log / sucure中,它显示root:抱歉,你必须有一个tty来运行sudo; TTY =未知; PWD = / root; USER = root; COMMAND = / sbin / service mysql stop. root:抱歉,你必须有一个tty来运行sudo; TTY =未知; PWD = / root; USER = root; COMMAND = / sbin / service mysql start.并且mysql服务器已关闭.
更新:
现在我尝试了代码@Anthon:
#!/bin/bash
RESULT=`mysql --host="localhost" --user="root" --password="password" --database="test" --execute="select browser from test limit 1"`
if [ $? -eq 0 ]; then
echo "mysql select ok"
else
/usr/bin/echo "mysql select failed"
sudo service mysql stop
pkill mysql
/usr/bin/sudo service mysql start
echo "error $(date)" >> /home/myspace/restart_log.txt
fi
它在SSH部分运行良好(返回mysql选择确定)
但不能在cronjob中工作(/home/myspace/restart_log.txt和mysql服务器中的每分钟写入错误永远不会启动)
这个问题是由PATH引起的吗?或特权?怎么解决?谢谢.
解决
谢谢大家,最后我解决了. @ Sigi的方法可能不错,但不适用于我的情况. @Anthon的回答写得比我好,但还是不行. @Emmanuel,因为答案比其他人更接近.经过长时间的测试,我向所有人分享了最终的工作代码.
#!/bin/bash
PATH=/bin:/usr/bin:/sbin:/usr/local/bin
# cronjob need clear where is the path
# mysql under path /usr/local/bin
mysql --host="localhost" --user="root" --password="password" --database="test" --execute="select id from test limit 1"
if [ $? -eq 0 ]; then echo "";
# mysql run well nothing to do, make a
else
sudo /etc/init.d/mysql stop
pkill /usr/local/bin/mysql
# It should be pkill /usr/local/bin/mysql, not pkill mysql, wrong write will cause below code not working
sudo /etc/init.d/mysql start
sudo /etc/init.d/httpd restart
# Some strange behave, after mysql restart, apache will die, so should add httpd restart
echo "error $(date)" >> /home/myspace/restart_log.txt
fi
解决方法:
在脚本中强制使用PATH,cron可能不会提供与终端会话中的路径相同的路径.
编辑:
在终端获取你的路径:
env | grep "^PATH="
PATH=/sbin:/usr/sbin:/usr/local/sbin:... (you will have different value
在脚本中剪切并粘贴该行只是#!/ bin / bash
#!/bin/bash
PATH=/sbin:/usr/sbin:/usr/local/sbin: (put your path
export PATH
(仅举例)
您的脚本中可能还有其他要添加的变量;查找名称包含带有env |的’MYSQL’字符串的变量grep MYSQL和set | grep MYSQL
内容总结
以上是互联网集市为您收集整理的bash在SSH部分运行良好时重启mysql,但不在cronjob中运行全部内容,希望文章能够帮你解决bash在SSH部分运行良好时重启mysql,但不在cronjob中运行所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。