mage2tv / magento-cache-clean

A faster drop in replacement for bin/magento cache:clean with file watcher
BSD 3-Clause "New" or "Revised" License
531 stars 63 forks source link

Watcher doesn't execute on Magento 2.4.4 + PHP 8+ #102

Closed markshust closed 2 years ago

markshust commented 2 years ago

Testing this out on Magento 2.4.4 + PHP 8.1. The watcher seems to start fine with no errors, but doesn't appear to be clearing out the appropriate caches. Confirmed by writing a new controller action, changing it, and the updates do not appear until a manual bin/magento cache:clean full_page is executed.

Vinai commented 2 years ago

Thanks for reporting the issue! I’m going to check what is happening…

Vinai commented 2 years ago

@markshust could you maybe do me a favor and help me pinpoint the issue quicker by running the tool with -vv? It will produce a ton of debug output. Please then modify the controller again and paste the log here. Thanks!

markshust commented 2 years ago

Ah thanks -- here you go:

app@0ccc115e9d3d:~/html$ /var/www/.composer-global/vendor/bin/cache-clean.js -w -vv
Release 1.0.46 sponsored by https://www.mage2.tv

Magento dir /var/www/html
Listing modules by shelling out to php
12:43:27 ERROR: failed shelling out to php for reading the module list.
12:43:27 ERROR Details: nil
12:43:27 ERROR Details: 
Listing themes by shelling out to php
12:43:27 ERROR: failed shelling out to php for reading the theme list.
12:43:27 ERROR Details: nil
12:43:27 ERROR Details: 
Watching static files in /var/www/html/pub/static/frontend
Config dump file /var/www/html/var/cache-clean-config.json not found
Monitoring app/etc/config.php for new modules
Reading app config by shelling out to php
Reading app config by shelling out to php
Consider enabling the currently disabled caches:
Reading app config by shelling out to php
full_page
Listening for hotkeys
Hot-keys for manual cache cleaning:
[c]onfig [b]lock_html [l]ayout [t]ranslate [f]ull_page [v]iew [a]ll

Clean generated code: [G]
Clean integration test sandboxes: [I]
Clean static content areas: [F]rontend [A]dminhtml

Watcher initialized (Ctrl-C to quit)

Just for reference, here's the command executed in the similar env on PHP 7.4 (which works):

``` app@ee9d3fb85f88:~/html$ /var/www/.composer-global/vendor/bin/cache-clean.js -w -vv Release 1.0.45 sponsored by https://www.mage2.tv Magento dir /var/www/html Listing modules by shelling out to php Watching module magento/module-asynchronous-operations Watching module magento/module-catalog Watching module magento/module-require-js Watching module magento/module-backend Watching module magento/module-authorization Watching module magento/module-captcha Watching module magento/module-checkout Watching module magento/module-sales-sequence Watching module magento/module-bundle Watching module magento/module-sales Watching module magento/module-customer Watching module magento/module-integration Watching module magento/module-user Watching module magento/module-deploy Watching module magento/module-config Watching module magento/module-directory Watching module magento/module-store Watching module magento/module-cms Watching module magento/module-email Watching module magento/module-widget Watching module magento/module-theme Watching module magento/module-media-storage Watching module magento/module-eav Watching module magento/module-ui Watching module magento/module-catalog-inventory Watching module magento/module-rss Watching module magento/module-wishlist Watching module magento/module-newsletter Watching module magento/module-downloadable Watching module magento/module-review Watching module magento/module-reports Watching module magento/module-page-cache Watching module magento/module-tax Watching module magento/module-quote Watching module magento/module-inventory-api Watching module magento/module-inventory-sales-api Watching module magento/module-payment Watching module magento/module-inventory-configuration-api Watching module magento/module-inventory-catalog-api Watching module magento/module-inventory Watching module magento/module-contact Watching module magento/module-shipping Watching module magento/module-re-captcha-validation-api Watching module magento/module-rule Watching module magento/module-import-export Watching module magento/module-webapi Watching module magento/module-inventory-source-selection-api Watching module magento/module-graph-ql Watching module magento/module-indexer Watching module magento/module-catalog-search Watching module magento/module-media-gallery-api Watching module magento/module-inventory-reservations-api Watching module magento/module-inventory-multi-dimensional-indexer-api Watching module magento/module-inventory-source-deduction-api Watching module magento/module-catalog-rule Watching module magento/module-vault Watching module magento/module-re-captcha-ui Watching module magento/module-sales-inventory Watching module magento/module-inventory-sales Watching module magento/module-inventory-indexer Watching module magento/module-configurable-product Watching module magento/module-msrp Watching module magento/module-catalog-import-export Watching module magento/module-grouped-product Watching module magento/module-search Watching module magento/module-sales-rule Watching module magento/module-catalog-url-rewrite Watching module magento/module-inventory-in-store-pickup-api Watching module magento/module-gift-message Watching module magento/module-cron Watching module magento/module-url-rewrite Watching module magento/module-customer-graph-ql Watching module magento/module-instant-purchase Watching module magento/module-media-content-api Watching module magento/module-re-captcha-webapi-api Watching module magento/module-analytics Watching module magento/module-login-as-customer-api Watching module magento/module-quote-graph-ql Watching module magento/module-paypal Watching module magento/module-inventory-in-store-pickup-shipping-api Watching module magento/module-product-alert Watching module magento/module-adobe-ims-api Watching module magento/module-media-gallery-synchronization-api Watching module magento/module-send-friend Watching module klarna/module-core Watching module magento/module-eav-graph-ql Watching module dotmailer/dotmailer-magento2-extension Watching module magento/module-adobe-stock-client-api Watching module magento/module-catalog-graph-ql Watching module magento/module-developer Watching module magento/module-variable Watching module magento/module-inventory-configuration Watching module magento/module-inventory-distance-based-source-selection-api Watching module magento/module-inventory-in-store-pickup-sales-api Watching module magento/module-catalog-widget Watching module amzn/amazon-pay-and-login-with-amazon-core-module Watching module magento/module-adobe-stock-asset-api Watching module magento/module-advanced-search Watching module magento/module-inventory-low-quantity-notification-api Watching module magento/module-page-builder Watching module magento/module-re-captcha-frontend-ui Watching module magento/module-media-gallery-metadata-api Watching module magento/module-media-gallery-ui-api Watching module magento/module-checkout-agreements Watching module vertexinc/module-request-logging-api Watching module klarna/module-ordermanagement Watching module magento/module-adobe-stock-image-api Watching module magento/module-inventory-admin-ui Watching module magento/module-inventory-catalog Watching module magento/module-inventory-catalog-admin-ui Watching module magento/module-inventory-catalog-search Watching module magento/module-inventory-in-store-pickup Watching module magento/module-offline-shipping Watching module magento/module-page-builder-analytics Watching module magento/module-adobe-ims Watching module magento/module-media-content-synchronization-api Watching module magento/module-usps Watching module magento/module-catalog-sample-data Watching module amzn/login-with-amazon-module Watching module dotmailer/dotmailer-magento2-extension-chat Watching module klarna/module-kp Watching module magento/module-cms-graph-ql Watching module magento/module-cookie Watching module magento/module-elasticsearch Watching module magento/module-inventory-catalog-frontend-ui Watching module magento/module-inventory-export-stock-api Watching module magento/module-inventory-in-store-pickup-quote Watching module magento/module-inventory-in-store-pickup-sales Watching module magento/module-inventory-low-quantity-notification Watching module magento/module-login-as-customer Watching module magento/module-re-captcha-admin-ui Watching module magento/module-re-captcha-webapi-ui Watching module magento/module-security Watching module magento/module-swagger Watching module magento/module-url-rewrite-graph-ql Watching module paypal/module-braintree-core Watching module vertexinc/module-tax Watching module magento/module-bundle-import-export Watching module magento/module-media-gallery Watching module magento/module-media-gallery-ui Watching module magento/module-downloadable-graph-ql Watching module magento/module-google-analytics Watching module magento/module-login-as-customer-assistance Watching module magento/module-login-as-customer-frontend-ui Watching module magento/module-media-gallery-renditions-api Watching module magento/module-release-notification Watching module magento/module-remote-storage Watching module magento/module-robots Watching module magento/module-sales-graph-ql Watching module magento/module-swatches Watching module magento/module-weee Watching module vertexinc/module-address-validation-api Watching module amzn/amazon-pay-module Watching module dotmailer/dotmailer-magento2-extension-chat-graph-ql Watching module dotmailer/dotmailer-magento2-extension-graph-ql Watching module dotmailer/dotmailer-magento2-extension-sms Watching module klarna/module-kp-graph-ql Watching module klarna/module-onsitemessaging Watching module magento/module-adobe-stock-admin-ui Watching module magento/module-adobe-stock-asset Watching module magento/module-adobe-stock-client Watching module magento/module-adobe-stock-image Watching module magento/module-adobe-stock-image-admin-ui Watching module magento/module-aws-s3-page-builder Watching module magento/module-backup Watching module magento/module-catalog-page-builder-analytics Watching module magento/module-cms-page-builder-analytics Watching module magento/module-cms-url-rewrite Watching module magento/module-inventory-advanced-checkout Watching module magento/module-inventory-bundle-import-export Watching module magento/module-inventory-bundle-product Watching module magento/module-inventory-bundle-product-admin-ui Watching module magento/module-inventory-bundle-product-indexer Watching module magento/module-inventory-cache Watching module magento/module-inventory-catalog-search-bundle-product Watching module magento/module-inventory-catalog-search-configurable-product Watching module magento/module-inventory-configurable-product Watching module magento/module-inventory-configurable-product-admin-ui Watching module magento/module-inventory-configurable-product-frontend-ui Watching module magento/module-inventory-configurable-product-indexer Watching module magento/module-inventory-distance-based-source-selection Watching module magento/module-inventory-distance-based-source-selection-admin-ui Watching module magento/module-inventory-elasticsearch Watching module magento/module-inventory-export-stock Watching module magento/module-inventory-graph-ql Watching module magento/module-inventory-grouped-product Watching module magento/module-inventory-grouped-product-admin-ui Watching module magento/module-inventory-grouped-product-indexer Watching module magento/module-inventory-import-export Watching module magento/module-inventory-in-store-pickup-admin-ui Watching module magento/module-inventory-in-store-pickup-frontend Watching module magento/module-inventory-in-store-pickup-graph-ql Watching module magento/module-inventory-in-store-pickup-multishipping Watching module magento/module-inventory-in-store-pickup-quote-graph-ql Watching module magento/module-inventory-in-store-pickup-sales-admin-ui Watching module magento/module-inventory-in-store-pickup-shipping Watching module magento/module-inventory-in-store-pickup-shipping-admin-ui Watching module magento/module-inventory-in-store-pickup-webapi-extension Watching module magento/module-inventory-low-quantity-notification-admin-ui Watching module magento/module-inventory-product-alert Watching module magento/module-inventory-quote-graph-ql Watching module magento/module-inventory-requisition-list Watching module magento/module-inventory-reservation-cli Watching module magento/module-inventory-reservations Watching module magento/module-inventory-sales-admin-ui Watching module magento/module-inventory-sales-frontend-ui Watching module magento/module-inventory-setup-fixture-generator Watching module magento/module-inventory-shipping Watching module magento/module-inventory-shipping-admin-ui Watching module magento/module-inventory-source-selection Watching module magento/module-inventory-swatches-frontend-ui Watching module magento/module-inventory-visual-merchandiser Watching module magento/module-inventory-wishlist Watching module magento/module-page-builder-admin-analytics Watching module magento/module-product-links-sample-data Watching module magento/module-re-captcha-checkout Watching module magento/module-re-captcha-contact Watching module magento/module-re-captcha-customer Watching module magento/module-re-captcha-migration Watching module magento/module-re-captcha-newsletter Watching module magento/module-re-captcha-paypal Watching module magento/module-re-captcha-review Watching module magento/module-re-captcha-send-friend Watching module magento/module-re-captcha-store-pickup Watching module magento/module-re-captcha-user Watching module magento/module-re-captcha-validation Watching module magento/module-re-captcha-version-2-checkbox Watching module magento/module-re-captcha-version-2-invisible Watching module magento/module-re-captcha-version-3-invisible Watching module magento/module-re-captcha-webapi-graph-ql Watching module magento/module-re-captcha-webapi-rest Watching module magento/module-securitytxt Watching module magento/module-translation Watching module magento/module-two-factor-auth Watching module paypal/module-braintree-graph-ql Watching module temando/module-shipping-remover Watching module vertexinc/module-address-validation Watching module vertexinc/module-request-logging Watching module yotpo/magento2-module-yotpo-reviews Watching module magento/google-shopping-ads Watching module magento/module-admin-analytics Watching module magento/module-admin-notification Watching module magento/module-advanced-pricing-import-export Watching module magento/module-amqp Watching module magento/module-amqp-store Watching module magento/module-aws-s3 Watching module magento/module-bundle-graph-ql Watching module magento/module-cache-invalidate Watching module magento/module-cardinal-commerce Watching module magento/module-catalog-analytics Watching module magento/module-catalog-cms-graph-ql Watching module magento/module-catalog-customer-graph-ql Watching module magento/module-catalog-inventory-graph-ql Watching module magento/module-catalog-rule-configurable Watching module magento/module-catalog-rule-graph-ql Watching module magento/module-catalog-rule-sample-data Watching module magento/module-catalog-url-rewrite-graph-ql Watching module magento/module-checkout-agreements-graph-ql Watching module magento/module-cms-url-rewrite-graph-ql Watching module magento/module-compare-list-graph-ql Watching module magento/module-configurable-import-export Watching module magento/module-configurable-product-graph-ql Watching module magento/module-configurable-product-sales Watching module magento/module-configurable-sample-data Watching module magento/module-csp Watching module magento/module-currency-symbol Watching module magento/module-customer-analytics Watching module magento/module-customer-downloadable-graph-ql Watching module magento/module-customer-import-export Watching module magento/module-dhl Watching module magento/module-directory-graph-ql Watching module magento/module-downloadable-import-export Watching module magento/module-elasticsearch-6 Watching module magento/module-elasticsearch-7 Watching module magento/module-encryption-key Watching module magento/module-fedex Watching module magento/module-gift-message-graph-ql Watching module magento/module-google-adwords Watching module magento/module-google-optimizer Watching module magento/module-graph-ql-cache Watching module magento/module-grouped-catalog-inventory Watching module magento/module-grouped-import-export Watching module magento/module-grouped-product-graph-ql Watching module magento/module-jwt-framework-adapter Watching module magento/module-layered-navigation Watching module magento/module-login-as-customer-admin-ui Watching module magento/module-login-as-customer-graph-ql Watching module magento/module-login-as-customer-log Watching module magento/module-login-as-customer-page-cache Watching module magento/module-login-as-customer-quote Watching module magento/module-login-as-customer-sales Watching module magento/module-marketplace Watching module magento/module-media-content Watching module magento/module-media-content-catalog Watching module magento/module-media-content-cms Watching module magento/module-media-content-synchronization Watching module magento/module-media-content-synchronization-catalog Watching module magento/module-media-content-synchronization-cms Watching module magento/module-media-gallery-catalog Watching module magento/module-media-gallery-catalog-integration Watching module magento/module-media-gallery-catalog-ui Watching module magento/module-media-gallery-cms-ui Watching module magento/module-media-gallery-integration Watching module magento/module-media-gallery-metadata Watching module magento/module-media-gallery-renditions Watching module magento/module-media-gallery-synchronization Watching module magento/module-media-gallery-synchronization-metadata Watching module magento/module-message-queue Watching module magento/module-msrp-configurable-product Watching module magento/module-msrp-grouped-product Watching module magento/module-multishipping Watching module magento/module-mysql-mq Watching module magento/module-new-relic-reporting Watching module magento/module-newsletter-graph-ql Watching module magento/module-offline-payments Watching module magento/module-paypal-captcha Watching module magento/module-paypal-graph-ql Watching module magento/module-persistent Watching module magento/module-product-video Watching module magento/module-quote-analytics Watching module magento/module-quote-bundle-options Watching module magento/module-quote-configurable-options Watching module magento/module-quote-downloadable-links Watching module magento/module-related-product-graph-ql Watching module magento/module-review-analytics Watching module magento/module-review-graph-ql Watching module magento/module-sales-analytics Watching module magento/module-sample-data Watching module magento/module-send-friend-graph-ql Watching module magento/module-sitemap Watching module magento/module-store-graph-ql Watching module magento/module-swagger-webapi Watching module magento/module-swagger-webapi-async Watching module magento/module-swatches-graph-ql Watching module magento/module-swatches-layered-navigation Watching module magento/module-tax-graph-ql Watching module magento/module-tax-import-export Watching module magento/module-theme-graph-ql Watching module magento/module-theme-sample-data Watching module magento/module-ups Watching module magento/module-vault-graph-ql Watching module magento/module-version Watching module magento/module-webapi-async Watching module magento/module-webapi-security Watching module magento/module-weee-graph-ql Watching module magento/module-wishlist-analytics Watching module magento/module-wishlist-graph-ql Watching module magento/composer-root-update-plugin Watching module magento/module-bundle-sample-data Watching module magento/module-cms-sample-data Watching module magento/module-customer-sample-data Watching module magento/module-downloadable-sample-data Watching module magento/module-grouped-product-sample-data Watching module magento/module-msrp-sample-data Watching module magento/module-offline-shipping-sample-data Watching module magento/module-review-sample-data Watching module magento/module-sales-rule-sample-data Watching module magento/module-sales-sample-data Watching module magento/module-swatches-sample-data Watching module magento/module-tax-sample-data Watching module magento/module-widget-sample-data Watching module magento/module-wishlist-sample-data Listing themes by shelling out to php Watching theme theme-frontend-blank Watching theme theme-adminhtml-backend Watching theme theme-frontend-luma Watching static files in /var/www/html/pub/static/frontend Config dump file /var/www/html/var/cache-clean-config.json not found Monitoring app/etc/config.php for new modules Reading app config by shelling out to php Reading app config by shelling out to php Listening for hotkeys Hot-keys for manual cache cleaning: [c]onfig [b]lock_html [l]ayout [t]ranslate [f]ull_page [v]iew [a]ll Clean generated code: [G] Clean integration test sandboxes: [I] Clean static content areas: [F]rontend [A]dminhtml Watcher initialized (Ctrl-C to quit) ```
Vinai commented 2 years ago

Thank you, but what I meant to ask for was the output of the watcher running with -vv while you edit the Controller file. There should be some additional output regarding the controller being added, and about the decisions what to do.

It might look something like this:

15:09:03 Processing /var/www/html/app/code/Example/Check/Controller/Check/NewAction.php
15:09:03 Cleaning id(s): app_action_list
Reading app config by shelling out to php
15:09:03 Cache storage  {:id_prefix 69d_, :backend Magento\Framework\Cache\Backend\Redis, :backend_options {:server redis, :database 0, :port 6379, :password , :compress_data 1, :compression_lib }}
15:09:03 Cleaning id(s): 69d_APP_ACTION_LIST
... more output
15:09:03 Cleaning cache type(s) full_page
15:09:03 Using :page_cache cache backend
Reading app config by shelling out to php
15:09:03 Cache storage  {:id_prefix 69d_, :backend Magento\Framework\Cache\Backend\Redis, :backend_options {:server redis, :database 1, :port 6379, :password , :compress_data 0, :compression_lib }}
15:09:03 Flushing redis db 1
15:09:03 Varnish request: #js {:protocol http:, :hostname varnish, :port 80, :method PURGE, :path /, :headers #js {:X-Magento-Tags-Pattern .*}, :timeout 10000}
15:09:03 Using :page_cache cache backend
... more output

Adding a new Controller class will cause the APP_ACTION_LIST record and the FULL_PAGE cache type to be cleared once. Subsequent changes of the controller will not trigger an action by the cache watcher.

Could you please add a new Controller file and paste the output that is printed? Any file path matching Controller/**/*.php is treated as a controller class, so it should be enough to create an empty Dummy.php file withing a modules Controller folder.

Vinai commented 2 years ago

Oh, I was tiered yesterday evening. I only just noticed the ERROR: failed shelling out to php for reading the module list in the output you posted. Sorry for not picking that up immediately.

The command that is used to read the path to all modules (or themes) in the given installation is

php -r "require 'vendor/autoload.php'; \$bp = strlen(dirname(dirname(realpath('vendor/autoload.php')))) + 1; foreach ((new \Magento\Framework\Component\ComponentRegistrar)->getPaths('module') as \$m) echo substr(\$m, \$bp).PHP_EOL;"

The command that is executed to read the config is the following (except that an absolute path to the env.php file is used).

php -r "echo json_encode((require 'app/etc/env.php') ?? []);"

Can you run those commands manually?

markshust commented 2 years ago

Agh... this one is user error 🤪. I must have been tired too.

I had my module defined twice, once in vendor and once in app/code. Appears everything is working now that I resolved my issue 👍 Thanks for the help, that first PHP line helped me find the issue.