geonative / garbage-collector
Doctrine Entities garbage collector
Installs: 11 502
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 2
Forks: 0
Open Issues: 2
Requires
- php: >=8.2
- doctrine/doctrine-bundle: ^2.5
- doctrine/orm: ^2.10
- symfony/console: ^6.4|^7.0
- symfony/http-kernel: ^6.4|^7.0
- symfony/uid: ^6.4|^7.0
Requires (Dev)
- pestphp/pest: ^2.36
- symfony/yaml: ^6.4|^7.0
This package is auto-updated.
Last update: 2025-03-12 09:18:05 UTC
README
This package is a Symfony Bundle providing a "garbage collector" command to prune Doctrine entities that you consider stale.
Installation
PHP 8.2 or above is required.
composer require geonative/garbage-collector
Configuration
-
Add the bundle into your
config/bundles.php
(likely to be done automatically with Symfony Flex). -
Update your configuration:
# config/packages/doctrine.yaml doctrine: orm: mappings: GarbageCollectorBundle: ~
# config/services.yaml services: _instanceof: GeoNative\GarbageCollector\PrunableRepositoryInterface: tags: [!php/const GeoNative\GarbageCollector\Services\GarbageCollector::PRUNABLE_REPOSITORY]
- Update your database schema:
php bin/console doctrine:schema:update --dump-sql --force
- Implement
GeoNative\GarbageCollector\PrunableRepositoryInterface
on your repositories:getGarbageCollectorCheckInterval()
should return the minimum interval between checks, to avoid ruining your DB performancespruneStaleEntities()
should actually perform removals and return the number of entities which have been removed.
If your entities should be pruned against a DateTime column, you can use GeoNative\GarbageCollector\PruneStaleEntitiesTrait
to get started faster.
Usage
Oneshot
php bin/console gc:entities:prune
You can store this in a crontab to periodically cleanup your entities.
Daemonize
This command can also run in a loop and be daemonized with supervisord or systemctl.
The react/event-loop
package is required.
php bin/console gc:entities:prune --loop=5
The Garbage Collector will pass every 5 seconds.
Lock
If your application runs on multiple hosts, you may want to prevent several instances
of the Garbage Collector from running simultaneously. To do so, just add a --lock
option:
php bin/console gc:entities:prune --lock
Tests
vendor/bin/pest
License
MIT.