Beschrijving
Jinx Fast-Cache
Beschrijving
Jinx Fast-Cache provides a simple but highly efficient way to implement full-page caching. It generates static HTML files of your pages, which are then served directly by your web server (Apache or Nginx).
By bypassing the entire PHP process and database queries, your server load is significantly reduced and your website response time becomes near-instant. Unlike many other plugins, Jinx Fast-Cache is built with a developer-first approach, working primarily with URLs and offering deep integration via filters and actions.
Usage
Server Configuration
To serve the cached files directly, you must add rewrite rules to your server configuration.
For Apache (.htaccess):
The plugin will attempt to modify your .htaccess automatically. If it fails, add this manually:
# BEGIN Jinx Fast-Cache RewriteEngine On RewriteBase / RewriteCond %{DOCUMENT_ROOT}/wp-content/jinx-fast-cache/%{HTTP_HOST}/%{REQUEST_URI}/%{QUERY_STRING}/index.html -s RewriteCond %{REQUEST_METHOD} GET RewriteRule .* /wp-content/jinx-fast-cache/%{HTTP_HOST}/%{REQUEST_URI}/%{QUERY_STRING}/index.html [L] # END Jinx Fast-Cache For Nginx:
Add the following logic to your server block:
set $cache_path false; if ($request_method = GET) { set $cache_path /wp-content/jinx-fast-cache/$host/$uri/$args/index.html; } location / { try_files $cache_path $uri $uri/ /index.php?$query_string; } Cache Management
- Admin Bar: You can flush (clear), warm (generate), or refresh (flush & warm) single or multiple URLs directly from the admin bar.
- Automatic Updates: Posts are automatically “warmed” after saving and “flushed” when deleted or set to draft.
- Background Processing: The warming process uses a background queue handled via WordPress Cron to ensure server stability. Single post warming skips the queue for immediate results.
- Plugin Updates: The cache is automatically refreshed after the plugin is updated.
Developer API
Jinx Fast-Cache is highly extensible. While a settings panel is available, developers can fine-tune every detail via filters and actions.
1. Filters
- jinx_fast_cache_active: Toggle caching for specific conditions (default: false).
- jinx_fast_cache_post_types: Define which post types should be cached (default: ‘page’ and ‘publicly_queryable’ types).
- jinx_fast_cache_posts: Filter the specific list of post objects to be cached.
- jinx_fast_cache_taxonomies: Define which taxonomies are cacheable.
- jinx_fast_cache_terms: Filter the specific list of terms to be cached.
- jinx_fast_cache_output: Modify the raw HTML content before it is saved to the cache file.
- jinx_fast_cache_minify: Enable/disable HTML minification (default: false).
- jinx_fast_cache_flush: Define additional related URLs that should be cleared when a specific page is flushed.
- jinx_fast_cache_warm: Define additional related URLs that should be preloaded when a specific page is warmed.
- jinx_fast_cache_queue_interval: Adjust the cron task frequency for the warming queue (default: 60s).
- jinx_fast_cache_queue_size: Adjust the batch size per cron task (default: 10). Set to
<= 0to process everything at once (Caution: High server load). - jinx_fast_cache_gc_interval: Adjust the Garbage Collector frequency to remove invalid files (default: 60s).
- jinx_fast_cache_ignore_logged_in_users: Toggle caching for logged-in users (default: true).
- jinx_fast_cache_ignore_404: Toggle if 404 error pages should be cached (default: false).
- jinx_fast_cache_query_params: Define allowed query parameters. Return
__return_empty_arrayto ignore all parameters. - jinx_fast_cache_refresh_on_upgrade: Toggle the full cache refresh after plugin updates (default: true).
- jinx_fast_cache_ttl: Define the cache lifetime (TTL). Supports seconds (e.g., 3600) or strings (e.g., ’12 hours’, ‘1 week’).
2. Dynamic Injections (AJAX)
Since static HTML files cannot execute PHP, Jinx allows you to “inject” dynamic content (like a user’s name or a shopping cart) via AJAX.
Injecting a Template Part:
do_action('jinx_fast_cache_inject_template', 'template-slug', 'Placeholder text...'); Injecting via Function Call:
You can call any public function or class method:
do_action('jinx_fast_cache_inject', 'date', ['Y']); do_action('jinx_fast_cache_inject', ['MyClass', 'myMethod'], [$arg1, $arg2]); Using Shortcodes:
[jinx_fast_cache_inject placeholder="Loading..."] Your dynamic content here [/jinx_fast_cache_inject] JS Callbacks:
Trigger custom JavaScript after the content has been injected:
$('.element').on('jinx-fast-cache-inject', (e) => { /* Handle injection */ }); element.addEventListener('jinx-fast-cache-inject', (e) => { /* Handle injection */ }, false); 3. URL Tags & Relations
Tags are a powerful way to link multiple URLs together. If one URL is flushed, all other URLs sharing the same tag will also be purged. This is perfect for linking a “Latest Posts” widget on your homepage to your single post entries.
Via Shortcode:
[jinx_fast_cache tags="news,homepage"] Via Action:
do_action('jinx_fast_cache', ['tags' => 'tag1,tag2']); do_action('jinx_fast_cache', ['tags' => ['tag1', 'tag2']]); 4. Per-Page Cache Duration (TTL)
Override the global TTL for specific high-traffic or highly dynamic pages.
Via Shortcode:
[jinx_fast_cache ttl="3600"] or `[jinx_fast_cache ttl="12 hours"]` Via Action:
do_action('jinx_fast_cache', ['ttl' => 3600]); Combined Call (Tags + TTL):
do_action('jinx_fast_cache', ['ttl' => 3600, 'tags' => ['foo', 'bar']]);<h3>Roadmap</h3> – [x] Release the plugin
– [x] Add HTML minification for output
– [x] Allow injection of dynamic rendered templates using ajax requests
– [x] Add taxonomies
– [x] Provide scheduled tasks
– [x] Add admin columns for cache status
– [x] Provide exclude option for posts and terms in backend
– [x] Add multisite support
– [x] Flush and warm after update complete
– [x] Add possibility to ignore 404
– [x] Allow query params to be excluded or totally ignored
– [x] Provide cache duration
– [x] Provide admin panel to change options
– [x] Add tags to flush related pages
– [x] Add shortcode for injects
– [x] Add JS events for injects
– [x] Gutenberg inject block
Blokken
Deze plugin heeft 1 blok.
- ⚡ Jinx Fast-Cache Inject
Installatie
- Unzip the downloaded package.
- Upload the
jinx-fast-cachefolder to the/wp-content/plugins/directory. - Activate the plugin through the ‘Plugins’ menu in WordPress.
- Important: Configure your server rewrite rules (see “Usage”) to serve the static files.
Beoordelingen
Er zijn geen beoordelingen voor deze plugin.
Bijdragers & ontwikkelaars
“Jinx Fast-Cache” is open source software. De volgende personen hebben bijgedragen aan deze plugin.
BijdragersVertaal “Jinx Fast-Cache” in je eigen taal.
Interesse in ontwikkeling?
Bekijk de code, haal de SVN repository op, of abonneer je op het ontwikkellog via RSS.




