dev-master
9999999-dev https://github.com/kiler129/SupercacheBundleSupercache bundle for Symfony
MIT
The Requires
by Grzegorz Zdanowski
cache supercache static cache pages caching
Supercache bundle for Symfony
This project was born in a need for faster pages rendering years ago. Now, we have much better techniques (CDNs, HTTP/2, SPAs) to deal with the problem. The code should work with Symfony 2 & 3, but newer versions of Symfony would need an overhaul., (*1)
This project is left here to stay for legacy apps still using it, as well as a historical piece., (*2)
Static pages caching for Symfony Framework., (*3)
Some of you may be annoyed looking at simple pages loading times - exactly like me. There's a lot solution for that problem - this is extreme one.
If you ever used Wordpress you probably seen WP Super Cache
plugin. This bundle is build around similar principles (but it is not affiliated in any way) as that plugin., (*4)
Basically SupercacheBundle caches whole response to static files and serve them at no cost. It's very useful for pages where there're a lot of static routes visited often., (*5)
Before you start using this bundle you should carefully read HTTP Cache chapter of Symfony Cookbook - it provides a bunch of excellent techniques and tips about caching., (*6)
Bundle can be installed like any other Symfony bundle.
1. Open a command console, enter your project directory and execute following command:
composer require noflash/supercache-bundle
2. Enable the bundle by adding following line to app/AppKernel.php
file:
```php
<?php
// app/AppKernel.php, (*7)
// ... class AppKernel extends Kernel { public function registerBundles() { $bundles = array( // ..., (*8)
new noFlash\SupercacheBundle\SupercacheBundle(), ); // ... } // ...
}
```
3. ~~Execute following command and follow onscreen instructions app/console supercache:install
~~
Currently manual installation is required. You should create webcache
directory in root folder and than perform first two steps described in Troubleshooting section below., (*9)
TBD Default configuration:, (*10)
supercache: # Enable/disable cache while running prod environment enable_prod: true # Enable/disable cache while running dev environment enable_dev: false # Cache directory, must be http-accessible (so it cannot be located under app/) cache_dir: '%kernel.root_dir%/../webcache' # Enable/disable adding X-Supercache header cache_status_header: true
Looks like specified cache directory cannot be created. It can be permission related problem. You can try creating it yourself. To do that simply create desired cache directory (by default it's set to ./webcache/
). Next put following content in .htaccess
inside cache directory:, (*11)
RemoveHandler .php RemoveType .php Options -ExecCGI <IfModule mod_php5.c> php_flag engine off </IfModule> <IfModule mod_headers.c> Header set Cache-Control 'max-age=3600, must-revalidate' </IfModule> <IfModule mod_expires.c> ExpiresActive On ExpiresByType text/html A3600 </IfModule> <IfModule mod_mime.c> AddType application/javascript .js AddType text/html .html AddType application/octet-stream .bin </IfModule>
If you (or some other bundle) modified web/.htaccess
file, installer may be have trouble automatically applying required changes. You can add following lines manually - they should be placed just below RewriteRule ^app\.php(/(.*)|$) %{ENV:BASE}/$2 [R=301,L]
(or similar):, (*12)
### >>>SUPERCACHE BUNDLE RewriteCond %{REQUEST_METHOD} !^(GET|HEAD) [OR] RewriteCond %{QUERY_STRING} !^$ RewriteRule . - [S=3] RewriteCond %{DOCUMENT_ROOT}/../webcache/$1/index.html -f RewriteRule ^(.*) %{DOCUMENT_ROOT}/../webcache/$1/index.html [L] RewriteCond %{DOCUMENT_ROOT}/../webcache/$1/index.js -f RewriteRule ^(.*) %{DOCUMENT_ROOT}/../webcache/$1/index.js [L] RewriteCond %{DOCUMENT_ROOT}/../webcache/$1/index.bin -f RewriteRule ^(.*) %{DOCUMENT_ROOT}/../webcache/$1/index.bin [L] ### <<<SUPERCACHE BUNDLE
Please note cache path need to be adjusted. Path is relative to web/
directory., (*13)
You have two options: translate rewrite rules (specified above) to format supported by server you use or use PHP-PULL mode.
SupercacheBundle contains fallback mode for servers without .htaccess support (e.g. CLI server issued using app/console server:run
command). This mode works by attaching to Symfony HTTP kernel and trying locate cached response for given request. Of course it comes with a price - fallback will run PHP intepretter and initialize core of the framework. In my tests DIRECT mode returns response in 3-5ms while PHP-PULL mode need around 30ms., (*14)
There's no need to change any configuration options to enable PHP-PULL., (*15)
No, request & response must meet some criteria to be cached:
* GET
request method
* No query string
* Response code between 200 and 300 (excluding 204)
* No private
or no-store
cache control directives
* Route is not marked as excluded (see #3 for details), (*16)
Yes, there are few:
* It's impossible to serve different content on /sandbox
and /sandbox/
* You cannot have routes ..
and .
(they are illegal in HTTP RFC anyway)
* There are no automatic check for authentication token (it's your responsibility to set private
cache policy if you're presenting user-specific information)
* Due to performance reasons files are served from cache with one of the following MIME-Types: text/html, application/javascript or application/octet-stream. See issue #2 for details., (*17)
Supercache bundle for Symfony
MIT
cache supercache static cache pages caching