0

Laravel 任务计划程序在 Windows XAMPP 服务器中无法正常工作。我制作数据库自动备份脚本源。备份数据库工作正常,但 Laravel 调度程序在 Windows 服务器中无法正常工作

app/Console/Commands/DatabaseBackUp.php使用php artisan make:command DatabaseBackUp命令创建的文件

<?php

namespace App\Console\Commands;

use Illuminate\Console\Command;
use Carbon\Carbon;

class DatabaseBackUp extends Command
{
    /**
     * The name and signature of the console command.
     *
     * @var string
     */
    protected $signature = 'database:backup';

    /**
     * The console command description.
     *
     * @var string
     */
    protected $description = 'Command description';

    /**
     * Create a new command instance.
     *
     * @return void
     */
    public function __construct()
    {
        parent::__construct();
    }

    /**
     * Execute the console command.
     *
     * @return int
     */
    public function handle()
    {
        $filename = "backup-" . Carbon::now()->format('Y-m-d') . ".sql";

        $command = "". env('DUMP_COMMAND_PATH') ." --user=" . env('DB_USERNAME') ." --password=" . env('DB_PASSWORD') . " --host=" . env('DB_HOST') . " " . env('DB_DATABASE') . " > " . storage_path() . "/app/backup/" . $filename;
  
        $returnVar = NULL;
        $output  = NULL;
  
        exec($command, $output, $returnVar);
        dd("Database backup Successfully Done - $filename Time:- ".Carbon::now());
    }
}
?>

app/Console/Kernel.php文件

<?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\DatabaseBackUp'
    ];

    /**
     * Define the application's command schedule.
     *
     * @param  \Illuminate\Console\Scheduling\Schedule  $schedule
     * @return void
     */
    protected function schedule(Schedule $schedule)
    {
        // $schedule->command('inspire')->hourly();
        $schedule->command('database:backup')
                    ->daily()
                    ->appendOutputTo(storage_path('logs/db-backups.log'));
    }

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

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

现在,当我php artisan database:backup手动点击命令时,它会创建数据库备份...

但根据官方文档。当我点击命令时,Laravel 8cd C:\xampp\htdocs\laravel-project && php artisan schedule:run >> /dev/null 2>&1显示错误,例如The system cannot find the path specified.

但是当我点击php artisan schedule:run命令时,它只创建一次数据库备份。不要重复我们提到的任务。

4

1 回答 1

0

在 Laravel Docs 中提到了 scheduler start 命令cd /path-to-your-project && php artisan schedule:run >> /dev/null 2>&1,它适用于 Linux crontab 功能,对于 Windows,我们需要使用 Task Scheduler

对于 Linux

crontab -e

* * * * * php /path/to/artisan schedule:run 1>> /dev/null 2>&1

或者

* * * * * cd /path-to-your-project && php artisan schedule:run >> /dev/null 2>&1

对于Windows(技巧 1)

  1. 在您的应用程序目录中创建 .bat 文件

db-Backup.bat 文件

在 db-Backup.bat 文件中写入以下行并保存

cd C:\xampp\htdocs\microtechcoupon && C:\xampp\php\php artisan schedule:run 

2.按 Windows + R,写 Taskschd.msc 并按 Enter & 任务计划程序将打开,3.点击创建任务

  1. 根据需要填写输入字段。有关更多详细信息,请参见此处如何填写任务计划程序中的字段

对于Windows(技巧 2)

如果您想防止在调度程序运行您的任务时每分钟都不会弹出命令行。然后你可以使用第二个技巧

  1. 按 Windows + R,写入 Taskschd.msc 并按 Enter 并打开任务计划程序

  2. 填写字段。但是在“操作”选项卡中单击“新建”,在“操作”字段中选择“启动程序”

  3. 然后在设置部分填写C:\xampp\php\php.exe程序/脚本输入字段和C:\xampp\htdocs\microtechcoupon\artisan schedule:run添加参数(可选)字段然后保存

Windows 中第二个技巧的功劳:- https://quantizd.com/how-to-use-laravel-task-scheduler-on-windows-10/

于 2021-11-13T12:39:04.347 回答