nginxキャッシュ構成

WBOY
リリース: 2016-07-30 13:31:46
オリジナル
980 人が閲覧しました

nginxキャッシュ設定

Nginxはバージョン0.7.48からSquidのようなキャッシュ機能をサポートしています。このキャッシュは URL と関連する組み合わせをキーとして扱い、md5 エンコードとハッシュを使用してハードディスクに保存するため、あらゆる URL リンクをサポートでき、404/301/302 などの 200 以外のステータス コードもサポートします。現在の公式 Nginx Web キャッシュ サービスは、指定された URL またはステータス コードの有効期限を設定することしかできず、指定されたキャッシュ ページを手動でクリアするための Squid のような PURGE 命令をサポートしていませんが、サードパーティの Nginx モジュールを通じて、指定した URL のキャッシュをクリアできます。 IT Network、http://www.it.net.cn

Nginx の Web キャッシュ サービスは、主に proxy_cache 関連の命令セットと fastcgi_cache 関連の命令セットで構成され、前者はバックエンドに影響を与えるリバース プロキシに使用されます。コンテンツ ソース サーバーのキャッシュ。後者は主に FastCGI 動的プログラムのキャッシュに使用されます。どちらの機能も基本的には同じです。

最新の Nginx 0.8.32 バージョンでは、proxy_cache と fastcgi_cache が比較的完成されており、サードパーティの ngx_cache_purge モジュール (指定された URL のキャッシュをクリアするために使用されます) と組み合わせることで、Squid を完全に置き換えることができます。 Nginx の proxy_cache キャッシュ機能を本番環境で 2 か月以上使用しています。非常に安定しており、速度も Squid に劣りません。

機能面では、Squidが持つWebキャッシュ高速化機能や指定URLキャッシュクリア機能はNginxに既に備わっています。パフォーマンスの点では、Nginx のマルチコア CPU の使用率は Squid よりもはるかに優れています。さらに、Nginx は、リバース プロキシ、ロード バランシング、ヘルス チェック、バックエンド サーバーのフェイルオーバー、書き換え、使いやすさの点で Squid よりもはるかに強力です。これにより、1台のNginxを「負荷分散サーバー」と「Webキャッシュサーバー」として同時に利用できるようになります。

1. Linux で Nginx ロード バランシングとキャッシュ サーバーをコンパイルしてインストールします:
Linux 学習、http://linux.it.net.c

ulimit -SHn 65535
wget ftp://ftp.csx 。 cam.ac.uk/pub/software/programming/pcre/pcre-8.00.tar.gz
tar zxvf pcre-8.00.tar.gz


cd pcre-8.00/
./configure
make && make install
cd 。 ./

wget http://labs.frickle.com/files/ngx_cache_purge-1.0.tar.gz
tar zxvf ngx_cache_purge-1.0.tar.gz

wget http://nginx.org/download/nginx-0.8.32。 tar.gz
tar zxvf nginx-0.8.32.tar.gz
cd nginx-0.8.32/
./configure --user=www --group=www --add-module=../ngx_cache_purge-1.0 - -prefix=/usr/local/nginx --with-http_stub_status_module --with-http_ssl_module
make && make install
cd ../ ITネットワーク、http://www.it.net.cn

2、 /usr/local/nginx/conf/nginx.conf 設定ファイルの内容は次のとおりです:
IT Network, http://www.it.net.cn

user www www;

worker_processes 8;

error_log / usr/local/nginx/logs/nginx_error.log crit; IT ネットワーク、http://www.it.net.cn

pid /usr/local/nginx/logs/nginx.pid;

#このプロセスで開くことができるファイル記述子の最大値を指定します
worker_rlimit_nofile 65535; /octet-stream ; http:// linux.it.net.cn


#charset utf-8;
server_names_hash_bucket_size 128;
client_header_buffer_size 32k;
large_client_header_buffers 4 32k;

client_max_body_size 300m;


sendfile on;
tcp_nopush on;
keepalive_timeout 60 ; ITネットワーク、http://www.it.net.cn


tcp_nolay on;

client_body_buffer_size 512k;
proxy_connect_timeout 5;
proxy_read_timeout 60 ;
proxy_send_timeout 5;
proxy_buffer_size 16k;
proxy_buffers 4 64k;

proxy_busy_buffers_size 128k;

proxy_temp_file_write_size 128k; IT ネットワーク、http://www.it.net。 cn

gzip on;

gzip_min_length 1k;

g zip_buffers 4 16k;
gzip_http_version 1.1;
gzip_comp_level 2;
gzip_types text/plain application/x-javascript text/css application/xml;
gzip_vary on;

#注意: proxy_temp_path と proxy_cache_path で指定されたパスは同じパーティション内にある必要があります
proxy_temp_path /data0/proxy_temp_dir;
#Web キャッシュ領域の名前を cache_one、メモリ キャッシュ領域のサイズを 200MB、まだ保存されていないコンテンツを設定します1 日以内にアクセスされたデータは自動的に消去され、ハードディスクのキャッシュ容量は 30GB になります。 proxy_cache_path /data0 /proxy_cache_dirレベル= 1:2 keys_z inactive = 1d max_size = 30g; 1 max_fails=2fail_timeout=30s;
サーバー 192.168.8.45:80weight=1max_fails=2fail_timeout=30s;
}

サーバー
{
listen 80;
サーバー名 www.it.net.cn 192.168.8.42;

Index Index.html Index.htm;

root /data0/htdocs/www;

location /
{
フェイルオーバー用の別のサーバー。
proxy_next_upstream http_502 http_504 エラー タイムアウト valid_header;

proxy_cache queue_one;

#HTTP ステータス コードごとに異なるキャッシュ時間を設定します
' ' s ' s 's ' t ‐ ‐ ‐ proxy_cache #ドメイン名を結合する、URI、およびパラメーターを使用して Web キャッシュのキー値を形成し、キャッシュのコンテンツを第 2 レベルのキャッシュ ディレクトリに保存します
proxy_set_header Host
;
proxy_set_header X-Forwarded-For $remote_addr;
proxy_pass http://back end_server;
Expires 1d;
}
# URL が http://192.168 であるとします。 .8.42/test.txt http://192.168.8.42/purge/test.txt キャッシュにアクセスすると、URL をクリアできます。
Location ~ /purge(/.*)

{
#指定された IP または IP 範囲のみを設定して URL キャッシュをクリアします。
127.0.0.1 を許可;
192.168.0.0/16 を許可;
すべて拒否; proxy_cache_purge queue_one $host$1$is_args $args;
}
# 拡張子が .php、.jsp、.cgi で終わる動的アプリケーションはキャッシュされません。
location ~ .*.(php|jsp|cgi)?$
{
proxy_set_header ホスト $host;
proxy_set_header X-Forwarded-For $remote_addr;
proxy_pass http://backend_server;
}
access_log off;
}


Linux 学習、http://linux.it.net.cn




上記では、関連する内容を含め、nginx のキャッシュ構成を紹介しています。PHP チュートリアルに興味のある友人に役立つことを願っています。


関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート