运行 一个 cron 作业。我所有的测试和尝试都失败了
Running a cron job. All my tests and tries were in vane
这是我第一次 运行 cron 作业。我正在使用 Amazon Ubuntu 14.04.2 LTS.
在虚拟机中执行此操作
这是我的文件 crontab -e
:
# Edit this file to introduce tasks to be run by cron.
#
# Each task to run has to be defined through a single line
# indicating with different fields when the task will be run
# and what command to run for the task
#
# To define the time you can provide concrete values for
# minute (m), hour (h), day of month (dom), month (mon),
# and day of week (dow) or use '*' in these fields (for 'any').#
# Notice that tasks will be started based on the cron's system
# daemon's notion of time and timezones.
#
# Output of the crontab jobs (including errors) is sent through
# email to the user the crontab file belongs to (unless redirected).
#
# For example, you can run a backup of all your user accounts
# at 5 a.m every week with:
# 0 5 * * 1 tar -zcf /var/backups/home.tgz /home/
#
# For more information see the manual pages of crontab(5) and cron(8)
#
# m h dom mon dow command
*/1 * * * * root /usr/bin/php /var/www/html/testimages/script.php
好吧,这就是我到目前为止尝试过的方法,我正在列一个清单,以便任何可能遇到 cron 作业问题的人都可以检查之前该做什么:
- 修改
ubuntu
用户的 crontab 和 root
用户的 crontab。
- 最后空一行
* * * * * root /usr/bin/php /var/www/html/testimages/script.php
* * * * * ubuntu /usr/bin/php /var/www/html/testimages/script.php
* * * * * /usr/bin/php /var/www/html/testimages/script.php
* * * * * php /var/www/html/testimages/script.php
* * * * * "php /var/www/html/testimages/script.php"
- 所有这些,但将第一个
*
替换为 */1
- 将
755
的权限设置为 script.php
- 正在重新启动 cron
- 在
script.php
上添加 header 行:#!/usr/local/bin/php -q
当我输入 grep CRON /var/log/syslog
时,我可以看到:
Oct 27 15:32:01 ip-172-31-1-104 CRON[1184]: (root) CMD (root /usr/bin/php /var/www/html/testimages/script.php)
Oct 27 15:33:01 ip-172-31-1-104 CRON[1520]: (root) CMD (root /usr/bin/php /var/www/html/testimages/script.php)
Oct 27 15:34:01 ip-172-31-1-104 CRON[1849]: (root) CMD (root /usr/bin/php /var/www/html/testimages/script.php)
Oct 27 15:35:01 ip-172-31-1-104 CRON[2188]: (root) CMD (root /usr/bin/php /var/www/html/testimages/script.php)
Oct 27 15:36:01 ip-172-31-1-104 CRON[2513]: (root) CMD (root /usr/bin/php /var/www/html/testimages/script.php)
Oct 27 15:37:01 ip-172-31-1-104 CRON[2840]: (root) CMD (root /usr/bin/php /var/www/html/testimages/script.php)
Oct 27 15:38:01 ip-172-31-1-104 CRON[3165]: (root) CMD (root /usr/bin/php /var/www/html/testimages/script.php)
Oct 27 15:39:01 ip-172-31-1-104 CRON[3494]: (root) CMD (root /usr/bin/php /var/www/html/testimages/script.php)
该脚本基本上执行代码并发送一封电子邮件,当我在命令行中键入 php /var/www/html/testimages/script.php
时效果很好,但在 cron 中设置时我没有收到该邮件。
我做错了什么?
非常感谢。
此致。
拉斐尔.
编辑:
这是我正在尝试 php 的文件 运行
#!/usr/local/bin/php -q
<?php
echo '<script>!function(e){function t(e,t){var n=new Image,r=e.getAttribute("data-src");n.onload=function(){e.parent?e.parent.replaceChild(n,e):e.src=r,t?t():null},n.src=r}function n(t){var n=t.getBoundingClientRect();return n.top>=0&&n.left>=0&&n.top<=(e.innerHeight||document.documentElement.clientHeight)}for(var r=function(e,t){if(document.querySelectorAll)t=document.querySelectorAll(e);else{var n=document,r=n.styleSheets[0]||n.createStyleSheet();r.addRule(e,"f:b");for(var l=n.all,c=0,o=[],i=l.length;i>c;c++)l[c].currentStyle.f&&o.push(l[c]);r.removeRule(0),t=o}return t},l=function(t,n){e.addEventListener?this.addEventListener(t,n,!1):e.attachEvent?this.attachEvent("on"+t,n):this["on"+t]=n},c=new Array,o=r("img.lazy"),i=function(){for(var e=0;e<c.length;e++)n(c[e])&&t(c[e],function(){c.splice(e,e)})},u=0;u<o.length;u++)c.push(o[u]);i(),l("scroll",i)}(this);</script>'
echo '<style>table, th, td {border: 1px solid black; border-collapse: collapse;}th, td {padding: 15px;}th { text-align: left; background-color: #666666;}</style>';
require '/var/www/html/libraries/mail/PHPMailerAutoload.php';
require '/var/www/html/libraries/myLibrary/core.php';
$mail = new PHPMailer;
$to = "example@gmail.com";
ob_start();
function echoText($text) {
echo $text;
}
$show_json = $_GET['show_json'];
echoContent(); // belongs to the core
// send email
$mail->isSMTP(); // Set mailer to use SMTP
$mail->Host = 'smtp.gmail.com'; // Specify main and backup SMTP servers
$mail->SMTPAuth = true; // Enable SMTP authentication
$mail->Username = 'example@gmail.com'; // SMTP username
$mail->Password = 'secret'; // SMTP password
$mail->SMTPSecure = 'tls'; // Enable TLS encryption, `ssl` also accepted
$mail->Port = 587; // TCP port to connect to
$mail->setFrom('example@gmail.com', 'Watchdog - Rafael');
// $mail->addAddress('joe@example.net', 'Joe User'); // Add a recipient
$mail->addAddress($to);
// $mail->addReplyTo('info@example.com', 'Information');
// $mail->addBCC('bcc@example.com');
// $mail->addAttachment('/var/tmp/file.tar.gz'); // Add attachments
// $mail->addAttachment('/tmp/image.jpg', 'new.jpg'); // Optional name
$mail->isHTML(true); // Set email format to HTML
$mail->Subject = 'Test on database';
$contents = ob_get_contents();
$mail->Body = $contents;
// $mail->AltBody = 'This is the body in plain text for non-HTML mail clients';
if(!$mail->send()) {
echo 'Message could not be sent.';
echo 'Mailer Error: ' . $mail->ErrorInfo;
} else {
echo 'Message has been sent';
}
print_r(error_get_last());
}
?>
编辑:
我正在尝试将 bash 脚本设置为 运行 它,甚至将结果导出到 log.txt... log.txt
是空的。
我发现系统正在向我发送如下邮件:
You've got a new mail on /var/mail/ubuntu
我忽略了它们,因为我能够在命令行上执行脚本,所以我认为没有任何错误。但它们是 (a ;
)... 所以如果出现最小错误,命令行会执行脚本而不是 cron。原来如此。
您的问题在 php 脚本的第 1 行 - 缺少终止符;
您发布的 CRON 系统日志显示 cron 运行ning 脚本。
您收到的电子邮件很可能来自 CRON 而不是您的脚本。
不幸的是,您的脚本的工作是发送电子邮件,但是,您的脚本不会发送给本地用户 "ubuntu".
如果您阅读这些邮件(您应该阅读!),您可能会发现问题所在。
该脚本要么有错误,要么没有,要么是 运行,要么不是。
根据您对 php(-cli).ini 的配置,您很可能没有收到任何错误报告,因此您认为脚本是正确的。
语法就是语法。
没有 "minimal error" 这样的东西。如果你侥幸逃脱,我们称之为 "feature" ;)
这是我第一次 运行 cron 作业。我正在使用 Amazon Ubuntu 14.04.2 LTS.
在虚拟机中执行此操作这是我的文件 crontab -e
:
# Edit this file to introduce tasks to be run by cron.
#
# Each task to run has to be defined through a single line
# indicating with different fields when the task will be run
# and what command to run for the task
#
# To define the time you can provide concrete values for
# minute (m), hour (h), day of month (dom), month (mon),
# and day of week (dow) or use '*' in these fields (for 'any').#
# Notice that tasks will be started based on the cron's system
# daemon's notion of time and timezones.
#
# Output of the crontab jobs (including errors) is sent through
# email to the user the crontab file belongs to (unless redirected).
#
# For example, you can run a backup of all your user accounts
# at 5 a.m every week with:
# 0 5 * * 1 tar -zcf /var/backups/home.tgz /home/
#
# For more information see the manual pages of crontab(5) and cron(8)
#
# m h dom mon dow command
*/1 * * * * root /usr/bin/php /var/www/html/testimages/script.php
好吧,这就是我到目前为止尝试过的方法,我正在列一个清单,以便任何可能遇到 cron 作业问题的人都可以检查之前该做什么:
- 修改
ubuntu
用户的 crontab 和root
用户的 crontab。 - 最后空一行
* * * * * root /usr/bin/php /var/www/html/testimages/script.php
* * * * * ubuntu /usr/bin/php /var/www/html/testimages/script.php
* * * * * /usr/bin/php /var/www/html/testimages/script.php
* * * * * php /var/www/html/testimages/script.php
* * * * * "php /var/www/html/testimages/script.php"
- 所有这些,但将第一个
*
替换为*/1
- 将
755
的权限设置为script.php
- 正在重新启动 cron
- 在
script.php
上添加 header 行:#!/usr/local/bin/php -q
当我输入 grep CRON /var/log/syslog
时,我可以看到:
Oct 27 15:32:01 ip-172-31-1-104 CRON[1184]: (root) CMD (root /usr/bin/php /var/www/html/testimages/script.php)
Oct 27 15:33:01 ip-172-31-1-104 CRON[1520]: (root) CMD (root /usr/bin/php /var/www/html/testimages/script.php)
Oct 27 15:34:01 ip-172-31-1-104 CRON[1849]: (root) CMD (root /usr/bin/php /var/www/html/testimages/script.php)
Oct 27 15:35:01 ip-172-31-1-104 CRON[2188]: (root) CMD (root /usr/bin/php /var/www/html/testimages/script.php)
Oct 27 15:36:01 ip-172-31-1-104 CRON[2513]: (root) CMD (root /usr/bin/php /var/www/html/testimages/script.php)
Oct 27 15:37:01 ip-172-31-1-104 CRON[2840]: (root) CMD (root /usr/bin/php /var/www/html/testimages/script.php)
Oct 27 15:38:01 ip-172-31-1-104 CRON[3165]: (root) CMD (root /usr/bin/php /var/www/html/testimages/script.php)
Oct 27 15:39:01 ip-172-31-1-104 CRON[3494]: (root) CMD (root /usr/bin/php /var/www/html/testimages/script.php)
该脚本基本上执行代码并发送一封电子邮件,当我在命令行中键入 php /var/www/html/testimages/script.php
时效果很好,但在 cron 中设置时我没有收到该邮件。
我做错了什么?
非常感谢。
此致。
拉斐尔.
编辑:
这是我正在尝试 php 的文件 运行
#!/usr/local/bin/php -q
<?php
echo '<script>!function(e){function t(e,t){var n=new Image,r=e.getAttribute("data-src");n.onload=function(){e.parent?e.parent.replaceChild(n,e):e.src=r,t?t():null},n.src=r}function n(t){var n=t.getBoundingClientRect();return n.top>=0&&n.left>=0&&n.top<=(e.innerHeight||document.documentElement.clientHeight)}for(var r=function(e,t){if(document.querySelectorAll)t=document.querySelectorAll(e);else{var n=document,r=n.styleSheets[0]||n.createStyleSheet();r.addRule(e,"f:b");for(var l=n.all,c=0,o=[],i=l.length;i>c;c++)l[c].currentStyle.f&&o.push(l[c]);r.removeRule(0),t=o}return t},l=function(t,n){e.addEventListener?this.addEventListener(t,n,!1):e.attachEvent?this.attachEvent("on"+t,n):this["on"+t]=n},c=new Array,o=r("img.lazy"),i=function(){for(var e=0;e<c.length;e++)n(c[e])&&t(c[e],function(){c.splice(e,e)})},u=0;u<o.length;u++)c.push(o[u]);i(),l("scroll",i)}(this);</script>'
echo '<style>table, th, td {border: 1px solid black; border-collapse: collapse;}th, td {padding: 15px;}th { text-align: left; background-color: #666666;}</style>';
require '/var/www/html/libraries/mail/PHPMailerAutoload.php';
require '/var/www/html/libraries/myLibrary/core.php';
$mail = new PHPMailer;
$to = "example@gmail.com";
ob_start();
function echoText($text) {
echo $text;
}
$show_json = $_GET['show_json'];
echoContent(); // belongs to the core
// send email
$mail->isSMTP(); // Set mailer to use SMTP
$mail->Host = 'smtp.gmail.com'; // Specify main and backup SMTP servers
$mail->SMTPAuth = true; // Enable SMTP authentication
$mail->Username = 'example@gmail.com'; // SMTP username
$mail->Password = 'secret'; // SMTP password
$mail->SMTPSecure = 'tls'; // Enable TLS encryption, `ssl` also accepted
$mail->Port = 587; // TCP port to connect to
$mail->setFrom('example@gmail.com', 'Watchdog - Rafael');
// $mail->addAddress('joe@example.net', 'Joe User'); // Add a recipient
$mail->addAddress($to);
// $mail->addReplyTo('info@example.com', 'Information');
// $mail->addBCC('bcc@example.com');
// $mail->addAttachment('/var/tmp/file.tar.gz'); // Add attachments
// $mail->addAttachment('/tmp/image.jpg', 'new.jpg'); // Optional name
$mail->isHTML(true); // Set email format to HTML
$mail->Subject = 'Test on database';
$contents = ob_get_contents();
$mail->Body = $contents;
// $mail->AltBody = 'This is the body in plain text for non-HTML mail clients';
if(!$mail->send()) {
echo 'Message could not be sent.';
echo 'Mailer Error: ' . $mail->ErrorInfo;
} else {
echo 'Message has been sent';
}
print_r(error_get_last());
}
?>
编辑:
我正在尝试将 bash 脚本设置为 运行 它,甚至将结果导出到 log.txt... log.txt
是空的。
我发现系统正在向我发送如下邮件:
You've got a new mail on /var/mail/ubuntu
我忽略了它们,因为我能够在命令行上执行脚本,所以我认为没有任何错误。但它们是 (a ;
)... 所以如果出现最小错误,命令行会执行脚本而不是 cron。原来如此。
您的问题在 php 脚本的第 1 行 - 缺少终止符;
您发布的 CRON 系统日志显示 cron 运行ning 脚本。 您收到的电子邮件很可能来自 CRON 而不是您的脚本。 不幸的是,您的脚本的工作是发送电子邮件,但是,您的脚本不会发送给本地用户 "ubuntu".
如果您阅读这些邮件(您应该阅读!),您可能会发现问题所在。
该脚本要么有错误,要么没有,要么是 运行,要么不是。 根据您对 php(-cli).ini 的配置,您很可能没有收到任何错误报告,因此您认为脚本是正确的。 语法就是语法。
没有 "minimal error" 这样的东西。如果你侥幸逃脱,我们称之为 "feature" ;)