Cache-control и Nginx

Lord Maverik
На сайте с 15.04.2003
Offline
471
1467

Пытаюсь настроить Cache-control в NGinx, вроде все по инструкции, но все равно не работает :(



user www-data;
worker_processes auto;

error_log /var/log/nginx/error.log warn;
pid /var/run/nginx.pid;


events {
worker_connections 2048;
use epoll;
}


http {
include /etc/nginx/mime.types;
default_type application/octet-stream;

log_format main '$remote_addr - $remote_user [$time_local] "$request" '
'$status $body_bytes_sent "$http_referer" '
'"$http_user_agent" "$http_x_forwarded_for"';

access_log /var/log/nginx/access.log main;

sendfile on;
#tcp_nopush on;

keepalive_timeout 65;

gzip on;


proxy_connect_timeout 600;
proxy_send_timeout 600;
proxy_read_timeout 600;
send_timeout 600;

client_max_body_size 100m;
client_body_buffer_size 128k;

gzip_buffers 16 8k;
gzip_http_version 1.1;
gzip_min_length 10;
gzip_types
text/plain
text/css
text/js
text/xml
text/javascript
text/X-javascript
image/png
application/json
application/js
application/javascript
application/x-javascript
application/xml
application/xml+rss
image/x-icon
application/vnd.ms-fontobject
font/opentype
application/x-font-ttf;
gzip_vary on;
gzip_comp_level 5;
gzip_proxied any;
gzip_disable msie6;

fastcgi_buffers 16 16k;
fastcgi_buffer_size 32k;
proxy_buffer_size 128k;
proxy_buffers 4 256k;
proxy_busy_buffers_size 256k;

include /etc/nginx/conf.d/*.conf;
include /etc/nginx/vhosts/*/*;
server {
server_name localhost;
disable_symlinks if_not_owner;
listen 80;
include /etc/nginx/vhosts-includes/*.conf;
location ~* \.(?:ico|css|js|gif|jpe?g|png)$ {
# Some basic cache-control for static files to be sent to the browser
expires max;
add_header Pragma public;
add_header Cache-Control "public, must-revalidate, proxy-revalidate";
}
location @fallback {
error_log /dev/null crit;
proxy_pass http://127.0.0.1:8080;
proxy_redirect http://127.0.0.1:8080 /;
proxy_set_header Host $host;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Forwarded-Proto $scheme;
access_log off ;
}
}
}

Проверяю на тех же картинках или css, ответ сервера:

HTTP/1.1 200 OK
Server: nginx/1.10.1
Date: Wed, 03 Aug 2016 05:08:25 GMT
Content-Type: application/javascript; charset=UTF-8
Content-Length: 356254
Last-Modified: Wed, 03 Aug 2016 04:36:24 GMT
Connection: keep-alive
Vary: Accept-Encoding
ETag: "57a174c8-56f9e"
Accept-Ranges: bytes
RedMall.Ru (https://redmall.ru) - Товары из Китая (Таобао, Tmall) с проверкой качества, скидка для форумчан 7% Партнерская программа 2 уровня: 5% + 5%. Подробнее. (https://redmall.ru/about/partner/)
L
На сайте с 10.02.2015
Offline
260
#1

gzip_min_length 10;

Смысла в этом нет.

Достаточно

gzip_min_length 1024;

Вы точно обращаетесь к серверу localhost? :)

Пропишите а этом блоке


location ~* \.(?:ico|css|js|gif|jpe?g|png)$ {
return 403;
}

Если ответ будет не 403, значит эта секция не отрабатывает.

Возможно js файлы обрабатываются в других файлах.

П.С.

Почему сервер localhost прописан в nginx.conf, а не в


include /etc/nginx/conf.d/*.conf;
include /etc/nginx/vhosts/*/*;
Lord Maverik
На сайте с 15.04.2003
Offline
471
#2
livetv:
Вы точно обращаетесь к серверу localhost?

ммм.. перенес в nginx.conf для домена, все заработало.

Я и до этого там размещал, но только сейчас обратил внимание, что для https еще и своя секция.

Все заработало :)

Авторизуйтесь или зарегистрируйтесь, чтобы оставить комментарий