我正在尝试从通过cron作业调用的脚本重启NGINX服务(它在root用户在命令行中运行时有效) - 我不确定这是否相关但是有问题的cron作业也是通过脚本创建的。我尝试了多个命令,但我现在使用的是以下命令:
sudo /etc/init.d/nginx restart
对此的任何帮助都会很棒!
更新
下面是cron运行并尝试重新加载nginx服务的脚本
#!/bin/bash
NGINX_CONFIG='/etc/nginx/sites-available'
NGINX_SITES_ENABLED='/etc/nginx/sites-enabled'
WEB_DIR='/var/www/vhosts/demos'
EMAIL=$1
DOMAIN=$2
SITE_DIR=$3
echo $DOMAIN
echo $SITE_DIR
# Remove the nginx configurtations
rm -Rf $NGINX_CONFIG/$DOMAIN.conf
rm -Rf $NGINX_SITES_ENABLED/$DOMAIN.conf
# Remove the access log
rm -Rf /var/log/nginx/$SITE_DIR.access.log
# Remove unicorn socket log
rm -Rf /tmp/unicorn.$SITE_DIR.sock
# Remove the DB
sudo psql -U postgres -c "SELECT pg_terminate_backend(pg_stat_activity.pid) FROM pg_stat_activity WHERE pg_stat_activity.datname = '_$SITE_DIR' AND pid <> pg_backend_pid();"
dropdb -U postgres $SITE_DIR
# Remove the sites application from the server
rm -Rf $WEB_DIR/$SITE_DIR/
if [[ ! "$(/sbin/service nginx status)" =~ "start/running" ]]
then
/etc/init.d/nginx reload
fi
答案 0 :(得分:9)
你需要像root用户一样创建一个cron作业,所以,添加新的cron作业,以root用户身份登录,然后运行crontab -e并添加它,
0 * * * * /etc/init.d/nginx reload
或编辑您的
/etc/crontab
使用root用户并添加cron
0 * * * * root /etc/init.d/nginx reload
(根据需要调整时间表;以上时间每小时运行一次)
你无法运行cron whit sudo(我认为)你需要以root身份登录或以root身份编辑crontab并添加你的命令。
更新************** +++
为什么不运行
/etc/init.d/nginx reload
而不是:
如果[[! “$(/ sbin / service nginx status)”=〜“start / running”]] 然后 /etc/init.d/nginx重新加载 网络
或者最好试试这个:
/etc/init.d/nginx status > /dev/null
status="$?"
if [ $status -eq "0" ]; then
/etc/init.d/nginx reload
fi
在那里你可以添加一个else,如果nginx被停顿以重新启动它或类似的东西... forme working我在我的lite监控脚本上使用它http://kb.skamasle.com/2013/monitorear-servicios-ftp-mysql-apache-etc-y-levantar-si-esta-caido/
我们也可以使用这个:
* * * * * /usr/bin/pgrep nginx > /dev/null || /etc/init.d/nginx restart >> /var/log/messages
如果没有重新启动它,只需检查nginx pid是否存在一个衬里cron