나는 다음을 가지고 있습니다 location
:
location /content/ {
proxy_cache my_cache;
proxy_cache_valid any 3m;
proxy_cache_revalidate on;
proxy_cache_min_uses 3;
proxy_cache_lock on;
proxy_ignore_headers X-Accel-Expires Expires Cache-Control Vary;
proxy_cache_use_stale error timeout updating http_500 http_502 http_503 http_504;
try_files $uri $uri/ =404;
구성은 다음과 같습니다 cache-path
.
proxy_cache_methods GET HEAD;
proxy_cache_path
/var/cache/nginx
levels=1:2
keys_zone=my_cache:3m
max_size=4g
inactive=360m;
이 스크립트를 실행하여 다음을 테스트합니다 location
.
# for x in {1..1000}; do curl -sD- http://172.30.3.19/content/tst.txt; sleep .3; done
HTTP/1.1 200 OK
Server: nginx
Date: Wed, 21 Feb 2018 13:14:12 GMT
Content-Type: text/plain
Content-Length: 8
Last-Modified: Wed, 21 Feb 2018 13:13:54 GMT
Connection: keep-alive
ETag: "5a8d7092-8"
Accept-Ranges: bytes
test 01
tst.txt
그런 다음 캐시되지 않은 것 같은 내용을 계속 변경합니다 .
무엇이 문제일까요?
캐시 디렉터리:
# ls -ld /var/cache/nginx/
drwx------ 2 www-data www-data 4096 May 23 2017 /var/cache/nginx/
Nginx 프로세스:
# ps -elf | grep nginx
5 S root 1983 1 0 80 0 - 50344 - 12:18 ? 00:00:00 nginx: master process /usr/sbin/nginx -g daemon on; master_process on;
5 S www-data 2292 1983 0 80 0 - 51114 - 13:06 ? 00:00:00 nginx: worker process
5 S www-data 2293 1983 0 80 0 - 51114 - 13:06 ? 00:00:00 nginx: worker process
5 S www-data 2294 1983 0 80 0 - 51114 - 13:06 ? 00:00:00 nginx: worker process
5 S www-data 2295 1983 0 80 0 - 51114 SyS_ep 13:06 ? 00:00:00 nginx: worker process
5 S www-data 2296 1983 0 80 0 - 50344 - 13:06 ? 00:00:00 nginx: cache manager process
0 S root 2351 2050 0 80 0 - 2043 wait_w 13:10 pts/2 00:00:00 less nginx.conf
0 S root 2375 2068 0 80 0 - 3182 - 13:17 pts/4 00:00:00 grep nginx
Nginx
버전:
# nginx -V
nginx version: nginx/1.10.3
built with OpenSSL 1.0.2l 25 May 2017
TLS SNI support enabled
configure arguments: --with-cc-opt='-g -O2 -fPIE -fstack-protector-strong -Wformat -Werror=format-security -fPIC -D_FORTIFY_SOURCE=2' --with-ld-opt='-fPIE -pie -Wl,-z,relro -Wl,-z,now -fPIC' --prefix=/usr/share/nginx --conf-path=/etc/nginx/nginx.conf --http-log-path=/var/log/nginx/access.log --error-log-path=/var/log/nginx/error.log --lock-path=/var/lock/nginx.lock --pid-path=/run/nginx.pid --modules-path=/usr/lib/nginx/modules --http-client-body-temp-path=/var/lib/nginx/body --http-fastcgi-temp-path=/var/lib/nginx/fastcgi --http-proxy-temp-path=/var/lib/nginx/proxy --http-scgi-temp-path=/var/lib/nginx/scgi --http-uwsgi-temp-path=/var/lib/nginx/uwsgi --with-debug --with-pcre-jit --with-ipv6 --with-http_ssl_module --with-http_stub_status_module --with-http_realip_module --with-http_auth_request_module --with-http_v2_module --with-http_dav_module --with-http_slice_module --with-threads --with-http_addition_module --with-http_flv_module --with-http_geoip_module=dynamic --with-http_gunzip_module --with-http_gzip_static_module --with-http_image_filter_module=dynamic --with-http_mp4_module --with-http_perl_module=dynamic --with-http_random_index_module --with-http_secure_link_module --with-http_sub_module --with-http_xslt_module=dynamic --with-mail=dynamic --with-mail_ssl_module --with-stream=dynamic --with-stream_ssl_module --add-dynamic-module=/build/nginx-1.10.3/debian/modules/headers-more-nginx-module --add-dynamic-module=/build/nginx-1.10.3/debian/modules/nginx-auth-pam --add-dynamic-module=/build/nginx-1.10.3/debian/modules/nginx-cache-purge --add-dynamic-module=/build/nginx-1.10.3/debian/modules/nginx-dav-ext-module --add-dynamic-module=/build/nginx-1.10.3/debian/modules/nginx-development-kit --add-dynamic-module=/build/nginx-1.10.3/debian/modules/nginx-echo --add-dynamic-module=/build/nginx-1.10.3/debian/modules/ngx-fancyindex --add-dynamic-module=/build/nginx-1.10.3/debian/modules/nchan --add-dynamic-module=/build/nginx-1.10.3/debian/modules/nginx-lua --add-dynamic-module=/build/nginx-1.10.3/debian/modules/nginx-upload-progress --add-dynamic-module=/build/nginx-1.10.3/debian/modules/nginx-upstream-fair --add-dynamic-module=/build/nginx-1.10.3/debian/modules/ngx_http_substitutions_filter_module
답변1
Nginx의 캐싱 능력에 대한 개념을 오해하신 것 같습니다.
시나리오를 설명한 한 정적 콘텐츠를 제공하고 있습니다. 여기에서 브라우저, CDN 또는 프록시 서버와 같은 다른 캐싱 시스템에 대한 적절한 캐싱 헤더를 설정할 수 있습니다. 또한 하드 디스크의 정적 콘텐츠를 하드 디스크에 캐시하는 경우 성능이 향상되지 않습니다.
Nginx의 캐싱 기능을 사용하려면 원본을 설정해야 합니다. 캐시된 콘텐츠를 가져오는 서비스입니다. HTTP 서버(Nginx 프록시 모듈) 또는 fast_cgi 백엔드(Nginx FastCGI 모듈).
그러나 Nginx 자체에 대한 Proxy_pass 지시문을 처리할 수 있습니다.
server {
listen *:80;
location /content/ {
proxy_cache my_cache;
proxy_pass http://127.0.0.1:8080;
}
}
server {
listen *:8080;
root /var/www/my-site.com;
location /content/ {
expires 3m;
try_files $uri $uri/ =404;
}
}