web/wp-content/plugins/wp-super-cache/readme.txt
changeset 194 32102edaa81b
parent 136 bde1974c263b
child 204 09a1c134465b
equal deleted inserted replaced
193:2f6f6f7551ca 194:32102edaa81b
     1 === WP Super Cache ===
     1 === WP Super Cache ===
     2 Contributors: donncha
     2 Contributors: donncha, automattic
     3 Tags: performance,caching,wp-cache,wp-super-cache,cache
     3 Tags: performance,caching,wp-cache,wp-super-cache,cache
     4 Tested up to: 2.8.6
     4 Tested up to: 3.4.2
     5 Stable tag: 0.9.8
     5 Stable tag: 1.2
     6 Requires at least: 2.6
     6 Requires at least: 3.0
     7 Donate link: http://ocaoimh.ie/gad/
       
     8 
     7 
     9 A very fast caching engine for WordPress that produces static html files.
     8 A very fast caching engine for WordPress that produces static html files.
    10 
     9 
    11 == Description ==
    10 == Description ==
    12 This plugin generates static html files from your dynamic WordPress blog.  After a html file is generated your webserver will serve that file instead of processing the comparatively heavier and more expensive WordPress PHP scripts.
    11 This plugin generates static html files from your dynamic WordPress blog.  After a html file is generated your webserver will serve that file instead of processing the comparatively heavier and more expensive WordPress PHP scripts.
    13 
    12 
    14 The static html files will be served to the vast majority of your users, but because a user's details are displayed in the comment form after they leave a comment those requests are handled by PHP. Static files are served to:
    13 The static html files will be served to the vast majority of your users, but because a user's details are displayed in the comment form after they leave a comment those requests are handled by the legacy caching engine. Static files are served to:
    15 
    14 
    16 1. Users who are not logged in.
    15 1. Users who are not logged in.
    17 2. Users who have not left a comment on your blog.
    16 2. Users who have not left a comment on your blog.
    18 3. Or users who have not viewed a password protected post.
    17 3. Or users who have not viewed a password protected post.
    19 
    18 
    20 99% of your visitors will be served static html files. Those users who don't see the static files will still benefit because they will see regular WP-Cache cached files and your server won't be as busy as before. This plugin will help your server cope with a front page appearance on digg.com or other social networking site.
    19 99% of your visitors will be served static html files. Those users who don't see the static files will still benefit because they will see different cached files that aren't quite as efficient but still better than uncached. This plugin will help your server cope with a front page appearance on digg.com or other social networking site.
    21 
    20 
    22 If for some reason "supercaching" doesn't work on your server then don't worry. Caching will still be performed, but every request will require loading the PHP engine. In normal circumstances this isn't bad at all. Visitors to your site will notice no slowdown or difference. Supercache really comes into it's own if your server is underpowered, or you're experiencing heavy traffic.
    21 If for some reason "supercaching" doesn't work on your server then don't worry. Caching will still be performed, but every request will require loading the PHP engine. In normal circumstances this isn't bad at all. Visitors to your site will notice no slowdown or difference. Supercache really comes into it's own if your server is underpowered, or you're experiencing heavy traffic.
    23 Super Cached html files will be served more quickly than PHP generated cached files but in every day use, the difference isn't noticeable.
    22 Super Cached html files will be served more quickly than PHP generated cached files but in every day use, the difference isn't noticeable.
    24 
    23 
    25 See the [WP Super Cache homepage](http://ocaoimh.ie/wp-super-cache/) for further information.
    24 The plugin serves cached files in 3 ways (ranked by speed):
       
    25 
       
    26 1. Mod_Rewrite. The fastest method is by using Apache mod_rewrite (or whatever similar module your web server supports) to serve "supercached" static html files. This completely bypasses PHP and is extremely quick. If your server is hit by a deluge of traffic it is more likely to cope as the requests are "lighter". This does require the Apache mod_rewrite module (which is probably installed if you have custom permalinks) and a modification of your .htaccess file. Visits by anonymous or unknown users will be served this way.
       
    27 2. PHP. Supercached static files can now be served by PHP. The plugin will serve a "supercached" file if it exists and it's almost as fast as the mod_rewrite method. It's easier to configure as the .htaccess file doesn't need to be changed. You still need a custom permalink. You can keep portions of your page dynamic in this caching mode. Your server may not cope as well with a really large amount of traffic. (You're gaming Digg aren't you? You'll need mod_rewrite, the rest of us are ok with PHP!)
       
    28 3. Legacy caching. This is mainly used to cache pages for known users. These are logged in users, visitors who leave comments or those who should be shown custom per-user data. It's the most flexible caching method but also the slowest. As each page is different it's often better not to cache pages for these users at all and avoid legacy caching. Legacy caching will also cache visits by unknown users if this caching mode is selected. You can have dynamic parts to your page in this mode too.
       
    29 
       
    30 If you're new to caching use PHP caching. It's easy to set up and very fast. Avoid legacy caching if you can.
       
    31 
       
    32 = Recommended Settings =
       
    33 Advanced users will probably want to use mod_rewrite caching, but PHP caching is almost as good and recommended for everyone else. Enable the following:
       
    34 
       
    35 1. PHP caching.
       
    36 2. Compress pages.
       
    37 3. Don't cache pages for known users.
       
    38 4. Cache rebuild.
       
    39 5. CDN support.
       
    40 6. Extra homepage checks.
       
    41 
       
    42 Garbage collection is the act of cleaning up cache files that are out of date and stale. There's no correct value for the expiry time but a good starting point is 1800 seconds if you're not using legacy mode. If you are using that mode start with an expiry time of 600 seconds.
       
    43 
       
    44 If you are not using legacy mode caching consider deleting the contents of the "Rejected User Agents" text box and allow search engines to create supercache static files.
       
    45 
       
    46 Likewise, preload as many posts as you can and enable "Preload Mode". Garbage collection will still occur but it won't affect the preloaded files. If you don't care about sidebar widgets updating often set the preload interval to 2880 minutes (2 days) so all your posts aren't recached very often. When the preload occurs the cache files for the post being refreshed is deleted and then regenerated. Afterwards a garbage collection of all old files is performed to clean out stale cache files.
       
    47 With preloading on cached files will still be deleted when posts are made or edited or comments made.
       
    48 
       
    49 See the [WP Super Cache homepage](http://ocaoimh.ie/wp-super-cache/) for further information. [Developer documentation](http://ocaoimh.ie/wp-super-cache-developers/) is also available for those who need to interact with the cache or write plugins.
    26 
    50 
    27 The [changelog](http://svn.wp-plugins.org/wp-super-cache/trunk/Changelog.txt) is a good place to start if you want to know what has changed since you last downloaded the plugin.
    51 The [changelog](http://svn.wp-plugins.org/wp-super-cache/trunk/Changelog.txt) is a good place to start if you want to know what has changed since you last downloaded the plugin.
    28 
    52 
       
    53 Interested in translating WP Super Cache to your language? Grab the [development version](http://downloads.wordpress.org/plugin/wp-super-cache.zip) where you will find an up to date wp-super-cache.pot. Send any translation files to donncha @ ocaoimh.ie and thank you!
       
    54 
       
    55 The cache directory, usually wp-content/cache/ is only for temporary files. Do not ever put important files or symlinks to important files or directories in that directory. They will be deleted if the plugin has write access to them.
       
    56 
       
    57 == Upgrade Notice ==
       
    58 
       
    59 = 1.2 =
       
    60 Lots of bugfixes, garbage collection improved, more details at http://ocaoimh.ie/y/3i
       
    61 
    29 == Changelog ==
    62 == Changelog ==
       
    63 
       
    64 = 1.2 =
       
    65 * Garbage collection of old cache files is significantly improved. I added a scheduled job that keeps an eye on things and restarts the job if necessary. Also, if you enable caching from the Easy page garbage collection will be enabled too.
       
    66 * Editors can delete single cached files from the admin bar now.
       
    67 * Fixed the cached page counter on the settings page.
       
    68 * Some sites that updated to 1.0 experienced too much garbage collection. There are still stragglers out there who haven.t upgraded but that.s fixed now!
       
    69 * Supercached mobile files are now used as there was a tiny little typo that needed fixing.
       
    70 * If your site is in a directory and you saw problems updating a page then that should be fixed now.
       
    71 * The deactivate hook has been changed so your configuration isn.t hosed when you upgrade. Unfortunately this will only happen after you do this upgrade.
       
    72 * Some sites use custom cookies with the LOGGED_IN_COOKIE constant. Added support for that.
       
    73 * Added support for WPTouch Pro, but it appears to be flaky still. Anyone have time to work on that? I don.t.
       
    74 * Some sites had problems with scheduled posts. For some reason the plugin thought the post was in draft mode and then because it only checked the same post once, when the post magically became published the cache wasn.t cleared. That.s fixed, thanks to the debug logging of several patient users.
       
    75 * And more bug fixes and translation updates.
       
    76 
       
    77 = 1.1 =
       
    78 * Use $_SERVER[ 'SERVER_NAME' ] to create cache directories.
       
    79 * Only create blogs cached directories if valid requests and blogs exist.
       
    80 * Only clear current blog's cache files if navigation menu is modified
       
    81 * Added clean_post_cache action to clear cache on post actions
       
    82 * Removed garbage collection details on Contents tab
       
    83 * Added wp_cache_check_mobile cacheaction filter to shortcircuit mobile device check.
       
    84 * Don't delete cache files for draft posts
       
    85 * Added action on wp_trash_post to clear the cache when trashed posts are deleted
       
    86 * Show a warning when 304 browser caching is disabled (because mod_rewrite caching is on)
       
    87 * New check for safe mode if using less that PHP 5.3.0
       
    88 * Added wp_supercache_remove_cookies filter to disable anonymous browsing mode.
       
    89 * Fixed garbage collection schedule dropdown
       
    90 * Fixed preload problem clearing site's cache on "page on front" sites.
       
    91 * Fix for PHP variable not defined warnings
       
    92 * Fixed problem refreshing cache when comments made as siteurl() sometimes didn't work
       
    93 * Preloading of taxonomies is now optional
       
    94 * Domain mapping fixes.
       
    95 * Better support for https sites. Remove https:// to get cache paths.
       
    96 * Added AddDefaultCharset .htaccess rule back in and added an option to remove it if required.
       
    97 * Added multisite plugin that adds a "Cached" column to Network->Sites to disable caching on a per site basis.
       
    98 * Added WPTouch plugin to modify browser and prefix list in mobile detection code. Added support for that plugin's exclude list.
       
    99 * Fixed cache tester
       
   100 * Filter the tags that are used to detect end-of-page using the wp_cache_eof_tags filter.
       
   101 * Removed debug level from logging as it wasn't helpful.
       
   102 * Removed mention of wp-minify.
       
   103 
       
   104 = 1.0 =
       
   105 * Removed AddDefaultCharset .htaccess rule
       
   106 * Fixed problem with blogs in a folder and don't have a trailing slash
       
   107 * New scheduling of garbage collection
       
   108 * Added a "Delete cache" link to admin bar to delete cache of current page.
       
   109 * Updated documentation
       
   110 * Sorry Digg, Stephen Fry power now!
       
   111 * Updated translations
       
   112 * Preload taxonomies and all post types except revisionsand nav menu items
       
   113 * Fixed previews by logged in users.
       
   114 * Added option to make logged in users anonymous
       
   115 * Use WP 3.0 variables to detect multisite installs
       
   116 * Hash filenames so files are served from the same CDNs
       
   117 
       
   118 = 0.9.9.9 =
       
   119 * Fixed typo, is_front_page.
       
   120 * Serve repeated static files from the same CDN hostname.
       
   121 * Updated translations.
       
   122 * Make supercache dir lowercase to avoid problems with unicode URLs.
       
   123 * Add option to skip https loaded static content. 
       
   124 * Remove 5 second check on age of existing cache files. Should help with posts that get lots of comments and traffic.
       
   125 * Lots of bugs fixed.
       
   126 
       
   127 = 0.9.9.8 =
       
   128 * CDN updates: can be switched off, multiple CNAMEs.
       
   129 * Uninstall process improved. It removes generated files and fixes edited files.
       
   130 * Cached dynamic pages can now be stored in Supercache files and compressed.
       
   131 * 1and1 Webhosting fix (/kunden/)
       
   132 * Remove log by email functionality as it caused problems for users who were inundated by email
       
   133 * Many more minor fixes and changes.
       
   134 
       
   135 = 0.9.9.6 =
       
   136 * Fixed problem serving cached files with PHP
       
   137 * Added support for 304 "file not modified" header to help browser caching. (PHP caching only)
       
   138 * Added French & German translations, updated Italian translation and fixed translation strings.
       
   139 * Sleep 4 seconds between preload urls to reduce load on the server
       
   140 * Updated docs and FAQs.
       
   141 
       
   142 = 0.9.9.5 =
       
   143 * Disable compression on on easy setup page. Still causes problems on some hosts.
       
   144 * Remove footerlink on easy setup page.
       
   145 * Don't delete mod_rewrite rules when caching is disabled.
       
   146 * Don't stop users using settings page when in safe mode.
       
   147 
       
   148 = 0.9.9.4 =
       
   149 * Settings page split into tabbed pages.
       
   150 * Added new "Easy" settings page for new users.
       
   151 * New PHP caching mode to serve supercached files.
       
   152 * Mobile support fixes.
       
   153 * Added Domain mapping support plugin.
       
   154 * Added "awaiting moderation" plugin that removes that text from posts.
       
   155 * Terminology change. Changed "half on" to "legacy caching".
       
   156 * Fixed cache tester on some installs of WordPress.
       
   157 * Updated documentation
       
   158 * Added $wp_super_cache_lock_down config variable to hide lockdown and directly cached pages admin items.
       
   159 * Preloaded checks if it has stalled and reschedules the job to continue.
       
   160 * Serve the gzipped page when first cached if the client supports compression.
       
   161 * Lots more bug fixes..
       
   162 
       
   163 = 0.9.9.3 =
       
   164 * Fixed division by zero error in half on mode.
       
   165 * Always show "delete cache" button.
       
   166 * Fixed "Update mod_rewrite rules" button.
       
   167 * Minor text changes to admin page.
       
   168 
       
   169 = 0.9.9.2 =
       
   170 * Forgot to change version number in wp-cache.php
       
   171 
       
   172 = 0.9.9.1 =
       
   173 * Added preloading of static cache.
       
   174 * Better mobile plugin support
       
   175 * .htaccess rules can be updated now. Added wpsc_update_htaccess().
       
   176 * Fixed "page on front" cache clearing bug.
       
   177 * Check for wordpress_logged_in cookie so test cookie isn't detected.
       
   178 * Added clear_post_supercache() to clear supercache for a single post.
       
   179 * Put quotes around rewrite rules in case paths have spaces.
       
   180 
       
   181 = 0.9.9 =
       
   182 * Added experimental object cache support.
       
   183 * Added Chinese(Traditional) translation by Pseric.
       
   184 * Added FAQ on WP-Cache vs Supercache files.
       
   185 * Use Supercache file if WP-Cache file not found. Useful if mod_rewrite rules are broken or not working.
       
   186 * Get mobile browser list from WP Mobile Edition if found. Warn user if .htaccess out of date.
       
   187 * Make sure writer lock is unlocked after writing cache files.
       
   188 * Added link to developer docs in readme.
       
   189 * Added Ukranian translation by Vitaly Mylo.
       
   190 * Added Upgrade Notice section to readme.
       
   191 * Warn if zlib compression in PHP is enabled.
       
   192 * Added compression troubleshooting answer. Props Vladimir (http://blog.sjinks.pro/)
       
   193 * Added Japanese translation by Tai (http://tekapo.com/)
       
   194 * Updated Italian translation.
       
   195 * Link to WP Mobile Edition from admin page for mobile support.
    30 
   196 
    31 = 0.9.8 =
   197 = 0.9.8 =
    32 * Added Spanish translation by Omi.
   198 * Added Spanish translation by Omi.
    33 * Added Italian translation by Gianni Diurno.
   199 * Added Italian translation by Gianni Diurno.
    34 * Addded advanced debug code to check front page for category problem. Enable by setting $wp_super_cache_advanced_debug to 1 in the config file.
   200 * Addded advanced debug code to check front page for category problem. Enable by setting $wp_super_cache_advanced_debug to 1 in the config file.
    55 * Use the wordpress_test_cookie in the cache key.
   221 * Use the wordpress_test_cookie in the cache key.
    56 * Show correct number of cache files when compression off.
   222 * Show correct number of cache files when compression off.
    57 * Fixed problem with PHP safe_mode detection.
   223 * Fixed problem with PHP safe_mode detection.
    58 * Various bugfixes and documentation updates. See Changelog.txt
   224 * Various bugfixes and documentation updates. See Changelog.txt
    59 
   225 
    60 
       
    61 = 0.9.6.1 =
   226 = 0.9.6.1 =
    62 * Move "not logged in" message init below check for POST.
   227 * Move "not logged in" message init below check for POST.
    63 * Add is_admin() check so plugin definitely can't cache the backend.
   228 * Add is_admin() check so plugin definitely can't cache the backend.
    64 * Add "do not cache" page type to admin page.
   229 * Add "do not cache" page type to admin page.
    65 
   230 
    86 4. Don't cache post previews.
   251 4. Don't cache post previews.
    87 5. Added backslashes to rejected URI regex list.
   252 5. Added backslashes to rejected URI regex list.
    88 6. Fixed problems with posts and comments not refreshing.
   253 6. Fixed problems with posts and comments not refreshing.
    89 
   254 
    90 == Installation ==
   255 == Installation ==
    91 1. You should have the Apache mod mime and mod rewrite modules installed and WordPress fancy permalinks enabled. PHP safe mode should be disabled. If any of those are missing or off you can still use the slower WP-Cache part of the plugin.
   256 1. You should have the Apache mod mime and mod rewrite modules installed and WordPress custom permalinks (Settings->Permalinks) enabled. PHP safe mode should be disabled. If any of those are missing or off you can still use PHP or legacy caching.
    92 2. If you have WP-Cache installed already, please disable it. Edit wp-config.php and make sure the WP_CACHE define is deleted, and remove the files wp-content/wp-cache-config.php and wp-content/advanced-cache.php. These will be recreated when you install this plugin.
   257 2. If you have WP-Cache installed already, please disable it. Edit wp-config.php and make sure the WP_CACHE and WPCACHEHOME defines are deleted, and remove the files wp-content/wp-cache-config.php and wp-content/advanced-cache.php. These will be recreated when you install this plugin.
    93 3. Upload this directory to your plugins directory. It will create a 'wp-content/plugins/wp-super-cache/' directory.
   258 3. Upload this directory to your plugins directory. It will create a 'wp-content/plugins/wp-super-cache/' directory.
    94 4. If you are using WordPress MU you will need to install this in 'wp-content/mu-plugins/wp-super-cache/' and the file wp-cache.php must be copied into the mu-plugins directory.
   259 4. If you are using WordPress MU or WordPress Multisite you can install the plugin in the ordinary plugins folder and activate it "network wide".
    95 5. WordPress users should go to their Plugins page and activate "WP Super Cache".
   260 5. WordPress users should go to their Plugins page and activate "WP Super Cache".
    96 6. Now go to Settings->WP Super Cache and enable caching. If you see an error message or a blank screen you may need to fix it. See the "FAQ" section later in this readme for instructions.
   261 6. Now go to Settings->WP Super Cache and enable caching. If you see an error message or a blank screen see the "FAQ" section later in this readme for instructions.
    97 7. mod_rewrite rules will be inserted into your .htaccess file. Look in your web root directory for this file. It should look similar to this:
   262 7. If you choose "Mod Rewrite caching", mod_rewrite rules will be inserted into your .htaccess file. Look in your web root directory for this file. It should look similar to this:
    98 
   263 
    99 	`-----------------.htaccess-----------------`
   264 	`-----------------.htaccess-----------------`
   100 	`RewriteEngine On`
   265 	`RewriteEngine On`
   101 	`RewriteBase /`
   266 	`RewriteBase /`
   102 	
   267 	
   103 	`RewriteCond %{REQUEST_METHOD} !=POST`
   268 	`RewriteCond %{REQUEST_METHOD} !=POST`
   104 	`RewriteCond %{QUERY_STRING} !.*=.*`
   269 	`RewriteCond %{QUERY_STRING} !.*=.*`
   105 	`RewriteCond %{HTTP_COOKIE} !^.*(comment_author_|wordpress|wp-postpass_).*$`
   270 	`RewriteCond %{HTTP_COOKIE} !^.*(comment_author_|wordpress|wp-postpass_).*$`
   106 	`RewriteCond %{HTTP:Accept-Encoding} gzip`
   271 	`RewriteCond %{HTTP:Accept-Encoding} gzip`
   107 	`RewriteCond %{HTTP_user_agent} !^.*(2.0\ MMP|240x320|AvantGo|BlackBerry|Blazer|Cellphone|Danger|DoCoMo|Elaine/3.0|EudoraWeb|hiptop|IEMobile|iPhone|iPod|KYOCERA/WX310K|LG/U990|MIDP-2.0|MMEF20|MOT-V|NetFront|Newt|Nintendo\ Wii|Nitro|Nokia|Opera\ Mini|Palm|Playstation\ Portable|portalmmm|Proxinet|ProxiNet|SHARP-TQ-GX10|Small|SonyEricsson|Symbian\ OS|SymbianOS|TS21i-10|UP.Browser|UP.Link|Windows\ CE|WinWAP).*`
   272 	`RewriteCond %{HTTP_USER_AGENT} !^.*(2.0\ MMP|240x320|400X240|AvantGo|BlackBerry|Blazer|Cellphone|Danger|DoCoMo|Elaine/3.0|EudoraWeb|Googlebot-Mobile|hiptop|IEMobile|KYOCERA/WX310K|LG/U990|MIDP-2.|MMEF20|MOT-V|NetFront|Newt|Nintendo\ Wii|Nitro|Nokia|Opera\ Mini|Palm|PlayStation\ Portable|portalmmm|Proxinet|ProxiNet|SHARP-TQ-GX10|SHG-i900|Small|SonyEricsson|Symbian\ OS|SymbianOS|TS21i-10|UP.Browser|UP.Link|webOS|Windows\ CE|WinWAP|YahooSeeker/M1A1-R2D2|iPhone|iPod|Android|BlackBerry9530|LG-TU915\ Obigo|LGE\ VX|webOS|Nokia5800).*`
   108 	`RewriteCond %{DOCUMENT_ROOT}/wp-content/cache/supercache/%{HTTP_HOST}/$1/index.html.gz -f`
   273 	`RewriteCond %{DOCUMENT_ROOT}/wp-content/cache/supercache/%{HTTP_HOST}/$1/index.html.gz -f`
   109 	`RewriteRule ^(.*) /wp-content/cache/supercache/%{HTTP_HOST}/$1/index.html.gz [L]`
   274 	`RewriteRule ^(.*) /wp-content/cache/supercache/%{HTTP_HOST}/$1/index.html.gz [L]`
   110 	
   275 	
   111 	`RewriteCond %{REQUEST_METHOD} !=POST`
   276 	`RewriteCond %{REQUEST_METHOD} !=POST`
   112 	`RewriteCond %{QUERY_STRING} !.*=.*`
   277 	`RewriteCond %{QUERY_STRING} !.*=.*`
   113 	`RewriteCond %{QUERY_STRING} !.*attachment_id=.*`
   278 	`RewriteCond %{QUERY_STRING} !.*attachment_id=.*`
   114 	`RewriteCond %{HTTP_COOKIE} !^.*(comment_author_|wordpress|wp-postpass_).*$`
   279 	`RewriteCond %{HTTP_COOKIE} !^.*(comment_author_|wordpress|wp-postpass_).*$`
   115 	`RewriteCond %{HTTP_user_agent} !^.*(2.0\ MMP|240x320|AvantGo|BlackBerry|Blazer|Cellphone|Danger|DoCoMo|Elaine/3.0|EudoraWeb|hiptop|IEMobile|iPhone|iPod|KYOCERA/WX310K|LG/U990|MIDP-2.0|MMEF20|MOT-V|NetFront|Newt|Nintendo\ Wii|Nitro|Nokia|Opera\ Mini|Palm|Playstation\ Portable|portalmmm|Proxinet|ProxiNet|SHARP-TQ-GX10|Small|SonyEricsson|Symbian\ OS|SymbianOS|TS21i-10|UP.Browser|UP.Link|Windows\ CE|WinWAP).*`
   280 	`RewriteCond %{HTTP_USER_AGENT} !^.*(2.0\ MMP|240x320|400X240|AvantGo|BlackBerry|Blazer|Cellphone|Danger|DoCoMo|Elaine/3.0|EudoraWeb|Googlebot-Mobile|hiptop|IEMobile|KYOCERA/WX310K|LG/U990|MIDP-2.|MMEF20|MOT-V|NetFront|Newt|Nintendo\ Wii|Nitro|Nokia|Opera\ Mini|Palm|PlayStation\ Portable|portalmmm|Proxinet|ProxiNet|SHARP-TQ-GX10|SHG-i900|Small|SonyEricsson|Symbian\ OS|SymbianOS|TS21i-10|UP.Browser|UP.Link|webOS|Windows\ CE|WinWAP|YahooSeeker/M1A1-R2D2|iPhone|iPod|Android|BlackBerry9530|LG-TU915\ Obigo|LGE\ VX|webOS|Nokia5800).*`
   116 	`RewriteCond %{DOCUMENT_ROOT}/wp-content/cache/supercache/%{HTTP_HOST}/$1/index.html -f`
   281 	`RewriteCond %{DOCUMENT_ROOT}/wp-content/cache/supercache/%{HTTP_HOST}/$1/index.html -f`
   117 	`RewriteRule ^(.*) /wp-content/cache/supercache/%{HTTP_HOST}/$1/index.html [L]`
   282 	`RewriteRule ^(.*) /wp-content/cache/supercache/%{HTTP_HOST}/$1/index.html [L]`
   118 	
   283 	
   119 	`RewriteCond %{REQUEST_FILENAME} !-f`
   284 	`RewriteCond %{REQUEST_FILENAME} !-f`
   120 	`RewriteCond %{REQUEST_FILENAME} !-d`
   285 	`RewriteCond %{REQUEST_FILENAME} !-d`
   133 	`</IfModule>`
   298 	`</IfModule>`
   134 	`<IfModule mod_deflate.c>`
   299 	`<IfModule mod_deflate.c>`
   135 	`  SetEnvIfNoCase Request_URI \.gz$ no-gzip`
   300 	`  SetEnvIfNoCase Request_URI \.gz$ no-gzip`
   136 	`</IfModule>`
   301 	`</IfModule>`
   137 	`<IfModule mod_headers.c>`
   302 	`<IfModule mod_headers.c>`
   138 	`  Header set Cache-Control 'max-age=300, must-revalidate'`
   303 	`  Header set Cache-Control 'max-age=3, must-revalidate'`
   139 	`</IfModule>`
   304 	`</IfModule>`
   140 	`<IfModule mod_expires.c>`
   305 	`<IfModule mod_expires.c>`
   141 	`  ExpiresActive On`
   306 	`  ExpiresActive On`
   142 	`  ExpiresByType text/html A300`
   307 	`  ExpiresByType text/html A3`
   143 	`</IfModule>`
   308 	`</IfModule>`
   144 	``
   309 	``
   145 	`# END supercache`
   310 	`# END supercache`
   146 9. Apache must be configured to allow the modules above. If you receive a "500 internal error" when serving requests to anonymous users you need to dig into your Apache configuration. This configuration in my virtual host works for me:
   311 9. Apache must be configured to allow the modules above. If you receive a "500 internal error" when serving requests to anonymous users you need to dig into your Apache configuration. This configuration in my virtual host works for me:
   147 
   312 
   148 	`<Directory /home/www/>`
   313 	`<Directory /home/www/>`
   149 	`AllowOverride All`
   314 	`AllowOverride All`
   150 	`</Directory>`
   315 	`</Directory>`
   151 10. wp-content/advanced-cache.php loads the caching engine. This file is generated by the plugin. Make sure the path in the include_once() is correct.
   316 10. wp-content/advanced-cache.php loads the caching engine. This file is generated by the plugin. It uses the constant WPCACHEHOME to load the caching engine.
   152 
   317 
   153 == How to uninstall WP Super Cache ==
   318 == How to uninstall WP Super Cache ==
   154 
   319 
   155 Edit the file uninstall.php in your plugins/wp-super-cache/ directory and set
   320 Almost all you have to do is deactivate the plugin on the plugins page. The plugin should clean up most of the files it created and modified, but it doesn't as yet remove the mod_rewrite rules from the .htaccess file. Look for the section in that file marked by SuperCache BEGIN and END tags. The plugin doesn't remove those because some people add the WordPress rules in that block too.
   156 UNINSTALL_WPSUPERCACHE to a non blank value.
       
   157 
       
   158 	`define( 'UNINSTALL_WPSUPERCACHE', '1' );`
       
   159 
       
   160 Open your browser and load wp-content/plugins/wp-super-cache/uninstall.php directly.
       
   161 You must be logged in, and you must confirm the action. If you do not delete the plugin
       
   162 immediately, after the script runs, please comment out the define() above to stop 
       
   163 someone else running it.
       
   164 
   321 
   165 To manually uninstall:
   322 To manually uninstall:
   166 
   323 
   167 1. Remove the WP_CACHE define from wp-config.php. It looks like `define( 'WP_CACHE', true );`
   324 1. Turn off caching on the plugin settings page and clear the cache.
   168 2. Clear the cache in the backend page and then deactivate the plugin on the plugins page.
   325 2. Deactivate the plugin on the plugins page.
   169 3. Remove the Super Cache mod_rewrite rules from your .htaccess file.
   326 3. Remove the WP_CACHE define from wp-config.php. It looks like `define( 'WP_CACHE', true );`
   170 4. Remove the files wp-content/advanced-cache.php and wp-content/wp-cache-config.php
   327 4. Remove the Super Cache mod_rewrite rules from your .htaccess file.
   171 5. Remove the directory wp-content/cache/
   328 5. Remove the files wp-content/advanced-cache.php and wp-content/wp-cache-config.php
   172 6. Remove the directory wp-super-cache from your plugins directory.
   329 6. Remove the directory wp-content/cache/
       
   330 7. Remove the directory wp-super-cache from your plugins directory.
   173 
   331 
   174 == If all else fails and your site is broken ==
   332 == If all else fails and your site is broken ==
   175 1. Remove the WP_CACHE define from wp-config.php. It looks like `define( 'WP_CACHE', true );`
   333 1. Remove the WP_CACHE define from wp-config.php. It looks like `define( 'WP_CACHE', true );`
   176 2. Remove the rules (see above) that the plugin wrote to the .htaccess file in your root directory.
   334 2. Remove the rules (see above) that the plugin wrote to the .htaccess file in your root directory.
   177 3. Delete the wp-super-cache folder in the plugins folder.
   335 3. Delete the wp-super-cache folder in the plugins folder.
   179 
   337 
   180 == Frequently Asked Questions ==
   338 == Frequently Asked Questions ==
   181 
   339 
   182 = How do I know my blog is being cached? =
   340 = How do I know my blog is being cached? =
   183 
   341 
   184 View the source of any page on your site. When a page is first created, you'll see the text "Dynamic page generated in XXXX seconds." and "Cached page generated by WP-Super-Cache on YYYY-MM-DD HH:MM:SS" at the end of the source code. On reload, a cached page will show the same timestamp so wait a few seconds before checking. 
   342 Enable debugging in the plugin settings page and load the log file in a new browser tab. Then view your blog while logged in and logged out. You should see activity in the log. View the source of any page on your site. When a page is first created, you'll see the text "Dynamic page generated in XXXX seconds." and "Cached page generated by WP-Super-Cache on YYYY-MM-DD HH:MM:SS" at the end of the source code. On reload, a cached page will show the same timestamp so wait a few seconds before checking. 
   185 In "HALF-ON" mode, if you have compression enabled, the text "Compression = gzip" will be added. If compression is disabled and the page is served as a static html file, the text "super cache" will be added. The only other way to check if your cached file was served by PHP script or from the static cache is by looking at the HTTP headers. WP-Cache (PHP) cached pages will have the header "WP-Super-Cache: WP-Cache". I used the <a href="https://addons.mozilla.org/en-US/firefox/addon/3829">Live HTTP Headers</a> extension for Firefox to examine the headers. You should also check your cache directory in wp-content/cache/supercache/hostname/ for static cache files.
   343 In legacy caching mode, if you have compression enabled, the text "Compression = gzip" will be added. If compression is disabled and the page is served as a static html file, the text "super cache" will be added. The only other way to check if your cached file was served by PHP script or from the static cache is by looking at the HTTP headers. PHP cached pages will have the header "WP-Super-Cache: Served supercache file from PHP". Legacy cached files will have the header, "WP-Super-Cache: Served legacy cache file". I used the <a href="https://addons.mozilla.org/en-US/firefox/addon/3829">Live HTTP Headers</a> extension for Firefox to examine the headers. You should also check your cache directory in wp-content/cache/supercache/hostname/ for static cache files.
       
   344 If the plugin rules are missing from your .htaccess file, the plugin will attempt to serve the super cached page if it's found. The header "WP-Super-Cache: Served supercache file from PHP" if this happens.
       
   345 
       
   346 = Legacy (WP-Cache) vs Supercache files =
       
   347 
       
   348 WP-Cache files are stored in wp-content/cache/ (or on MU sites in a blogs sub directory) and are named wp-cache-XXXXXXXXXXXXXXXXX.html. Associated meta files are stored in a meta sub directory. Those files contain information about the cached file. These files are generated by the "legacy caching" code in the plugin.
       
   349 Supercache files are stored in wp-content/cache/supercache/HOSTNAME/ where HOSTNAME is your domain name. The files are stored in directories matching your site's permalink structure.
   186 
   350 
   187 = Why is WP-Super-Cache better than WP-Cache? =
   351 = Why is WP-Super-Cache better than WP-Cache? =
   188 
   352 
   189 This plugin is based on the excellent WP-Cache plugin and therefore brings all the benefits of that plugin to WordPress. On top of that it creates copies of every page that is accessed on a blog in a form that is quickly served by the web server. It's almost as quick as if the you had saved a page in your browser and uploaded it to replace your homepage.
   353 This plugin is based on the excellent WP-Cache plugin. Besides the caching WP-Cache did this plugin creates copies of every page that is accessed on a blog in a form that is quickly served by the web server. It's almost as quick as if the you had saved a html page in your browser and uploaded it to replace your homepage.
   190 
   354 
   191 = Will comments and other dynamic parts of my blog update immediately? =
   355 = Will comments and other dynamic parts of my blog update immediately? =
   192 
   356 
   193 Comments will show as soon as they are moderated, depending on the comment policy of the blog owner. Other dynamic elements on a page may not update unless they are written in Javascript, Flash, Java or another client side browser language. The plugin really produces static html pages. No PHP is executed when those pages are served. "Popularity Contest" is one such plugin that will not work. Plugins that show different content for mobile users will probaby not work either.
   357 Comments will show as soon as they are moderated, depending on the comment policy of the blog owner. Other dynamic elements on a page may not update unless they are written in Javascript, Flash, Java or another client side browser language. The plugin really produces static html pages. No PHP is executed when those pages are served. "Popularity Contest" is one such plugin that will not work. 
   194 
   358 
   195 = Will the Super Cache compression slow down my server? =
   359 = Will the Super Cache compression slow down my server? =
   196 
   360 
   197 No, it will do the opposite in fact. Super Cache files are compressed and stored that way so the heavy compression is done only once. These files are generally much smaller and are sent to a visitor's browser much more quickly than uncompressed html. As a result, your server spends less time talking over the network which saves CPU time and bandwidth, and can also serve the next request much more quickly.
   361 No, it will do the opposite. Super Cache files are compressed and stored that way so the heavy compression is done only once. These files are generally much smaller and are sent to a visitor's browser much more quickly than uncompressed html. As a result, your server spends less time talking over the network which saves CPU time and bandwidth, and can also serve the next request much more quickly.
   198 
   362 
   199 = How do I make certain parts of the page stay dynamic? =
   363 = How do I make certain parts of the page stay dynamic? =
   200 
   364 
   201 WP Super Cache retains the dynamic loading code of WP Cache but only works in "half on" mode.
   365 There are 2 ways of doing this. You can use Javascript to draw the part of the page you want to keep dynamic. That's what Google Adsense and many widgets from external sites do. Or you can use a WP Super Cache tag to do the job but you can't use mod_rewrite mode caching. You have to switch to PHP or legacy caching.
   202 
   366 
   203 There are two ways to do this, you can have functions that stay dynamic or you can include other files on every page load. To have a dynamic function in the cached PHP page use this syntax around the function:
   367 There are a few ways to do this, you can have functions that stay dynamic or you can include other files on every page load. To execute PHP code on every page load you can use either the "dynamic-cached-content", "mfunc", or "mclude" tags. The "dynamic-cached-content" tag is easier to use but the other tags can still be used. Make sure you duplicate the PHP code when using these tags. The first code is executed when the page is cached, while the second chunk of code is executed when the cached page is served to the next visitor.
       
   368 To execute WordPress functions you must enable the 'Late init' feature on the advanced settings page.
       
   369 
       
   370 = dynamic-cached-content example =
       
   371 
       
   372 This code will include the file adverts.php and will execute the functions "print_sidebar_ad()" and "do_more_stuff()". Make sure there's no space before or after the PHP tags.
       
   373 
       
   374 `<!--dynamic-cached-content--><?php
       
   375 include_once( ABSPATH . '/scripts/adverts.php' );
       
   376 print_sidebar_ad();
       
   377 do_more_stuff();
       
   378 ?><!--
       
   379 include_once( ABSPATH . '/scripts/adverts.php' );
       
   380 print_sidebar_ad();
       
   381 do_more_stuff();
       
   382 --><!--/dynamic-cached-content-->`
       
   383 
       
   384 = mfunc example =
       
   385 
       
   386 To execute the function "function_name()":
   204 
   387 
   205 `<!--mfunc function_name( 'parameter', 'another_parameter' ) -->
   388 `<!--mfunc function_name( 'parameter', 'another_parameter' ) -->
   206 <?php function_name( 'parameter', 'another_parameter' ) ?>
   389 <?php function_name( 'parameter', 'another_parameter' ) ?>
   207 <!--/mfunc-->`
   390 <!--/mfunc-->`
   208 
   391 
   209 The HTML comments around the mirrored PHP allow it to be executed in the static page. To include another file try this:
   392 = mclude example =
       
   393 To include another file:
   210 
   394 
   211 `<!--mclude file.php-->
   395 `<!--mclude file.php-->
   212 <?php include_once( ABSPATH . 'file.php' ); ?>
   396 <?php include_once( ABSPATH . 'file.php' ); ?>
   213 <!--/mclude-->`
   397 <!--/mclude-->`
   214 
   398 
   215 That will include file.php under the ABSPATH directory, which is the same as where your wp-config.php file is located.
   399 That will include file.php under the ABSPATH directory, which is the same as where your wp-config.php file is located.
   216 
   400 
   217 = Why doesn't WP UserOnline, Popularity Contest, WP Postratings or plugin X not work or update on my blog now? =
   401 Example:
   218 
   402 `<!--mfunc date( 'Y-m-d H:i:s' ) -->
   219 This plugin caches entire pages but some plugins think they can run PHP code every time a page loads. To fix this, the plugin needs to use Javascript/AJAX methods or the mfunc/mclude code described in the previous answer to update or display dynamic information.
   403 <?php date( 'Y-m-d H:i:s' ) ?>
       
   404 <!--/mfunc-->`
       
   405 
       
   406 = How do I use WordPress functions in cached dynamic pages? =
       
   407 
       
   408 See the next qestion, you have to load WordPress before the cached file is served.
       
   409 
       
   410 = How do I delay serving the cache until the "init" action fires? =
       
   411 
       
   412 Cached files are served before almost all of WordPress is loaded. While that's great for performance it's a pain when you want to extend the plugin using a core part of WordPress. Set $wp_super_cache_late_init to "1" in wp-content/wp-cache-config.php and cached files will be served when "init" fires. WordPress and it's plugins will be loaded now. This is very useful when you are using the mfunc tag in your theme.
       
   413 
       
   414 = Why don't WP UserOnline, Popularity Contest, WP Postratings or plugin X not work or update on my blog now? =
       
   415 
       
   416 This plugin caches entire pages but some plugins think they can run PHP code every time a page loads. To fix this, the plugin needs to use Javascript/AJAX methods or the dynamic-cached-content/mfunc/mclude code described in the previous answer to update or display dynamic information.
       
   417 
       
   418 = What does the Cache Rebuild feature do? =
       
   419 
       
   420 When a visitor leaves a comment the cached file for that page is deleted and the next visitor recreates the cached page. A page takes time to load so what happens if it receives 100 visitors during this time? There won't be a cached page so WordPress will serve a fresh page for each user and the plugin will try to create a cached page for each of those 100 visitors causing a huge load on your server. This feature stops this happening. The cached page is not cleared when a comment is left. It is marked for rebuilding instead. The next visitor will regenerate the cached page while the old page is served to the other 99 visitors. The page is eventually loaded by the first visitor and the cached page updated. See [this post](http://ocaoimh.ie/2009/01/23/wp-super-cache-089/) for more.
   220 
   421 
   221 = Why doesn't the plugin cache requests by search engine bots by default? =
   422 = Why doesn't the plugin cache requests by search engine bots by default? =
   222 
   423 
   223 Those bots usually only visit each page once and if the page is not popular there's no point creating a cache file that will sit idle on your server.
   424 Those bots usually only visit each page once and if the page is not popular there's no point creating a cache file that will sit idle on your server. However if you're not using legacy caching you can allow these visits to be cached by removing the list of bots from "Rejected User Agents" on the Advanced settings page.
   224 
       
   225 = Why shouldn't I create a cache file of every page on my site? =
       
   226 
       
   227 Like the previous question, there's no point caching pages that won't be visited. The large number of cache files will slow down the garbage collection system as it attempts to check each file. It also causes problems for hosting companies. In the event of a disk failure on your server it may take much longer to check the files. Remember how long a scandisk or a fsck took on a large drive?
       
   228 
   425 
   229 = A category page is showing instead of my homepage =
   426 = A category page is showing instead of my homepage =
   230 
   427 
   231 A tiny proportion of websites will have problems with the following configuration:
   428 A tiny proportion of websites will have problems with the following configuration:
   232 
   429 
   233 1. Uses a static page for the front page.
   430 1. Uses a static page for the front page.
   234 2. Uses /%category%/%postname%/ permalink structure.
   431 2. Uses /%category%/%postname%/ permalink structure.
   235 
   432 
   236 Sometimes a category page is cached as the homepage of the site instead of the static page. I can't [replicate the problem](http://wordpress.org/support/topic/237415/page/2?replies=38) but a simple solution is to switch the plugin to half-on mode. For normal traffic you will see no difference in the speed of your site.
   433 Sometimes a category page is cached as the homepage of the site instead of the static page. I can't [replicate the problem](http://wordpress.org/support/topic/237415/page/2?replies=38) but a simple solution is to switch the plugin to PHP mode. For normal traffic you will see no difference in the speed of your site. You can also enable "Extra homepage checks" on the Advanced Settings page.
   237 
   434 
   238 = Why do I get warnings about caching from http://ismyblogworking.com/ =
   435 = Why do I get warnings about caching from http://ismyblogworking.com/ =
   239 
   436 
   240 "Your blog doesn't support client caching (no 304 response to If-modified-since)."
   437 "Your blog doesn't support client caching (no 304 response to If-modified-since)."
   241 "Your feed doesn't support caching (no 304 response to If-modified-since)"
   438 "Your feed doesn't support caching (no 304 response to If-modified-since)"
   242 
   439 
   243 Supercache doesn't support 304 header checks. This is caching done by your browser, not your server. It is a check your browser does to ask the server if an updated version of the current page is available. If not, it doesn't download the old version again.
   440 Supercache doesn't support 304 header checks in mod_rewrite mode but does support it in PHP mode. This is caching done by your browser, not the server. It is a check your browser does to ask the server if an updated version of the current page is available. If not, it doesn't download the old version again. The page is still cached by your server, just not by your visitors' browsers.
   244 The page is still cached by your server, just not by the browsers of your visitors. WordPress doesn't support 304 caching either so you're not losing out.
       
   245 Try the Cacheability Engine at http://www.ircache.net/cgi-bin/cacheability.py or http://redbot.org/ for further analysis.
   441 Try the Cacheability Engine at http://www.ircache.net/cgi-bin/cacheability.py or http://redbot.org/ for further analysis.
   246 
   442 
       
   443 = How should I best use the utm_source tracking tools in Google Analytics with this plugin? =
       
   444 
       
   445 That tracking adds a query string to each url linked from various sources like Twitter and feedreaders. Unfortunately it stops pages being supercached. See [Joost's comment here](http://ocaoimh.ie/remove-unused-utmsource-urls/#comment-672813) for how to turn it into an anchor tag which can be supercached.
       
   446 
       
   447 = The plugin complains that wp-content is writable! htdocs is writable! =
       
   448 
       
   449 It's not good when the web server can write to these directories but sometimes shared hosting accounts are set up in this way to make administration easier. Use `chmod 755 directory` to fix the permissions or find the permissions section of your ftp client. This [Google search](http://www.google.ie/search?sourceid=chrome&ie=UTF-8&q=ftp+fix+directory+permissions+755) will lead you to more information on this topic and there's also [this codex page](http://codex.wordpress.org/Changing_File_Permissions) too. Unfortunately some hosts require that those directories be writable. If that's the case just ignore this warning.
       
   450 
       
   451 = How do I delete the WP_CACHE define from wp-config.php? =
       
   452 
       
   453 Load your desktop ftp client and connect to your site. Navigate to the root (or the directory below it) of your site where you'll find wp-config.php. Download that file and edit it in a text editor. Delete the line `define( 'WP_CACHE', true );` and save the file. Now upload it, overwriting the wp-config.php on your server.
       
   454 
       
   455 = How do I delete the Super Cache rules from the .htaccess file? =
       
   456 
       
   457 Load your desktop ftp client and connect to your site. You may need to enable "Show hidden files" in the preferences of the ftp client. Navigate to the root of your site where you'll find the .htaccess file. Download that file and edit it in a text editor. Delete the lines between "# BEGIN WPSuperCache" and "# END WPSuperCache" and save the file. Now upload it, overwriting the .htaccess file on your server.
       
   458 
       
   459 = How do I change file permissions? =
       
   460 
       
   461 This [page](http://codex.wordpress.org/Changing_File_Permissions) on the WordPress Codex explains everything you need to know about file permissions on your server and various ways of changing them.
       
   462 
       
   463 = Why do I get load spikes when new posts are made? =
       
   464 
       
   465 You may have the "clear all cached files when new posts are made" option set. Clearing those files can take time plus your visitors will now be visiting uncached pages. Are you using Google Analytics campaign tracking with utm_source in the url? Those pages aren't cached. See the question, "How should I best use the utm_source tracking tools in Google Analytics with this plugin" above for how to use them properly.
       
   466 Cached pages have to be refreshed when posts are made. Perhaps your server just isn't up to the job of serving the amount of traffic you get. Enable the "cache rebuild" feature as that may help.
       
   467 
       
   468 = How many pages can I cache? =
       
   469 
       
   470 The only real limit are limits defined by your server. For example, EXT2 and EXT3 allow a maximum of 31,999 sub directories so if you have a flat permalink structure (like /%POSTNAME%/) and more than 32,000 posts you may run into problems. Likewise, if you run a multisite network and have more than 31,999 sites (blogs) you won't be able to cache all of them. Realistically if you had that many active sites you wouldn't be running on one server.
       
   471 
       
   472 = How do I serve cached mobile pages to clients on small screens like phones and tablets? =
       
   473 
       
   474 You'll have to use a separate mobile plugin to render a page formatted for those visitors. The following plugins have been tested but YMMV depending on mobile client.
       
   475 * [WPTouch] (http://wordpress.org/extend/plugins/wptouch/)
       
   476 * [WordPress Mobile Edition] (http://wordpress.org/extend/plugins/wordpress-mobile-edition/)
       
   477 * [WordPress Mobile Pack] (http://wordpress.org/extend/plugins/wordpress-mobile-pack/) (can't have "Don't cache pages for known users." enabled)
       
   478 
       
   479 
   247 = Troubleshooting =
   480 = Troubleshooting =
   248 
   481 
   249 If things don't work when you installed the plugin here are a few things to check:
   482 If things don't work when you installed the plugin here are a few things to check:
   250 
   483 
   251 1.  Is wp-content writable by the web server?
   484 1.  Is wp-content writable by the web server?
   252 2.  Is there a wp-content/wp-cache-config.php ? If not, copy the file wp-super-cache/wp-cache-config-sample.php to wp-content/wp-cache-config.php and make sure WPCACHEHOME points at the right place. "plugins" should be "mu-plugins" if you're using WordPress MU.
   485 2.  Is there a wp-content/wp-cache-config.php ? If not, copy the file wp-super-cache/wp-cache-config-sample.php to wp-content/wp-cache-config.php and make sure WPCACHEHOME points at the right place.
   253 3.  Is there a wp-content/advanced-cache.php ? If not, then you must copy wp-super-cache/advanced-cache.php into wp-content/. You must edit the file and change the path so it points at the wp-super-cache folder.
   486 3.  Is there a wp-content/advanced-cache.php ? If not, then you must copy wp-super-cache/advanced-cache.php into wp-content/. You must edit the file and change the path so it points at the wp-super-cache folder.
   254 4.  If pages are not cached at all, remove wp-content/advanced-cache.php and recreate it, following the advice above.
   487 4.  If pages are not cached at all, remove wp-content/advanced-cache.php and recreate it, following the advice above.
   255 5.  Make sure the following line is in wp-config.php and it is ABOVE the "require_once(ABSPATH.'wp-settings.php');" line:
   488 5.  Make sure the following line is in wp-config.php and it is ABOVE the "require_once(ABSPATH.'wp-settings.php');" line:
   256 
   489 
   257     `define( 'WP_CACHE', true );`
   490     `define( 'WP_CACHE', true );`
   261 9.  If your browser keeps asking you to save the file after the super cache is installed you must disable Super Cache compression. Go to the Settings->WP Super Cache page and disable it there.
   494 9.  If your browser keeps asking you to save the file after the super cache is installed you must disable Super Cache compression. Go to the Settings->WP Super Cache page and disable it there.
   262 10. The plugin does not work very well when PHP's safe mode is active. This must be disabled by your administrator.
   495 10. The plugin does not work very well when PHP's safe mode is active. This must be disabled by your administrator.
   263 11. If pages are randomly super cached and sometimes not, your blog can probably be viewed with and without the "www" prefix on the URL. You should choose one way and install the [Enforce www preference](http://txfx.net/code/wordpress/enforce-www-preference/) plugin if you are using an old WordPress install. The latest versions redirect themselves (you should always be running the latest version of WordPress anyway!)
   496 11. If pages are randomly super cached and sometimes not, your blog can probably be viewed with and without the "www" prefix on the URL. You should choose one way and install the [Enforce www preference](http://txfx.net/code/wordpress/enforce-www-preference/) plugin if you are using an old WordPress install. The latest versions redirect themselves (you should always be running the latest version of WordPress anyway!)
   264 12. Private Server users at Dreamhost should edit wp-content/wp-cache-config.php and set the cache dir to "/tmp/" if they are getting errors about increasing CPU usage. See this [discussion](http://wordpress.org/support/topic/145895?replies=42) for more.
   497 12. Private Server users at Dreamhost should edit wp-content/wp-cache-config.php and set the cache dir to "/tmp/" if they are getting errors about increasing CPU usage. See this [discussion](http://wordpress.org/support/topic/145895?replies=42) for more.
   265 13. File locking errors such as "failed to acquire key 0x152b: Permission denied in..." or "Page not cached by WP Super Cache. Could not get mutex lock." are a sign that you may have to use file locking. Edit wp-content/wp-cache-config.php and uncomment "$use_flock = true" or set $sem_id to a different value. You can also disable file locking from the Admin screen as a last resort.
   498 13. File locking errors such as "failed to acquire key 0x152b: Permission denied in..." or "Page not cached by WP Super Cache. Could not get mutex lock." are a sign that you may have to use file locking. Edit wp-content/wp-cache-config.php and uncomment "$use_flock = true" or set $sem_id to a different value. You can also disable file locking from the Admin screen as a last resort.
   266 14. Make sure cache/wp_cache_mutex.lock is writeable by the web server.
   499 14. Make sure cache/wp_cache_mutex.lock is writable by the web server if using coarse file locking.
   267 15. The cache folder cannot be put on an NFS or Samba or NAS share. It has to be on a local disk. File locking and deleting expired files will not work properly unless the cache folder is on the local machine.
   500 15. The cache folder cannot be put on an NFS or Samba or NAS share. It has to be on a local disk. File locking and deleting expired files will not work properly unless the cache folder is on the local machine.
   268 16. Garbage collection of old cache files won't work if WordPress can't find wp-cron.php. If your hostname resolves to 127.0.0.1 it could be preventing the garbage collection from working. Check your access_logs for wp-cron.php entries. Do they return a 404 (file not found) or 200 code? If it's 404 or you don't see wp-cron.php anywhere WordPress may be looking for that script in the wrong place. You should speak to your server administator to correct this or edit /etc/hosts on Unix servers and remove the following line. Your hostname must resolve to the external IP address other servers on the network/Internet use. See http://yoast.com/wp-cron-issues/ for more.
   501 16. Garbage collection of old cache files won't work if WordPress can't find wp-cron.php. If your hostname resolves to 127.0.0.1 it could be preventing the garbage collection from working. Check your access_logs for wp-cron.php entries. Do they return a 404 (file not found) or 200 code? If it's 404 or you don't see wp-cron.php anywhere WordPress may be looking for that script in the wrong place. You should speak to your server administator to correct this or edit /etc/hosts on Unix servers and remove the following line. Your hostname must resolve to the external IP address other servers on the network/Internet use. See http://yoast.com/wp-cron-issues/ for more. A line like "127.0.0.1 localhost localhost.localdomain" is ok.
   269 
   502 
   270     `127.0.0.1 myhostname.com`
   503     `127.0.0.1 myhostname.com`
   271 A line like "127.0.0.1 localhost localhost.localdomain" is ok.
       
   272 17. If old pages are being served to your visitors via the supercache, you may be missing Apache modules (or their equivalents if you don't use Apache). 3 modules are required: mod_mime, mod_headers and mod_expires. The last two are especially important for making sure browsers load new versions of existing pages on your site.
   504 17. If old pages are being served to your visitors via the supercache, you may be missing Apache modules (or their equivalents if you don't use Apache). 3 modules are required: mod_mime, mod_headers and mod_expires. The last two are especially important for making sure browsers load new versions of existing pages on your site.
   273 18. The error message, "WP Super Cache is installed but broken. The path to wp-cache-phase1.php in wp-content/advanced-cache.php must be fixed!" appears at the end of every page. Open the file wp-content/advanced-cache.php in your favourite editor. Is the path to wp-cache-phase1.php correct? If it is not the caching engine will not load.
   505 18. The error message, "WP Super Cache is installed but broken. The path to wp-cache-phase1.php in wp-content/advanced-cache.php must be fixed!" appears at the end of every page. Open the file wp-content/advanced-cache.php in your favourite editor. Is the path to wp-cache-phase1.php correct? This file will normally be in wp-content/plugins/wp-super-cache/. If it is not correct the caching engine will not load.
   274 19. Caching doesn't work. The timestamp on my blog keeps changing when I reload. Check that the path in your .htaccess rules matches where the supercache directory is. You may have to hardcode it. Or use the plugin in Half-On mode.
   506 19. Caching doesn't work. The timestamp on my blog keeps changing when I reload. Check that the path in your .htaccess rules matches where the supercache directory is. You may have to hardcode it. Or use the plugin in PHP or legacy caching mode.
   275 20. If supercache cache files are generated but not served, check the permissions on all your wp-content/cache/supercache folders (and each of wp-content cache and supercache folders) and wp-content/cache/.htaccess. If your PHP runs as a different user to Apache and permissions are strict Apache may not be able to read the PHP generated cache files. To fix you must add the following line to your wp-config.php (Add it above the WP_CACHE define.) Then clear your cache.
   507 20. If supercache cache files are generated but not served, check the permissions on all your wp-content/cache/supercache folders (and each of wp-content cache and supercache folders) and wp-content/cache/.htaccess. If your PHP runs as a different user to Apache and permissions are strict Apache may not be able to read the PHP generated cache files. To fix you must add the following line to your wp-config.php (Add it above the WP_CACHE define.) Then clear your cache.
   276 
   508 
   277 	`umask( 0022 );`
   509 	`umask( 0022 );`
       
   510 21. If you see garbage in your browser after enabling compression in the plugin, compression may already be enabled in your web server. In Apache you must disable mod_deflate, or in PHP zlib compression may be enabled. You can disable that in three ways. If you have root access, edit your php.ini and find the zlib.output_compression setting and make sure it's "Off" or add this line to your .htaccess:
       
   511 
       
   512 	`php_flag zlib.output_compression off`
       
   513 If that doesn't work, add this line to your wp-config.php:
       
   514 
       
   515 	`ini_set('zlib.output_compression', 0);`
       
   516 22. The "white screen of death" or a blank page  when you visit your site is almost always caused by a PHP error but [it may also be caused by APC](http://www.johnberns.com/2010/03/19/wp-super-cache-blank-page-problem-fixed/). Disable that PHP extension if you have trouble and replace with eAccelerator or Xcache.
       
   517 23. After uninstalling, your permalinks may break if you remove the WordPress mod_rewrite rules too. Regenerate those rules by visiting the Settings->Permalink page and saving that form again.
       
   518 24. If your blog refuses to load make sure your wp-config.php is correct. Are you missing an opening or closing PHP tag?
       
   519 25. Your front page is ok but posts and pages give a 404? Go to Settings->permalinks and click "Save" once you've selected a custom permalink structure. You may need to manually update your .htaccess file.
       
   520 26. If certain characters do not appear correctly on your website your server may not be configured correctly. You need to tell visitors what character set is used. Go to Settings->Reading and copy the 'Encoding for pages and feeds' value. Edit the .htaccess file with all your Supercache and WordPress rewrite rules and add this at the top, replacing CHARSET with the copied value. (for example, 'UTF-8')
       
   521 
       
   522 	`AddDefaultCharset CHARSET`
       
   523 27. Use [Cron View](http://wordpress.org/extend/plugins/cron-view/) to help diagnose garbage collection and preload problems. Use the plugin to make sure jobs are scheduled and for what time. Look for the wp_cache_gc and wp_cache_full_preload_hook jobs.
       
   524 18. The error message, "WP Super Cache is installed but broken. The constant WPCACHEHOME must be set in the file wp-config.php and point at the WP Super Cache plugin directory." appears at the end of every page. You can delete wp-content/advanced-cache.php and reload the plugin settings page or edit wp-config.php and look for WPCACHEHOME and make sure it points at the wp-super-cache folder. This will normally be wp-content/plugins/wp-super-cache/ but you'll likely need the full path to that file (so it's easier to let the settings page fix it). If it is not correct the caching engine will not load.
       
   525 
       
   526 
       
   527 == CDN ==
       
   528 
       
   529 A Content Delivery Network (CDN) is usually a network of computers situated around the world that will serve the content of your website faster by using servers close to you. Static files like images, Javascript and CSS files can be served through these networks to speed up how fast your site loads. You can also create a "poor man's CDN" by using a sub domain of your domain to serve static files too.
       
   530 
       
   531 [OSSDL CDN off-linker](http://wordpress.org/extend/plugins/ossdl-cdn-off-linker/) has been integrated into WP Super Cache to provide basic CDN support. It works by rewriting the URLs of files (excluding .php files) in wp-content and wp-includes on your server so they point at a different hostname. Many CDNs support [origin pull](http://www.google.com/search?hl=en&q=%22origin+pull%22). This means the CDN will download the file automatically from your server when it's first requested, and will continue to serve it for a configurable length of time before downloading it again from your server.
       
   532 
       
   533 Configure this on the "CDN" tab of the plugin settings page. This is an advanced technique and requires a basic understanding of how your webserver or CDNs work. Please be sure to clear the file cache after you configure the CDN.
   278 
   534 
   279 == Custom Caching ==
   535 == Custom Caching ==
   280 It is now possible to hook into the caching process using the add_cacheaction() function.
   536 It is now possible to hook into the caching process using the add_cacheaction() function.
   281 
   537 
   282 Three hooks are available:
   538 Three hooks are available:
   287 
   543 
   288 There is one regular WordPress filter too. Use the "do_createsupercache" filter 
   544 There is one regular WordPress filter too. Use the "do_createsupercache" filter 
   289 to customize the checks made before caching. The filter accepts one parameter. 
   545 to customize the checks made before caching. The filter accepts one parameter. 
   290 The output of WP-Cache's wp_cache_get_cookies_values() function.
   546 The output of WP-Cache's wp_cache_get_cookies_values() function.
   291 
   547 
   292 See plugins/searchengine.php as an example I use for my [No Adverts for Friends](plugin at http://ocaoimh.ie/no-adverts-for-friends/)
   548 See plugins/searchengine.php as an example I use for my [No Adverts for Friends](http://ocaoimh.ie/no-adverts-for-friends/) plugin.
   293 
   549 
   294 == Links ==
   550 == Links ==
   295 [WP Widget Cache](http://wordpress.org/extend/plugins/wp-widget-cache/) is another caching plugin for WordPress. This plugin caches the output of widgets and may significantly speed up dynamic page generation times.
   551 [WP Widget Cache](http://wordpress.org/extend/plugins/wp-widget-cache/) is another caching plugin for WordPress. This plugin caches the output of widgets and may significantly speed up dynamic page generation times.
   296 
   552 
   297 == Updates ==
   553 == Updates ==
   301 I would sincerely like to thank [John Pozadzides](http://onemansblog.com/) for giving me the idea for this, for writing the "How it works" section and for testing the plugin through 2 front page appearances on digg.com
   557 I would sincerely like to thank [John Pozadzides](http://onemansblog.com/) for giving me the idea for this, for writing the "How it works" section and for testing the plugin through 2 front page appearances on digg.com
   302 
   558 
   303 Thanks to James Farmer and Andrew Billits of [Edu Blogs](http://edublogs.org/) fame who helped me make this more WordPress MU friendly.
   559 Thanks to James Farmer and Andrew Billits of [Edu Blogs](http://edublogs.org/) fame who helped me make this more WordPress MU friendly.
   304 
   560 
   305 Translators who did a great job converting the text of the plugin to their native language. Thank you!
   561 Translators who did a great job converting the text of the plugin to their native language. Thank you!
   306 [Gianni Diurno](http://gidibao.net/) (Italian)
   562 
   307 [Omi](http://equipajedemano.info/) (Spanish)
   563 * [Gianni Diurno](http://gidibao.net/) (Italian)
       
   564 * [Omi](http://equipajedemano.info/) (Spanish)
       
   565 * [tomchen1989](http://emule-fans.com/) and [Christopher Meng](http://cicku.me) (Simplified Chinese)
       
   566 * Tai (Japanese)
       
   567 * [Vitaly](http://pressword.com.ua/wordpress/) (Ukranian)
       
   568 * [Pseric](http://pseric.com/) and [Priv](http://priv.tw/blog) (Traditional Chinese)
       
   569 * [Maître Mô](http://maitremo.fr/) (French)
       
   570 * [Mathias Roth](http://trade-service.eu/) (German)
       
   571 * Bar¿¿ Ünver (Turkish)
       
   572 * [Elvis Fweb](http://wp.turkenichev.ru/) (Russian)
       
   573 * Fredrik Forséll (Swedish)
       
   574 * [Alyona Lompar](http://wwww.webhostinggeeks.com/) (Ukranian)
       
   575 * [Nata Strazda](http://www.webhostingrating.com/) (Lithuanian)
       
   576 * [Alexander Alexandrov](http://www.designcontest.com/) (Belarusian)
       
   577 * [Michail Bogdanov](http://www.webhostinghub.com/) (Romanian)