WP Super Cache

Опис

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.

Статичні файли html будуть подаватися переважній більшості ваших користувачів:

  • Users who are not logged in.
  • Users who have not left a comment on your blog.
  • Or users who have not viewed a password protected post.

99% ваших відвідувачів будуть обслуговуватися статичними HTML-файлами. Один кешований файл можна подавати тисячі разів. Іншим відвідувачам будуть подані кешовані кешовані файли з урахуванням їх відвідування. Якщо вони увійшли в систему або залишили коментарі, ці дані будуть відображені та кешовані для них.

The plugin serves cached files in 3 ways (ranked by speed):

  1. Expert. 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 which is risky and may take down your site if modified incorrectly.
  2. Простий режим. Суперкешовані статичні файли можуть обслуговуватися PHP, і це рекомендований спосіб використання плагіна. Плагін буде обслуговувати “суперкешований” файл, якщо він існує, і це майже так само швидко, як метод mod_rewrite. Налаштувати це легше, оскільки файл .htaccess не потрібно змінювати, але вам все ще потрібні власні постійні посилання. У цьому режимі ви можете зберігати частини сторінки динамічними.
  3. Кешування WP-Cache. В основному використовується для кешування сторінок для відомих користувачів, URL-адрес із параметрами та каналами. Відомі користувачі – це користувачі, що ввійшли в систему, відвідувачі, які залишили коментарі, або ті, кому слід показувати якісь особливі дані. Це найбільш гнучкий метод кешування, але трохи повільніший. Кешування WP-Cache також зачіпає відвідування невідомими користувачами, якщо суперкешування вимкнено. У цьому режимі ви також можете мати динамічні частини на вашій сторінки. Цей режим завжди ввімкнено, але ви можете вимкнути кешування для відомих користувачів, URL-адрес із параметрами або каналів окремо. Встановіть для константи “DISABLE_SUPERCACHE” значення 1 у вашому wp-config.php, якщо ви хочете використовувати лише кешування WP-Cache.

Якщо вам не подобається редагувати PHP-файли, використовуйте простий режим. Він легкий і швидкий в налаштуванні.

Recommended Settings

  1. Просте кешування.
  2. Compress pages.
  3. Don’t cache pages for known users.
  4. Cache rebuild.
  5. CDN support.
  6. Extra homepage checks.

Збір сміття – це очищення застарілих та застарілих файлів кешу. Немає правильного значення часу застарівання, але хороша початкова точка – 1800 секунд.

Подумайте про видалення вмісту текстового поля “Відхилені User-Agent” та дозвольте пошуковим системам кешувати файли для вас.

Попередньо завантажте стільки записів, скільки зможете, і ввімкніть “Режим попереднього завантаження”. Збір сміття старих кешованих файлів буде вимкнено. Якщо ви не дбаєте про оновлення віджетів бічної панелі, встановлюйте інтервал попереднього завантаження на 2880 хвилин (2 дні), щоб ваші записи не оновлювалися дуже часто. Коли відбувається попереднє завантаження, файли кешу для запису, який оновлюється, видаляються, а потім відновлюються. Потім виконується збір сміття всіх старих файлів для очищення застарілого кешу.↵
Навіть при ввімкненому режимі попереднього завантаження кешовані файли все одно видалятимуться, коли записи змінюються або коментуються.

Розробка

Документація

Якщо вам потрібно більше інформації, ніж наведено нижче, ви можете переглянути документацію для розробників.

Попереднє завантаження

Ви можете створити кешовані файли для записів, категорій та позначок вашого сайту, попередньо завантаживши їх. Попереднє завантаження відвідає кожну сторінку вашого сайту, генеруючи кешовану сторінку, як і будь-який інший відвідувач сайту. Через послідовний характер цієї функції, може знадобитися деякий час, щоб попередньо завантажити весь сайт, особливо якщо записів багато.
Щоб зробити попереднє завантаження більш ефективним, може бути корисно відключити збір сміття, щоб старі файли кешу не видалялися. Це робиться шляхом увімкнення режиму попереднього завантаження в налаштуваннях. Однак пам’ятайте, що сторінки з часом застаріють, хоч оновлення шляхом надсилання коментарів або редагування записів і очистять частини кешу.

Збір сміття

Каталог кешу з часом заповнюється, що займає місце на сервері. Якщо простір обмежений, дорогий, або якщо ви турбуєтесь, що кешовані сторінки вашого сайту будуть застарілими, тоді потрібно налаштувати збір сміття. Збір сміття відбувається регулярно і видаляє старі файли в каталозі з кешем. На сторінці розширених налаштувань ви можете вказати:
1. Тайм-аут кешу. Як довго кеш-файли вважаються свіжими. Через цей час вони стануть застаріли і можуть бути видалені.
2. Планувальник. Встановіть, як часто слід робити збір сміття.
3. Електронні листи з повідомленнями. Ви можете бути проінформовані про хід роботи зі збору сміття.
Немає правильних чи неправильних налаштувань для збору сміття, все залежить від вашого власного сайту.
Якщо ваш сайт отримує регулярні оновлення або коментарі, встановіть час очікування 1800 секунд, а таймер – 600 секунд.
Якщо ваш сайт в основному статичний, ви можете вимкнути збір сміття, ввівши 0, як тайм-аут або використати дуже велике значення тайм-ауту.

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.

CDN

Мережа доставки контенту (CDN) – це, як правило, мережа комп’ютерів, розташованих по всьому світу, які швидше обслуговуватимуть вміст вашого веб-сайту за допомогою близьких до вас серверів. Статичні файли, такі як зображення, файли Javascript та CSS, можуть подаватися через ці мережі, щоб пришвидшити швидкість завантаження вашого сайту. Ви також можете створити “бідний CDN”, використовуючи піддомен свого домену для обслуговування статичних файлів.

OSSDL CDN off-linker інтегрований у WP Super Cache для забезпечення базової підтримки CDN. Він працює, переписуючи URL-адреси файлів (крім файлів .php) у wp-content та wp-includes на вашому сервері, щоб вони вказували на інше ім’я хосту. Багато мереж CDN підтримують origin pull. Це означає, що CDN автоматично завантажить файл із вашого сервера при першому запиті, і продовжить обслуговувати його протягом певного періоду часу, перш ніж завантажувати його знову з вашого сервера.

Налаштуйте це на вкладці “CDN” на сторінці налаштувань плагіна. Це передова техніка, яка вимагає базового розуміння того, як працює ваш веб-сервер або CDN. Будь ласка, не забудьте очистити кеш файлів після налаштування CDN.

REST API

Зараз існують REST API endpoints для доступу до налаштувань цього плагіна. Вам потрібно буде автентифікуватися як адміністратор з дозволом переглядати сторінку налаштувань, щоб використовувати його. Це ще не задокументовано, але ви можете знайти весь код, який має справу з цим, у каталозі “rest”.

Власне кешування

Тепер можна використати хук для процесу кешування за допомогою функції add_cacheaction().

Доступні три хуки:

  1. ‘wp_cache_get_cookies_values’ – змінює ключ, що використовується WP Cache.
  2. ‘add_cacheaction’ – запускається у фазі 2. Дозволяє плагіну додавати хуки WordPress.
  3. ‘cache_admin_page’ – запускається на сторінці адміністратора. Використовуйте його для модифікації цієї сторінки, додавши нові параметри конфігурації.

Існує також один звичайний фільтр WordPress. Використовуйте фільтр “do_createsupercache ”
для налаштування перевірок, зроблених перед кешуванням. Фільтр приймає один параметр.
Результат роботи функції wp_cache_get_cookies_values ​​() WP-Cache.

WP Super Cache має власну систему плагінів. Їх код завантажується разом із WP Super Cache і може використовуватися для зміни налаштувань кешування. Це відбувається у більшості до завантаження WordPress, тому деякі функції будуть недоступні. Плагіни можуть бути розташовані де завгодно, звідки їх може завантажити PHP. Додайте власний плагін:

  • помістивши свій плагін в каталог wp-content/ plugins/wp-super-cache-plugins, або
  • за допомогою виклику wpsc_add_plugin( $name ), де $name – це повне ім’я файлу та шлях до плагіна. Вам потрібно лише один раз викликати цю функцію, щоб додати його. Використовуйте wpsc_delete_plugin( $name ), щоб видалити його зі списку завантажених плагінів.

Файли cookie, які використовує WP Super Cache для ідентифікації “відомих користувачів”, тепер можна змінити, додавши імена цих файлів cookie до списку в конфігурації плагіна. Використовуйте wpsc_add_cookie( $name ), щоб додати новий файл cookie, та wpsc_delete_cookie( $name ), щоб видалити його. Назви файлів cookie також змінюють правила mod_rewrite, що використовуються плагіном, але рекомендується використовувати кешування в простому режимі, щоб уникнути ускладнень з оновленням файлу .htaccess.
Ім’я та значенняcookie використовуються для розмежування користувачів, тому ви, наприклад, можете мати один cookie, але різні значення для кожного типу користувачів на вашому сайті. Їм буде подано різні файли кешу.

Див. plugins/searchengine.php, як приклад, який використовується у плагіні No Adverts for Friends.

Troubleshooting

If things don’t work when you installed the plugin here are a few things to check:

  1. Is wp-content writable by the web server?
  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.
  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.
  4. If pages are not cached at all, remove wp-content/advanced-cache.php and recreate it, following the advice above.
  5. Make sure the following line is in wp-config.php and it is ABOVE the “require_once(ABSPATH.’wp-settings.php’);” line:

    define( 'WP_CACHE', true );
    
  6. Try the Settings->WP Super Cache page again and enable cache.
  7. Look in wp-content/cache/supercache/. Are there directories and files there?
  8. Anything in your php error_log?
  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.
  10. The plugin does not work very well when PHP’s safe mode is active. This must be disabled by your administrator.
  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 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!)
  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 for more.
  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.
  14. Make sure cache/wp_cache_mutex.lock is writable by the web server if using coarse file locking.
  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.
  16. Збір сміття не працюватиме, якщо WordPress не може знайти wp-cron.php. Якщо ваше ім’я хосту – 127.0.0.1, це може перешкоджати роботі збору сміття. Перевірте свої журнали доступу на наявність записів wp-cron.php. Вони повертають код 404 (файл не знайдено) або 200? Якщо це 404 або ви не бачите wp-cron.php де-небудь, WordPress може шукати цей сценарій не в тому місці. Вам слід поговорити зі своїм системним адміністратором, щоб виправити це або відредагувати /etc/hosts на Unix-серверах і видалити наступний рядок. Ім’я вашого хосту повинно перетворюватися на зовнішню IP-адресу інших серверів у мережі / інтернеті. Докладніше див. на веб-сайті http://yoast.com/wp-cron-issues/. Рядок типу “127.0.0.1 localhost localhost.localdomain” – це нормально.

    127.0.0.1 example.com
    
  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.
  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.
  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. Try disabling supercache mode.
  20. Якщо файли кешу генеруються, але не доставляються, перевірте дозволи на всі ваші папки wp-content/cache/supercache (і кожну з папок wp-content cache та supercache) та wp-content/ cache/.htaccess. Якщо ваш PHP працює як окремий користувач і має обмежені дозволи, Apache може не змогти прочитати файли кешу, створені PHP. Щоб виправити цю помилку, потрібно додати наступний рядок до вашого wp-config.php (додайте його над визначенням WP_CACHE). Потім очистіть кеш.

    umask( 0022 );
    
  21. Якщо після увімкнення стиснення в плагіні ви бачите сміття у своєму браузері, стиснення може бути вже ввімкнено на вашому веб-сервері. В Apache ви повинні вимкнути mod_deflate, інакше в PHP може бути ввімкнено стиснення zlib. Ви можете вимкнути це трьома способами. Якщо у вас є root-доступ, відредагуйте php.ini та знайдіть параметр zlib.output_compression і переконайтеся, що він вимкнений, або додайте цей рядок до свого .htaccess:

    php_flag zlib.output_compression off
    

    Якщо це не працює, додайте цей рядок до вашого wp-config.php:

    ini_set('zlib.output_compression', 0);
    
  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. Disable that PHP extension if you have trouble and replace with eAccelerator or Xcache.
  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.
  24. If your blog refuses to load make sure your wp-config.php is correct. Are you missing an opening or closing PHP tag?
  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.
  26. Якщо певні символи хибно відображаються на вашому веб-сайті, ваш сервер може бути налаштований неправильно. Вам потрібно сказати відвідувачам, який набір символів використовується. Перейдіть до Налаштування->Читання та скопіюйте значення “Кодування сторінок та стрічок”. Відредагуйте файл .htaccess з усіма правилами перезапису Supercache та WordPress і додайте це вгорі, замінивши CHARSET на скопійоване значення (наприклад, “UTF-8”).

    AddDefaultCharset CHARSET
    
  27. Use 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.
  28. 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.
  29. Якщо на вашому сервері виникають проблеми через кількість семафорів, які використовує плагін, це тому, що ваші користувачі використовують блокування файлів, що не рекомендується (але потрібно невеликій кількості користувачів). Ви можете глобально вимкнути блокування файлів, визначивши константу WPSC_DISABLE_LOCKING або визначивши константу WPSC_REMOVE_SEMAPHORE, щоб викликати sem_remove() після того, як кожна сторінка кешується, але це, здається, створює проблеми для інших процесів, що вимагають того самого семафору. Краще відключити його.
  30. Встановіть змінну $htaccess_path у wp-config.php або wp-cache-config.php у шлях до вашого глобального .htaccess, якщо плагін шукає цей файл у неправильному каталозі. Це може статися, якщо WordPress встановлено у незвичний каталог.

Встановлення

Встановіть, як і будь-який інший плагін, безпосередньо зі своєї сторінки плагінів, але переконайтеся, що у вас увімкнено власні постійні посилання. Перейдіть на сторінку налаштувань плагіна в Налаштування->WP Super Cache та ввімкніть кешування.

Як видалити WP Super Cache

Майже все, що вам потрібно зробити, це деактивувати плагін на сторінці плагінів. Плагін повинен очистити більшість створених та модифікованих файлів, але він ще не видаляє правила mod_rewrite із файлу .htaccess. Шукайте розділ у цьому файлі, позначений тегами SuperCache BEGIN та END. Плагін не видаляє їх, оскільки деякі люди також додають правила WordPress у цей блок.

Щоб видалити вручну:

  1. Вимкніть кешування на сторінці налаштувань плагіна та очистіть кеш.
  2. Вимкніть плагін на сторінці плагінів.
  3. Видаліть визначення WP_CACHE із wp-config.php. Це виглядає як define ('WP_CACHE', true);
  4. Видаліть правила Super Cache mod_rewrite з вашого файлу .htaccess.
  5. Видаліть файли wp-content/advanced-cache.php та wp-content/wp-cache-config.php
  6. Видалити каталог wp-content/cache/
  7. Видаліть каталог wp-super-cache з каталогу плагінів.

Якщо все інше не вдається, і ваш сайт зламаний

  1. Видаліть визначення WP_CACHE із wp-config.php. Це виглядає як define ('WP_CACHE', true);
  2. Видаліть правила (див. вище), які плагін записав у файл .htaccess у вашому кореневому каталозі.
  3. Видаліть папку wp-super-cache у папці плагінів.
  4. За бажанням видаліть advanced-cache.php, wp-cache-config.php та папку кешу в wp-content/.

Часті питання

How do I know my blog is being cached?

Зайдіть в Налаштування -> WP Super Cache і знайдіть форму “Перевірка кешу” на сторінці простих налаштувань. Клацніть «Перевірити кеш», і плагін двічі зробить запит на першу сторінку сайту, порівнюючи позначку часу на кожній, щоб переконатися, що вони збігаються.

Якщо ви хочете зробити це вручну, увімкніть налагодження на сторінці налаштувань плагіна та завантажте файл журналу на новій вкладці браузера. Потім перегляньте свій блог, увійшовши та вийшовши з системи. Ви повинні побачити активність у журналі. Перегляньте вихідний код будь-якої сторінки вашого сайту. Коли сторінку створено вперше, ви побачите текст “Dynamic page generated in XXXX seconds.”. та “Cached page generated by WP-Super-Cache on YYYY-MM-DD HH:MM:SS” в кінці вихідного коду. При перезавантаженні кешована сторінка відображатиме той самий відміток часу, тому зачекайте кілька секунд перед перевіркою
Якщо Supercaching вимкнено і у вас увімкнено стиснення, буде додано текст “Compression = gzip”. Якщо стиснення вимкнено і сторінка подається як статичний html-файл, буде додано текст “super cache”. Єдиний інший спосіб перевірити, чи кешований файл обслуговувався PHP-скриптом або зі статичного кешу, – це перегляд заголовків HTTP. Сторінки, кешовані PHP, матимуть заголовок “WP-Super-Cache: Served supercache file from PHP”. Кешовані файли WPCache матимуть заголовок “WP-Super-Cache: Served WPCache cache file”. Вам також слід перевірити каталог кешу у wp-content/ cache/ supercache/hostname/ на наявність файлів статичного кешу.
Якщо у вашому файлі .htaccess відсутні правила плагіна, плагін спробує обслуговувати суперкешовану сторінку, якщо її буде знайдено. Якщо це трапиться, з’явиться заголовок “WP-Super-Cache: Served supercache file from PHP”.
Модуль Pagespeed для Apache може викликати проблеми під час тестування. Вимкніть його, якщо ви помітили будь-які проблеми із запуском перевірки кешу.

Як відключити Supercaching?

Якщо ви хочете використовувати лише механізм WP-Cache, тоді відредагуйте wp-config.php або створіть му-плагін, який встановлює константу ‘DISABLE_SUPERCACHE’ в 1.

WP-Cache проти файлів Supercache

Усі файли кешу зберігаються у wp-content/ cach / supercache/HOSTNAME/, де HOSTNANE – це ваше доменне ім’я. Файли зберігаються в каталогах, що відповідають структурі постійного посилання вашого сайту. Файли Supercache – це index.html або якийсь їх варіант, залежно від того, який тип відвідувача потрапив у блог. Інші файли називаються wp-cache-XXXXXXXXXXXXXXXXXX.php. Імена пов’язаних метафайлів починаються з “meta”. Ці файли містять інформацію про кешований файл. Вони генеруються механізмом “кешування WPCache” у плагіні.

Will comments and other dynamic parts of my blog update immediately?

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.

Will the Super Cache compression slow down my server?

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.

How do I make certain parts of the page stay dynamic?

Note: this functionality is disabled by default. You will have to enable it on the Advanced Settings page.

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 and is the recommended way. Or you can use a WP Super Cache filter to do the job but you can’t use mod_rewrite mode caching. You have to use the “simple” delivery method or disable supercaching.

WP Super Cache 1.4 представив фільтр кешування, який називається wpsc_cachedata. Кешована сторінка, що відображається, проходить через цей фільтр і дозволяє змінювати її. Якщо сторінка містить тег-заповнювач, фільтр можна використовувати для заміни цього тегу на ваш динамічно сформований html.↵
Функція, яка підключається до фільтра wpsc_cachedata, повинна бути поміщена у файл у папці плагінів WP Super Cache, якщо ви не використовуєте функцію late_init. Приклад плагіна включений. Відредагуйте dynamic-cache-test.php , щоб побачити приклад коду.↵
Там є дві приклади функцій. Існує проста функція, яка замінює рядок (або тег), який ви визначаєте при обслуговуванні кешованої сторінки. Інший приклад функції використовує вихідний буфер для генерації динамічного вмісту. Через обмеження в роботі PHP код вихідного буфера ПОВИНЕН запускатися до того, як потрапить фільтр wpsc_cachedata, принаймні, коли сторінка кешована. Не має значення при обслуговуванні кешованих сторінок. Дивіться цю публікацію, щоб отримати більш технічне та довше пояснення.
Для запуску функцій WordPress потрібно ввімкнути функцію «Пізня ініціалізація» на сторінці розширених налаштувань.

How do I delay serving the cache until the “init” action fires?

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. Enable ‘Late init’ mode on the Advanced settings page and cached files will be served when “init” fires. WordPress and it’s plugins will be loaded now.

Why don’t WP UserOnline, Popularity Contest, WP Postratings or plugin X not work or update on my blog now?

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 wpsc_cachedata filter described in the previous answer to update or display dynamic information.

Why do my WP Super Cache plugins disappear when I upgrade the plugin?

WordPress видаляє папку плагіна, коли оновлює плагін. Те ж саме стосується і WP Super Cache, тому будь-які змінені файли в wp-super-cache/ plugins/ будуть видалені. Ви можете розмістити власні плагіни в іншому каталозі різними способами: можете визначити змінну $wp_cache_plugins_dir у wp-config.php або wp-content/wp-cache-config.php і направити її в каталог за межами папки wp-super-cache. Тепер плагіни WP Super Cache будуть завантажуватись звідти. Або якщо ви поширюєте плагін, який потрібно завантажити раніше, ви можете використовувати функцію wpsc_add_plugin( $filename ), щоб додати новий плагін, де б він не був. Використовуйте wpsc_delete_plugin( $filename ), щоб видалити файл плагіна. Див. #574 або цю публікацію про написання плагінів для WP Super Cache.

What does the Cache Rebuild feature do?

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 within the next 10 seconds 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 for more.

Why doesn’t the plugin cache requests by search engine bots by default?

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 you can allow these visits to be cached by removing the list of bots from “Rejected User Agents” on the Advanced settings page.

A category page is showing instead of my homepage

A tiny proportion of websites will have problems with the following configuration:

  1. Uses a static page for the front page.
  2. Uses /%category%/%postname%/ permalink structure.

Іноді сторінка категорії кешується як домашня сторінка сайту замість статичної. Ми не можемо відтворити проблему, але легким рішенням є використання простого режиму. Ви також можете ввімкнути “Додаткові перевірки домашньої сторінки” на сторінці Додаткові налаштування.

Why do I get warnings about caching from http://ismyblogworking.com/

“Ваш блог не підтримує кешування клієнта (немає 304 відповіді на If-modified-since).”
“Ваш канал не підтримує кешування (немає 304 відповіді на If-modified-since)”

Supercache не підтримує перевірку заголовка 304 у просунутому режимі, але підтримує його у простому. Це кешування здійснює ваш браузер, а не сервер. Це перевірка, яку ваш браузер запитує у сервера, чи доступна оновлена ​​версія поточної сторінки. Якщо ні, вона не завантажує стару версію знову. Сторінка все ще кешується вашим сервером, а не браузерами ваших відвідувачів.
Спробуйте механізм кешування на http://www.ircache.net/cgi-bin/cacheability.py або https://redbot.org/ для подальшого аналізу.

How should I best use the utm_source tracking tools in Google Analytics with this plugin?

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 for how to turn it into an anchor tag which can be supercached.

The plugin complains that wp-content is writable! htdocs is writable!

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 will lead you to more information on this topic and there’s also this codex page too. Unfortunately some hosts require that those directories be writable. If that’s the case just ignore this warning.

How do I delete the WP_CACHE define from wp-config.php?

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.

How do I delete the Super Cache rules from the .htaccess file?

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.

How do I change file permissions?

This page on the WordPress Codex explains everything you need to know about file permissions on your server and various ways of changing them.

Why do I get load spikes when new posts are made?

Можливо, у вас встановлена ​​опція “очистити всі кешовані файли при створенні нових записів”. Очищення цих файлів може зайняти час, плюс ваші відвідувачі тепер будуть відвідувати некешовані сторінки. Чи використовуєте ви відстеження кампаній Google Analytics з utm_source в URL-адресі? Ці сторінки не кешуються. Дивіться вище запитання “Як найкраще використовувати інструменти відстеження utm_source в Google Analytics за допомогою цього плагіна” вище, щоб дізнатися, як ними правильно користуватися.
Кешовані сторінки повинні оновлюватися під час створення дописів. Можливо, ваш сервер просто не в змозі обслуговувати обсяг отриманого вами трафіку. Увімкніть функцію “очистка кешу”, оскільки це може допомогти.

How many pages can I cache?

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.

Я бачу, що www версія мого сайту кешована окремо. Як цього уникнути?

WordPress повинен переспрямовувати всі запити на канонічну URL-адресу вашого сайту, але якщо цього не відбувається, додайте це у свій .htaccess над правилами Supercache та WordPress. Замініть example.com на ваше ім’я хосту:
RewriteCond %{HTTP_HOST} www.example.com$ [NC]
RewriteRule ^(.*)$ https://example.com/$1 [L,R=301]

How do I serve cached mobile pages to clients on small screens like phones and tablets?

Ваша тема, скоріш за все, адаптивна, що означає, що вона змінює розмір сторінки відповідно до будь-якого пристрою, що відображає сторінку. Якщо вона не адаптивна, вам доведеться використовувати окремий плагін для мобільних пристроїв, щоб відтворити сторінку, відформатовану для цих відвідувачів. Наступні плагіни протестовані, але все залежить від мобільного клієнта. Вам також доведеться включити підтримку мобільного браузера на сторінці Додаткові налаштування.

Відгуки

17.08.2022
I have been using this plugin for many years, and it's working good without any issues. As well, the site speed has improved a lot.
Прочитати всі 1 298 відгуків

Учасники та розробники

“WP Super Cache” — проект з відкритим вихідним кодом. В розвиток плагіну внесли свій вклад наступні учасники:

Учасники

“WP Super Cache” було перекладено на 30 локалізацій. Дякуємо перекладачам за їх роботу.

Перекладіть “WP Super Cache” на вашу мову.

Цікавитесь розробкою?

Перегляньте код, перегляньте сховище SVN або підпишіться на журнал розробки за допомогою RSS.

Журнал змін

1.9 – 2022-09-16

Added

  • Cache deletion: add new hook to trigger actions after a successful cache deletion from the admin bar.

Fixed

  • Fixes to URL parsing to prevent cache pollution issues around URLs with double-slashes.

See the previous changelogs here