解决cron不执行的问题

解决cron不执行的问题

在FreeBSD5.4下面做开发,需要定期备份mysql数据,开始在网上找了bash的脚本,但是执行无效,一怒之下,使用php来写,嘿嘿,其实php写脚本也不错滴。备份其实就是把mysql的数据库文件复制出来,当然,也可以使用mysqldump之类的工具把结果生成sql语句,不过我为了方便,就直接复制文件,并且压缩一下。看php代码:

#!/usr/local/php/bin/php
<?
$date = "mysql_". date("Ymd_His");
$cmd = "sudo /usr/bin/tar -cf /home/heiyeluren/db_dump/".$date.".tgz /usr/local/mysql/var/";
system($cmd);
?>

把脚本保存到 /home/heiyeluren/db_dump/mysql_dump.php。
上面的代码很好理解吧,就是生成一个按照时间为名字的.tgz文件,保存在我的个人主目录下面,为了脚本能够执行,还要加上 chmod +x /home/heiyeluren/db_dump/mysql_dump.php ,让脚本能够有执行权限。我们自己先试验一次这个脚本,看有效没有:
/home/heiyeluren/db_dump/mysql_dump.php
在看看有没有生成文件:
ls /home/heiyeluren/db_dump/
嗯,生成了 mysql_20051206_xxxxx.tgz的文件,证明有效果。

好,切换到root用户:su – root,输入密码,添加cron任务:

crontab -e

加入任务:

*/1 * * * * /usr/local/php/bin/php /home/heiyeluren/db_dump/mysql_dump.php > /dev/null

嘿嘿,设定了一分钟执行一次,设这么快,主要是看看有没有效果。

等了两分钟,看了一下,嗯?怎么在 /home/heiyeluren/db_dump/下面还是没有 .tgz 的文件?怎么回事呢?

查看cron的日志:

cat /var/log/cron

刷刷列了好几屏幕,看到类似这样的:
Dec 6 19:32:00 BSD /usr/sbin/cron[12256]: (root) CMD (/usr/local/php/bin/php /home/heiyeluren/db_dump/mysql_dump.php > /dev/null)

证明我的脚本执行了。。。但是为什么没有效果呢?
哦,我想起来了,好像cron能够把脚本中的输出当作邮件发送给创建cron的用户,嗯,好,我们去掉 > /dev/null 这段,就让我们cron直接发送邮件给我们的root:
crontab -e
修改为:
*/1 * * * * /usr/local/php/bin/php /home/heiyeluren/db_dump/mysql_dump.php
等了一会,看一下邮件,可以使用mail命令来看,也可以直接在 /var/spool/clientmqueue/ 下面看,我们选择第二种:
ls /var/spool/clientmqueue/
列出好多文件:
dfjB6BG0SE012107 dfjB6BN0JP012185 
dfjB6BU1mj012248 qfjB6BG0SE012107 
qfjB6BN0JP012185 qfjB6BU1mj012248
dfjB6BH0aP012123 dfjB6BO1ID012192 
dfjB6BV0dL012254 qfjB6BH0aP012123 
qfjB6BO1ID012192 qfjB6BV0dL012254
我们打开一个来看:
cat /var/spool/clientmqueue/dfjB6BG0SE012107
嗯,看到输出:
sudo: not found
???难道是我们的php脚本有问题,不是我测试过没有问题的吗?哦,看提示,原来是sudo命令没有找到,为什么呢?因为所有脚本中引用的程序都必须是绝对路径滴,不然会找不到,唉,犯错了。

嗯,既然我是用root执行的,权限是没有问题滴,何不把sudo给删除呢,说干就干,修改脚本:
vi /home/heiyeluren/db_dump/mysql_dump.php
修改为:

#!/usr/local/php/bin/php
<?
$date = "mysql_". date("Ymd_His");
$cmd = "/usr/bin/tar -cf /home/heiyeluren/db_dump/".$date.".tgz /usr/local/mysql/var/";
system($cmd);
?>

嘿嘿,去掉了sodu,嗯,保存退出,看看我们的crontab效果如何。。。

哈哈,一分钟过后,查看下目录:
ls /home/heiyeluren/db_dump
嘿嘿,有两个 .tgz 的文件了:mysql_20051206_xxxx.tgz,嗯,证明成功了,但是不能总是让cron给root发邮件呀,不然一会功夫服务器空间就没有了,修改cron任务为:
0 6 * * * /usr/local/php/bin/php /home/heiyeluren/db_dump/mysql_dump.php > /dev/null
就是每天早上的六点执行一次,并且把任何输出到输出到 /dev/null 中,不要给root发邮件。

好,终于解决,不容易,涉及很多知识电,不过增长了经验,不是吗?

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/112344.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • pycharm中文安装包

    pycharm中文安装包pycharm中文安装包如果是自定义安装的,那么他的相应地址应该是下面提供中文安装包链接:https://pan.baidu.com/s/1pf3B-kwZVRwzrWBxj-oZ7g提取码:hduy  这也是俺自己正在用的pycharm中文安装包Pycharm中文安装包一般来说都是放在C:\…

  • 使用 Python 程序实现摩斯密码翻译器「建议收藏」

    作者主页:海拥作者简介:CSDN全栈领域优质创作者、HDZ核心组成员、蝉联C站周榜前十粉丝福利:往期获奖记录每周送6~9本书,不定期送各种小礼品(搪瓷杯、抱枕、鼠标垫、马克杯等)摩斯密码是一种将文本信息作为一系列通断的音调、灯光或咔嗒声传输的方法,无需特殊设备,熟记的小伙伴即可直接翻译。它以电报发明者SamuelF.B.Morse的名字命名。算法算法非常简单。英语中的每个字符都被一系列“点”和“破折号”代替,或者有时只是单数的“点”或“

  • vim学习六之搜索命令「建议收藏」

    vim学习六之搜索命令「建议收藏」目录Vim基本搜索命令/或者?搜索n/N正反向下一个特殊搜索Vim高亮搜索搜索大小写敏感搜索进阶Vim正则表达式搜索查找在行首的特定串查找在行尾的特定串匹配特定行Vim基本搜索命令/或者?搜索在Vim普通模式下,输入/或?符号就进入了搜索模式,/用于正向往下搜索,?用于反向往上搜索。n/N正反向下一个在搜索模式下可以对Vim打开的整个文本内容进行搜索,当按下n时可以继续正向查找下一个相匹配的目前单词。N的作用与n相反,是往上反向搜索目标单词。特殊搜索在Vim命

  • linux系统dpkg命令[通俗易懂]

    linux系统dpkg命令[通俗易懂]dpkg是Debianpackage的简写,为”Debian“操作系统专门开发的套件管理系统,用于软件的安装,更新和移除。阅读目录安装软件 列出与该包先关联的文件 显示包的版本 移除软件(保留配置) 移除软件(不保留配置) 查找包的详细信息 列出deb包的内容安装软件命令:dpkg-i<.debfilename>实例:dpkg-i~/Download/mozybackup_i386.debmozybackup_i386.deb是手动下…

  • file_get_contents 返回null,allow_url_fopen = On如何解决

    file_get_contents 返回null,allow_url_fopen = On如何解决绝对有效开启fsockopen函数iis6打开allow_url_fopen设置发表时间:2013-12-0611:48来源:未知分类:其它代码作者:岑溪网站开发点击:75次烦爆了,今天装个自己租了个有了务器,想装discuz两个函数allow_url_fopen和file_get_contents都不能成功开启。为什么不能成功开启,按照网上说的allow_

  • Pytest(11)allure报告「建议收藏」

    Pytest(11)allure报告「建议收藏」前言allure是一个report框架,支持java的Junit/testng等框架,当然也可以支持python的pytest框架,也可以集成到Jenkins上展示高大上的报告界面。mac环境:

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号