Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/mage2tv/magento-cache-clean
A faster drop in replacement for bin/magento cache:clean with file watcher
https://github.com/mage2tv/magento-cache-clean
cachemanager development-utility magento2
Last synced: 2 months ago
JSON representation
A faster drop in replacement for bin/magento cache:clean with file watcher
- Host: GitHub
- URL: https://github.com/mage2tv/magento-cache-clean
- Owner: mage2tv
- License: bsd-3-clause
- Created: 2018-08-08T18:05:40.000Z (over 6 years ago)
- Default Branch: master
- Last Pushed: 2024-05-13T08:18:54.000Z (8 months ago)
- Last Synced: 2024-10-31T17:08:20.227Z (2 months ago)
- Topics: cachemanager, development-utility, magento2
- Language: Clojure
- Homepage:
- Size: 4.96 MB
- Stars: 532
- Watchers: 29
- Forks: 63
- Open Issues: 13
-
Metadata Files:
- Readme: readme.md
- Funding: .github/FUNDING.yml
- License: LICENSE
Awesome Lists containing this project
- awesome-magento2 - Magento Cache Clean - A faster drop in replacement for bin/magento (Open Source Extensions / Development Utilities)
- awesome-magento2 - Magento Cache Clean - A faster drop in replacement for bin/magento (Open Source Extensions / Development Utilities)
README
> "You know, hope is a mistake. If you can't fix what's broken, you'll, uh... you'll go insane." - Max Rockatansky
# Magento 2 Cache Clean
A faster drop in replacement for `bin/magento cache:clean` with a file watcher.
The file watcher automatically cleans affected cache types in the Magento 2
cache during development.
For example, if you make a change to a template, it only cleans the
`block_html` and `full_page` caches, not the `config` or `layout` caches.The project is only tested on MacOS and Linux.
Please report bugs by opening an issue on the [GitHub issue tracker](https://github.com/mage2tv/magento-cache-clean/issues).## Features
* Supports file, redis and varnish cache backends
* Removes affected generated code classes when a source file is changed
* Zero configuration, all required information is read from `app/etc/env.php`
* Hotkeys for quick cache flushes while the watcher is running## Installation & Updating
Installation:
``` shell
composer require --dev mage2tv/magento-cache-clean
```Update:
``` shell
composer update --dev mage2tv/magento-cache-clean
```The tool is commonly installed globally using `composer global require ...`.
## Usage
In your Magento directory, run `vendor/bin/cache-clean.js --watch`
Press `Ctrl-C` to exit the watcher process.
The script can also be used as a faster drop in replacement of `bin/magento cache:clean`.
For example:``` shell
vendor/bin/cache-clean.js config full_page
```
(It's quicker because the start up time of `bin/magento` is so slow.)There are several options to customize the behavior:
```
vendor/bin/cache-clean.js --help
Sponsored by https://www.mage2.tvUsage: cache-clean.js [options and flags] [cache-types...]
Clean the given cache types. If none are given, clean all cache types.--directory|-d Magento base directory
--watch|-w Watch for file changes
--verbose|-v Display more information
--no-flood-guard|-n Disable the 5s debounce per cache type
--debug|-vv Display too much information
--silent|-s Display less information
--version Display the version
--help|-h This help message
```Usually I run the command once with the `--watch` switch when I start
development, and when I make a change that isn't automatically detected (yet),
I run `vendor/bin/cache-clean.js` with the given cache types as a drop in
replacement for `bin/magento cache:clean`.### Hotkeys
When the watcher is running, segments of the cache can be cleaned with
individual keystrokes:|Key|Cache Segment(s)|
|---|----------------|
|`c`| `config` |
|`b`| `block_html` |
|`l`| `layout` |
|`f`| `full_page` |
|`a`| (a for all) |
|`v`| (v for view) `block_html`, `layout`, `full_page`, `translate` |
|`t`| `translate` |There also are hotkeys to clean the static assets in the `A`dminhtml or
the `F`rontend area or `I`ntegration test sandboxes or clean the `G`enerated code directory.### Prerequisites:
* `node.js` (built on 10, but should work with older 8.x versions, too).
* It probably is a good idea to turn on all Magento caches
`bin/magento cache:enable` to get the full benefit.## Known issues
* Currently, the watcher has to be restarted after a new theme is added, so it
is added to the watchlist.* Changes to files on NFS mounts (e.g. in vagrant) do not trigger the watches.
Depending on a given setup, it might be possible to run the watcher on the
host system instead.* If you run the task in PHPStorm and the hotkeys are not working, search for
actions by pressing `STRG+SHIFT+A`, then search for "registry...", then
enable `nodejs.console.use.terminal` and restart the watcher process.* Not tested a lot on Windows, please open an issue if you want to contribute.
* If you run into the error `Error NOSPC` or `ENOSPC: System limit for number of file watchers reached` on Linux, run the command:
``` shell
echo fs.inotify.max_user_watches=524288 | sudo tee -a /etc/sysctl.conf && sudo sysctl -p
```* In Magento 2.1.0 - 2.3.3 there is a [bug](https://github.com/magento/magento2/pull/22228) that causes the full page cache
records to be written to the `var/cache` directory instead of `var/page_cache`.
This issue causes the cache cleaner behavior to be erratic.
There is an easy workaround, namely removing all cache configuration from
the default `app/etc/env.php`. The bug only affects the default config with the
file system cache backend. Redis or Varnish are not affected.
The bug will be fixed in the (currently upcoming) Magento 2.3.4 release.## More information
* Some words on using the watcher with [Docker & VMs](https://github.com/mage2tv/magento-cache-clean/blob/master/doc/docker-and-vm.md).
* [Running the watcher from code](https://github.com/mage2tv/magento-cache-clean/blob/master/doc/using-via-code.md).
* The [rationale](https://github.com/mage2tv/magento-cache-clean/blob/master/doc/rationale.md) explains the reasons I wrote the utility.
* How to [build](https://github.com/mage2tv/magento-cache-clean/blob/master/doc/building.md) the tool from source.
* Integrating the watcher with PHPStorm:
* [Mage2 TV] [How to set up the watcher as a PHPStorm startup task](https://www.mage2.tv/content/fundamentals/magento-cli-tool/configuring-the-magento-cache-clean.js-utility-phpstorm-startup-task/).
* [Mage2 TV] [How to enable the hotkeys in PHPStorm](https://www.mage2.tv/content/fundamentals/magento-cli-tool/enabling-the-hotkeys-for-the-cache-clean.js-utility-in-phpstorm/).## Thanks
This script was inspired by [Timon de Groot](https://twitter.com/TimonGreat)'s
[blog post](https://blog.timpack.org/speed-up-magento-development) where he
describes the idea to use a file watcher in PHPStorm to call `redis-cli` to
clear the complete cache whenever a XML file is modified.
The only downside of that solution is that it always flushes the full cache and
only works with redis.Thank you also to everybody who gave feedback, shared ideas and helped test new
features! This tool would be impossible without you!## Copyright & License
Copyright 2019 - present by Vinai Kopp, distributed under the BSD-3-Clause license (see
the [LICENSE](https://github.com/mage2tv/magento-cache-clean/blob/master/LICENSE) file).