ларвел Крон не стреляет, но другие кроны стреляют - PullRequest
0 голосов
/ 26 сентября 2018

У меня установлена ​​Ubuntu 18.04 и запущен laravel 5.6, и я установил планировщик по умолчанию в crontab -e

* * * * * php /var/www/html/laravel/artisan schedule:run >> /var/www/html/crons.txt 2>&1

, и он не работает

мой код ядра

<?php

namespace App\Console;

use Illuminate\Console\Scheduling\Schedule;
use Illuminate\Foundation\Console\Kernel as ConsoleKernel;

class Kernel extends ConsoleKernel
{
    /**
     * The Artisan commands provided by your application.
     *
     * @var array
     */
    protected $commands = [
        'App\Console\Commands\CompletelyReviewInternship',
        'App\Console\Commands\MigrateUsers',
        'App\Console\Commands\MigrateUsersTwo',
        'App\Console\Commands\MigrateUsersThree',
        'App\Console\Commands\MigrateUsersFour',
        'App\Console\Commands\MigrateUsersFive',
        'App\Console\Commands\MigrateUsersSix',
        'App\Console\Commands\MigrateUsersSeven',
        'App\Console\Commands\MigrateUsersEight',
        'App\Console\Commands\MigrateUsersNine',
        'App\Console\Commands\MigrateUsersTen'
    ];

    /**
     * Define the application's command schedule.
     *
     * @param  \Illuminate\Console\Scheduling\Schedule  $schedule
     * @return void
     */
    protected function schedule(Schedule $schedule)
    {
        $schedule->command('review:internship')->hourly();

        $schedule->command('migrate:users')->dailyAt('17:40');

        $schedule->command('migrate:userstwo')->dailyAt('17:40');

        $schedule->command('migrate:usersthree')->dailyAt('17:40');

        $schedule->command('migrate:usersthree')->dailyAt('17:40');

        $schedule->command('migrate:usersfour')->dailyAt('17:40');

        $schedule->command('migrate:usersfive')->dailyAt('17:40');

        $schedule->command('migrate:userssix')->dailyAt('17:40');

        $schedule->command('migrate:usersseven')->dailyAt('17:40');

        $schedule->command('migrate:userseight')->dailyAt('17:40');

        $schedule->command('migrate:usersnine')->dailyAt('17:40');

        $schedule->command('migrate:usersten')->dailyAt('17:40');

    }

    /**
     * Register the commands for the application.
     *
     * @return void
     */
    protected function commands()
    {
        $this->load(__DIR__.'/Commands');

        require base_path('routes/console.php');
    }
}

Пожалуйста, обратите внимание: - мои команды запускаются с php artisan, и я использую nginx в качестве моего веб-сервера

любые рекомендации по этому вопросу будут целесообразны

Ответы [ 2 ]

0 голосов
/ 26 сентября 2018

Я думаю, что может быть несколько причин:

  • Ваше приложение находится в режиме обслуживания.В этом случае ни одна команда не будет запущена, если вы не используете ->evenInMaintenanceMode() для каждой команды
  • Вы используете время, но время на вашем компьютере отличается от ожидаемого, поэтому команда будет запущена на более позднем этапе.Убедитесь, что время действительно верно, или попробуйте изменить временные ограничения на ->everyMinute(), просто чтобы убедиться, что в этом случае это не проблема

Как сторона, которой нет - не нужно перечислять все командыв $commands свойстве, если они находятся в каталоге Commands.

0 голосов
/ 26 сентября 2018

если вы используете nginx, то вы установили пользователя www-data на вкладке cron с таким разрешением суперпользователя, как это

* * * * * sudo -u www-data php /var/www/html/laravel/artisan schedule:run >> /dev/null 2>&1
...