When you use the file
cache driver, you may have noticed that the cache files are never deleted automatically. They are overwritten when the cache is refreshed which is good, but if there is some randomness in you cache keys, or for some other reason some of your cache files are never touched again, they will stay on your server forever. This package helps you to get rid of these lingering files.
This package only adds one artisan command: php artisan cache:clear-expired
and it will delete all cache files that has already been expired.
You can install the package via composer:
composer require arifhp86/laravel-clear-expired-cache-file
Run the following command
php artisan cache:clear-expired
You can also schedule the command to run automatically. For example, if you want to run the command every day at 1 AM, you can add the following to your app/Console/Kernel.php
file:
protected function schedule(Schedule $schedule)
{
$schedule->command('cache:clear-expired')->dailyAt('01:00');
}
You can run the command in dry run mode. In this mode, the command will not delete any files. It will only show you the files that will be deleted if you run the command without the --dry-run
option.
php artisan cache:clear-expired --dry-run
By default, the command will delete all empty directories after deleting the expired files. You can disable this behavior by using the --disable-directory-delete
option.
php artisan cache:clear-expired --disable-directory-delete
The command triggers three events:
Arifhp86\ClearExpiredCacheFile\Events\GarbageCollectionStarting
: Before the command runs.Arifhp86\ClearExpiredCacheFile\Events\GarbageCollectionEnded
: After the command runs.Arifhp86\ClearExpiredCacheFile\Events\GarbageCollectionFailed
: If the command fails.
You can use these events to run your own code before or after the command runs.
// app/Providers/EventServiceProvider.php boot method
use Arifhp86\ClearExpiredCacheFile\Events\GarbageCollectionEnded;
Event::listen(function (GarbageCollectionEnded $event) {
$timeTaken = $event->time; // in seconds
$memory = $event->memory; // in bytes
$numberOfFilesDeleted = $event->expiredFiles->getCount();
$diskCleared = $event->expiredFiles->getFormattedSize();
$remainingFiles = $event->activeFiles->getCount();
$remainingDisk = $event->activeFiles->getFormattedSize();
$numberOfDeletedDirectories = $event->deletedDirectories;
// Send email notification
//...
});
// app/Providers/EventServiceProvider.php boot method
use Arifhp86\ClearExpiredCacheFile\Events\GarbageCollectionFailed;
Event::listen(function (GarbageCollectionFailed $event) {
$exception = $event->exception;
$message = $exception->getMessage();
$stackTrace = $exception->getTraceAsString();
// Send email notification
//...
});
Please see CHANGELOG for more information on what has changed recently.
Please see CONTRIBUTING for details.
Please review our security policy on how to report security vulnerabilities.
The MIT License (MIT). Please see License File for more information.