我正在与Schedular
in合作Laravel 5.8
。设置后Commands
,Command Kernal
我收到错误,
在 /home/SERVER_USER_NAME/public_html/vendor/symfony/console/Input/ArgvInput.php:261 为 foreach() 提供的参数无效)
下面是Kernal
方法,
protected $commands = [
Commands\OfferMonitor::class,
Commands\RankingCommand::class,
Commands\CreditCycle::class,
];
protected function schedule(Schedule $schedule)
{
$schedule->command('KG:OfferMonitor')->dailyAt('01:00');
$schedule->command('KG:UpdateRanks')->everyTenMinutes();
$schedule->command('KG:CreditCycle')->dailyAt('00:00');
}
这是我Laravel Cron Job
在生产服务器上的运行,
我认为 cron 作业本身会引发错误,我使用的是php
二进制而不是php-cli
. 是否导致错误?如果是的话,这个问题的解决方法是什么?
这是来自 Laravel 的完整错误日志和堆栈跟踪,
Invalid argument supplied for foreach() {"exception":"[object] (ErrorException(code: 0): Invalid argument supplied for foreach() at /home/SERVER_USER_NAME/public_html/vendor/symfony/console/Input/ArgvInput.php:261)
[stacktrace]
#0 /home/SERVER_USER_NAME/public_html/vendor/symfony/console/Input/ArgvInput.php(261): Illuminate\\Foundation\\Bootstrap\\HandleExceptions->handleError(2, 'Invalid argumen...', '/home/SERVER_USER_NAME...', 261, Array)
#1 /home/SERVER_USER_NAME/public_html/vendor/symfony/console/Application.php(970): Symfony\\Component\\Console\\Input\\ArgvInput->getFirstArgument()
#2 /home/SERVER_USER_NAME/public_html/vendor/laravel/framework/src/Illuminate/Console/Application.php(81): Symfony\\Component\\Console\\Application->getCommandName(Object(Symfony\\Component\\Console\\Input\\ArgvInput))
#3 /home/SERVER_USER_NAME/public_html/vendor/laravel/framework/src/Illuminate/Foundation/Console/Kernel.php(133): Illuminate\\Console\\Application->run(Object(Symfony\\Component\\Console\\Input\\ArgvInput), Object(Symfony\\Component\\Console\\Output\\ConsoleOutput))
#4 /home/SERVER_USER_NAME/public_html/artisan(36): Illuminate\\Foundation\\Console\\Kernel->handle(Object(Symfony\\Component\\Console\\Input\\ArgvInput), Object(Symfony\\Component\\Console\\Output\\ConsoleOutput))
#5 {main}
"}
注意:当我从终端使用它们时,
Commands
调度的 in运行正常,因此命令没有问题。Kernal.php
artisan