HttpLogClearCommand.php
857 Bytes
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
<?php
namespace App\Console\Commands;
use Illuminate\Console\Command;
use Illuminate\Support\Facades\DB;
class HttpLogClearCommand extends Command
{
    /**
     * The name and signature of the console command.
     *
     * @var string
     */
    protected $signature = 'http-log:clear';
    /**
     * The console command description.
     *
     * @var string
     */
    protected $description = '清理请求系统日志';
    /**
     * Execute the console command.
     *
     * @return int
     */
    public function handle(): int
    {
        $this->line('clear start ...');
        do {
            $deleted = DB::table('system_http_logs')->where('created_at', '<', now()->subMonth()->toDateTimeString())->take(1000)->delete();
        } while ($deleted !== 0);
        $this->line('clear end ...');
        return self::SUCCESS;
    }
}