Joh*_*ohn 4 php laravel laravel-4 laravel-3
我需要学习如何使用Laravel中的cron作业.我可以看到文档没有指定这部分.我找到了一个教程,但它是关于Laravel-3的.你可以给我一些关于如何安排每天运行一次cron工作的建议吗?吗?有没有关于这个问题的教程?
到目前为止,我的代码如下:
JobDaemon.php:
<?php
use Illuminate\Console\Command;
use Symfony\Component\Console\Input\InputOption;
use Symfony\Component\Console\Input\InputArgument;
class JobDaemon extends Command {
/**
* The console command name.
*
* @var string
*/
protected $name = 'job-daemon';
/**
* The console command description.
*
* @var string
*/
protected $description = 'Get all recent jobs once a day.';
/**
* Create a new command instance.
*
* @return void
*/
public function __construct()
{
parent::__construct();
}
/**
* Execute the console command.
*
* @return void
*/
public function fire()
{
$this->info('fired');
}
/**
* Get the console command arguments.
*
* @return array
*/
protected function getArguments()
{
return array(
//array('example', InputArgument::REQUIRED, 'An example argument.'),
);
}
/**
* Get the console command options.
*
* @return array
*/
protected function getOptions()
{
return array(
//array('example', null, InputOption::VALUE_OPTIONAL, 'An example option.', null),
);
}
}
Run Code Online (Sandbox Code Playgroud)
我使用以下命令进行设置
php artisan command:make JobDaemon
Run Code Online (Sandbox Code Playgroud)
我的工匠文件如下:
<?php
Artisan::add(new JobDaemon);
Run Code Online (Sandbox Code Playgroud)
我从我的控制台得到以下内容......
johnnemo@johnnemo:/opt/lampp/htdocs/e-support-uop$ tail -f /var/log/syslog | grep -i cron
Jan 1 18:31:09 johnnemo crontab[4484]: (johnnemo) REPLACE (johnnemo)
Jan 1 18:31:09 johnnemo crontab[4484]: (johnnemo) END EDIT (johnnemo)
Jan 1 18:35:01 johnnemo CRON[5054]: (johnnemo) CMD (php /opt/lampp/htdocs/e-support-uop/artisan job-daemon)
Jan 1 18:35:02 johnnemo CRON[5053]: (CRON) info (No MTA installed, discarding output)
Jan 1 18:39:01 johnnemo CRON[5064]: (root) CMD ( [ -x /usr/lib/php5/maxlifetime ] && [ -x /usr/lib/php5/sessionclean ] && [ -d /var/lib/php5 ] && /usr/lib/php5/sessionclean /var/lib/php5 $(/usr/lib/php5/maxlifetime))
Jan 1 18:40:01 johnnemo CRON[5076]: (johnnemo) CMD (php /opt/lampp/htdocs/e-support-uop/artisan job-daemon)
Jan 1 18:40:01 johnnemo CRON[5075]: (CRON) info (No MTA installed, discarding output)
Run Code Online (Sandbox Code Playgroud)
Ant*_*iro 21
首先,您需要确保新命令已启动,因此如果您运行
php artisan list
Run Code Online (Sandbox Code Playgroud)
'job-daemon'必须在命令列表中
然后你测试它:
php artisan job-daemon
Run Code Online (Sandbox Code Playgroud)
它有用吗?很酷,现在你可以设置自己的编辑器:
export EDITOR=nano
Run Code Online (Sandbox Code Playgroud)
用它打开crontab:
[sudo] crontab -e
Run Code Online (Sandbox Code Playgroud)
执行类型到php的正确路径:
type php
Run Code Online (Sandbox Code Playgroud)
你应该得到类似的东西
php is hashed (/opt/lampp/bin/php)
Run Code Online (Sandbox Code Playgroud)
所以你的php可执行文件是
/opt/lampp/bin/php
Run Code Online (Sandbox Code Playgroud)
这将打开并编辑当前的cron作业,sudo是可选的打开root crontab,只需添加一行与你的:
25 10 * * * /opt/lampp/bin/php /whatever/directory/your/site/is/artisan job-daemon
Run Code Online (Sandbox Code Playgroud)
这将在每天上午10:25运行您的命令.
要每隔5分钟执行一次
*/5 * * * * /opt/lampp/bin/php /whatever/directory/your/site/is/artisan job-daemon
Run Code Online (Sandbox Code Playgroud)
然后你tail在syslog上看它运行:
tail -f /var/log/syslog | grep -i cron
Run Code Online (Sandbox Code Playgroud)
你应该看到类似的东西
Jan 1 10:25:01 server CRON[19451]: (root) CMD (php /var/www/<siteName>/artisan job-daemon)
Run Code Online (Sandbox Code Playgroud)
在你的命令中你不能真正在屏幕上打印东西,你不会看到它们打印,所以要测试你必须,例如,保存一些文件:
public function fire()
{
File::append('/tmp/laravel.txt', "fired\n");
Log::info('fired');
}
Run Code Online (Sandbox Code Playgroud)
然后
tail -f /tmp/laravel.txt
Run Code Online (Sandbox Code Playgroud)
实时查看结果.