Как очистить (удалить/обнулить/сбросить) cache в nginx?

Если вы активно используете встроенные в nginx функции кеширования, то рано или поздно может возникнуть ситуация, когда вам будет необходимо очистить текущий кеш, например, после обновления стилей css или рекламных блоков, чтобы ваши посетители сразу же увидели изменения, а не дожидались, когда кеш обновится из-за истечения срока его действия.
Удаление всего кеша с диска
Для очистки кеша в nginx достаточно просто удалить все файлы кеша, которые создал nginx в процессе своей работы. В зависимости от типа используемого прокси, файлы могут лежать в разных директориях.
При использовании proxy_cache
Местоположение каталога, в котором будут хранится закешированные ресурсы, определяется параметром proxy_cache_path в конфигурационном файле, обычно, если не менять конфигурацию, все расположено в директории: /var/cache/nginx Чтобы удалить все закешированные страницы и файлы, необходимо проделать следующее:
sudo find /var/cache/nginx -type f -delete
После этого, все страницы и ресурсы на сайте, для которых включено кеширование, должны будут обновить свой кеш по мере поступления к ним запросов.
При использовании fastcgi_cache
Местоположение каталога, в котором будут хранится закешированные ресурсы, определяется параметром fastcgi_cache_path в конфигурационном файле. Для примера, если в конфиге есть такая строка:
fastcgi_cache_path /var/run/nginx-fastcgi-cache levels=1:2 keys_zone=FASTCGICACHE:150m inactive=60m;
То отсюда видно, что кеш хранится в директории /var/run/nginx-fastcgi-cache
Чтобы удалить все закешированные страницы и файлы, необходимо проделать следующее:
sudo find /var/run/nginx-fastcgi-cache -type f -delete
После этого, все страницы и ресурсы на сайте, для которых включено кеширование, должны будут обновить свой кеш по мере поступления к ним запросов.
[nginx] Как принудительно очистить кэш для сайта/URI
Всем привет, есть такой вопрос: как принудительно очистить кэш у nginx`а?
Нашел упоминание о модуле ngx_cache_purge(http://labs.frickle.com/nginx_ngx_cache_purge/), но что-то не понял ни как его использовать ни как он работает 🙂
A_Hariton ★
25.02.10 15:16:24 MSK

поищи в архиве рассылки nginx-ru, там этот вопрос поднимался.
true_admin ★★★★★
( 25.02.10 18:01:43 MSK )

rm -rf proxy_temp
и перезапустите nginx
Sylvia ★★★★★
( 25.02.10 18:05:38 MSK )
Ответ на: комментарий от Sylvia 25.02.10 18:05:38 MSK
было бы классным решением, еслибы не чистился кэшь для всех сайтов 🙁
A_Hariton ★
( 25.02.10 18:15:00 MSK ) автор топика
Ответ на: комментарий от A_Hariton 25.02.10 18:15:00 MSK

server < listen site; server_name site; root /var/www/site; location / < try_files /cache/$uri @stor; >location @stor < proxy_pass http://servak; proxy_set_header Host $host; proxy_store on; proxy_store_access user:rw group:rw all:r; proxy_temp_path /var/www/site/cache/; root /var/www/site/cache/; >>
ну и чистим соответственно руками (кроном). перезапускать ничего не нужно
r0mik ★
( 25.02.10 22:26:56 MSK )
Ответ на: комментарий от r0mik 25.02.10 22:26:56 MSK
а что обозначает конструкция @stor ?
A_Hariton ★
( 26.02.10 12:20:12 MSK ) автор топика
Ответ на: комментарий от A_Hariton 26.02.10 12:20:12 MSK

это отдельный локейшн в котором как раз и указывается куда класть кеш данного вирт.хоста
proxy_pass — куда проксировать proxy_temp_path и root в этом локейшнене указывает куда оно будет складироваться (/var/www/site/cache/).
потом в рутовом локейшене с помощью try-files будет сделана попытка сначала забрать из кеша, а если там нету файла то оно на прокси передаст (@stor)
так делаете с каждым вашим вирт.хостом, меняя соответствующим образом site_name, root и proxy_temp_path.
то есть второй (третий) виртхост будет таким:
server < listen mysite2.net; server_name mysite2.net; root /var/www/mysite2.net; location / < try_files /cache/$uri @stor; >location @stor < proxy_pass http://servak; proxy_set_header Host $host; proxy_store on; proxy_store_access user:rw group:rw all:r; proxy_temp_path /var/www/mysite2.net/cache/; root /var/www/mysite2.net/cache/; >>
таким образом кеши будут отдельно в /var/www/САЙТ/cache/.
вообще это один из вариантов возможных, так как не понятно как оно у вас там сделано. вы бы показали свой конфиг что ли.
r0mik ★
( 26.02.10 13:58:46 MSK )
Ответ на: комментарий от r0mik 26.02.10 13:58:46 MSK
да нечего мне собственно показываьть, просто есть конфигурация
users -> nginx -> Apache
nginx кэширует ответы от Apache чтобы ему было не так плохо. Нужно сделать возможность мочить кэш сайта при необходимости.
A_Hariton ★
( 26.02.10 16:00:44 MSK ) автор топика
Ответ на: комментарий от A_Hariton 26.02.10 16:00:44 MSK

ну вот, значит я все правильно описал. в таком варианте он будет кешировать и складировать для каждого сайта в отдельное место.
r0mik ★
( 26.02.10 18:25:19 MSK )
Ответ на: комментарий от r0mik 26.02.10 18:25:19 MSK

эээмм. извиняюсь, вообще-то эта конфа рассчитана на статику, а я что-то не в те дебри залез.
короче вам, по простому говоря, вообще нужно описать только дерективу proxy_temp_path и proxy_cache_path, а store не трогайте)))) ну и перезапускать таки нужно, это да..
Кэширование ответа от backend с помощью NGINX

Обновлено: 02.08.2023 Опубликовано: 27.01.2020
NGINX позволяет значительно ускорить процесс загрузки страницы, не обращаясь к бэкэнду, а выдавая готовый html из кэша. Для работы данной функции необходимо, чтобы веб-сервер был версии 0.7.44 и выше (проверить можно командой nginx -v). Для FastCGI кэш задается с помощью опций fastcgi_cache_*. Для запросов к бэкэнду с помощью proxy_pass — proxy_cache_*.
Рекомендации и противопоказания
Кэш — это данные не первой свежести. Это важно учитывать, если мы хотим настроить эффективное кэширование средствами nginx. Мы можем столкнуться с различными проблемами, например, неспособность сервера продлить сессию авторизованного пользователя или отображение старой информации на портале с динамично меняющимся контентом. Чтобы избежать данных проблем, настройка nginx должна быть тесно сопряжена с разработкой сайта. Идеальная работа кэша возможна только при полном понимании внутренних механизмах работы портала, такие как, отправка запросов на авторизацию, продление сессии, обновлении контента — программист может написать для этого запрос по определенным URL, для которого администратор NGINX может отключить кэширование. Кэширование динамики будет полезно для сайтов с высокой посещаемостью, из-за которой создается высокая нагрузка на сервер и он не может успеть выполнить обработку запросов. Также оно будет полезно для отдельных страниц, содержимое которых меняется очень редко, но отработка скриптов выполняется долго. Из всего этого можно сделать вывод, что кэширование на стороне сервера NGINX стоит применять только в случае высоких нагрузок и медленной работы сайта из-за долгой работы backend’а.
Настройка кэширования для proxy_pass
Как было сказано выше, для разных методов обращения к серверу, который обрабатывает запрос, нужно использовать разные методы кэширования.
Включение кэширования
Открываем конфигурационный файл nginx:
vi /etc/nginx/nginx.conf
В секцию http добавляем:
http <
.
proxy_cache_path /var/cache/nginx levels=1:2 keys_zone=all:64m inactive=2h max_size=2g;
.
>
- /var/cache/nginx — путь хранения кэша.
- levels — уровень вложенности каталогов. В данном примере мы задаем настройку, при которой в каталог с кэшем будет создан каталог, а в ней — еще один каталог.
- keys_zone — имя зоны в разделяемой памяти, где будет храниться кэш, а также ее размер.
- inactive — задает время, после которого кэш будет автоматически чиститься.
- max_size — максимальный размер данных под кэш. Когда место заканчивается, nginx сам удаляет устаревшие данные.
Создаем каталог для хранения кэша и задаем владельца:
chown nginx:nginx /var/cache/nginx
Настройка хостов
Чтобы определенный сайт или отдельная страница кешировала запрос, открываем конфигурационный файл с настройками виртуального домена или хоста, например:
. и добавим к proxy_pass кэширование — мы получим что-то на подобие:
location / if ($http_cookie ~* «.+» ) set $cookie_cache_bypass 1;
>
proxy_cache_bypass $cookie_cache_bypass;
proxy_pass http://localhost:3000;
.
proxy_cache all;
proxy_cache_methods GET POST HEAD;
proxy_cache_valid 404 502 503 5m;
proxy_cache_valid any 1h;
proxy_cache_use_stale error timeout invalid_header updating;
>
- set $cookie_cache_bypass 1 — задаем значения переменной $cookie_cache_bypass, если передаются куки. Необходимо для предотвращения отдачи устаревших данных.
- proxy_cache_bypass — не отдавать данные из кэша. В нашем случае, применяется при куках.
- proxy_pass — передает запросы на бэкэнд.
- proxy_cache_methods — по умолчанию, закэшированными будут только запросы GET и HEAD. Если нам нужны другие методы, то добавляем их. В нашем примере добавлен POST.
- proxy_cache — включаем кэширование.
- proxy_cache_valid — задает время кеширования. В нашем примере первый параметр задает кэширование страниц с кодами ответов 404, 502, 503 на 5 минут, второй — для всего остального на 1 час.
- proxy_cache_use_stale — указывает, в каких случаях можно отдать устаревший кэш.
Применение настроек
NGINX настроен. Проверим корректность настроек и применяем их, если нет ошибок:
nginx -t && nginx -s reload
Теперь заходим на сайт и смотрим в каталог с кэшем — в нем должны появиться каталоги и файлы:
Мы должны увидеть что-то на подобие:
drwx——. 3 nginx nginx 4096 Jan 25 16:09 0
drwx——. 5 nginx nginx 4096 Jan 25 16:09 2
drwx——. 5 nginx nginx 4096 Jan 25 16:15 3
drwx——. 3 nginx nginx 4096 Jan 25 16:09 4
drwx——. 4 nginx nginx 4096 Jan 26 05:08 5
drwx——. 3 nginx nginx 4096 Jan 25 16:09 6
drwx——. 3 nginx nginx 4096 Jan 26 04:18 7
drwx——. 3 nginx nginx 4096 Jan 25 16:10 8
drwx——. 5 nginx nginx 4096 Jan 25 16:15 a
drwx——. 3 nginx nginx 4096 Jan 25 16:09 b
drwx——. 5 nginx nginx 4096 Jan 26 04:19 e
drwx——. 3 nginx nginx 4096 Jan 25 19:55 f
Настройка кэширования для fastcgi_pass
Настройка fastcgi_cache аналогична proxy_cache и настройки можно сделать по подобию последнего, заменив proxy_ на fastcgi_. Мы разберем основные настройки без подробностей и комментариев.
Открываем конфиг nginx:
Добавляем в секцию http:
http .
fastcgi_cache_path /var/cache/fastcgi levels=1:2 keys_zone=fastcgi:64m inactive=2h max_size=2g;
.
>
* обратите внимание, что мы задали другой каталог и keys_zone.
Создаем каталог для кэша:
chown nginx:nginx /var/cache/fastcgi
location / if ($http_cookie ~* «.+» ) set $cookie_cache_bypass 1;
>
fastcgi_cache_bypass $cookie_cache_bypass;
fastcgi_pass http://localhost:9000;
.
fastcgi_cache all;
fastcgi_cache_methods GET POST HEAD;
fastcgi_cache_valid 404 502 503 5m;
fastcgi_cache_valid any 1h;
fastcgi_cache_use_stale error timeout invalid_header updating;
>
* опции fastcgi_ аналогичны опциям proxy_.
Проверяем настройки и применяем их:
nginx -t && nginx -s reload
Кэширование статики
Кэширование статики не имеет никакого отношения к кэшированию ответа от бэкэнда, однако, это тоже позволяет разгрузить сервер. Суть в том, что nginx сам умеет отдавать статические файлы + задавать инструкцию для браузера по ее кэшированию.
Настройка выполняется для каждого виртуального хоста (секция server):
server .
location ~* ^.+\.(css|js)$ root /var/www/site
expires modified +1w;
>
location ~* ^.+\.(jpg|jpeg|gif|png)$ root /var/www/site
expires max;
>
>
* в данном примере мы задаем для файлов изображений (jpg, jpeg, gif, png) кэш до 31 декабря 2037 23:55:55 (max), для файлов css и js — 1 неделя с момента их модификации. Данные настройки мы задаем при помощи параметра expires, который, в свою очередь, задает заголовок cache-control. NGINX будет искать статические файлы в корневом каталоге /var/www/site.
После применяем настройки:
systemctl restart nginx
Отключение кэширования
Как говорилось выше, в некоторых случаях, кэширование может навредить и на некоторых страницах его стоит отключить. В настройках виртуального хоста, мы можем создать отдельный location, для которого отключиться кэш, например:
location /proxy_nocache proxy_pass http://localhost:3000;
.
proxy_cache off;
>
location /fastcgi_nocache fastcgi_pass http://localhost:9000;
.
fastcgi_cache off;
>
* обратите внимание, что в данном примере мы отключаем кэширование как для запросов proxy_pass, так и fastcgi_pass.
При отключении кэширования для статики используем следующую конфигурацию:
server .
location ~* ^.+\.(jpg|jpeg|gif|png|css|js)$ root /var/www/site
expires epoch;
>
>
* expires epoch задаст заголовок сache-control с временем окончания кэша «1 января 1970 00:00:01».
Сброс кэша
Удалить кэш на стороне сервера nginx мы можем только для бэкэнда. Для статики нужно удалять кэш в самом браузере (например, в настройках или с помощью дополнений).
Для сброса кэша мы просто должны удалить содержимое каталога, который прописан в опции proxy_cache_path или fastcgi_cache_path — в нашем случае, это /var/cache/nginx и /var/cache/fastcgi соответственно.
а) для proxy_cache_path:
б) для fastcgi_cache_path:
Хранение кэша в оперативной памяти
Мы можем значительно ускорить процесс записи и чтения информации, если будем хранить кэш в оперативной памяти.
Создаем обычный каталог, в который будем монтировать часть оперативной памяти:
. и дадим на него полные права:
chmod 777 /var/ramdisk
Монтируем часть оперативной памяти как обычный каталог:
mount -t tmpfs -o size=2G ramdisk /var/ramdisk
* в данном примере мы монтируем 2 Гб оперативной памяти как папку /var/ramdisk. Возможно, правильнее будет заранее убедиться в наличие свободной памяти командой free.
Для автоматического монтирования открываем на редактирование fstab:
ramdisk /var/ramdisk tmpfs nodev,nosuid,noexec,nodiratime,size=2G 0 0
Теперь, когда у нас есть каталог, данные которого хранятся в оперативной памяти, редактируем параметр proxy_cache_path или fastcgi_cache_path в NGINX:
proxy_cache_path /var/ramdisk levels=1:2 keys_zone=all:64m inactive=2h max_size=2g;
fastcgi_cache_path /var/ramdisk levels=1:2 keys_zone=fastcgi:64m inactive=2h max_size=2g;
systemctl restart nginx
Отключение кэша nginx
Отключение кэша nginx или как решить проблему? Здравствуйте господа, На впс наблюдаю такую проблему: Загрузил и установил скрипт движка, при смене в дизайне графику или css, на сайте ничего не меняется, заливаю логотип сайта по фтп а браузер показывает старый логотип, конечно же чистил кэш браузера, все равно ничего не помогает, решил поискать по форумам инфу как решить проблему, оказалось многие встречали подобное и решали по разному, по мнению многих пользователей виноват кэш Nginx, некоторые пользователи пишут, что нужно удалить папку кэша Nginx на сервере, так же нашел инструкцию как настроить время кэширования типа: В nginx.conf
server <
#.
location ~* \.(gif|ico|jpe?g|png)(\?[0-9]+)?$ <
expires 1w;
>
location ~* \.(css|js)$ <
expires 1d;
>
#.
>
где expires — это количество дней, сколько кэш статических файлов будет храниться.
А как отключить вообще не нашел. Написал так же с проблемой в т.п хоста вот ответ
Почистили кэш.
чистить так
service nginx stop
rm -rf /var/cache/nginx/*
service nginx start
Но и это не помогло. Все равно в браузер выдает старую графику и стили. Вот скажите пожалуйста как бы правильно отключить кэш nginx на совсем? Или например настроить как, что бы кэш хранился всего 1-2 секунд? Если в expires в место 1w укажу 2s будет ли работать так? или в место 1w напишу off? Используется панель Веста — если это имеет значение. спасибо.
- eTarget 2011:Панельная дискуссия «Стратегия и планирование рекламной кампании в интернете»
- eTarget 2011: Круглый стол «Реклама в онлайн-видео»
- Могут ли «плохие» входящие ссылки привести к ухудшению ранжирования?