web-dev-qa-db-ja.com

他のnginxサーバーの前にあるnginxリバースプロキシキャッシュを無効にする方法は?

私は単一のIPアドレスでProxmoxサーバーを実行しており、要求されたホストに応じてコンテナーにHTTP要求をディスパッチします。

Proxmox側でnginxを使用してHTTPリクエストをリッスンし、proxy_passに従ってリクエストをディスパッチするために、さまざまなserverブロックでserver_nameディレクティブを使用しています。

私のコンテナーはUbuntuで実行され、nginxインスタンスも実行しています。

完全に静的な特定のWebサイトでのキャッシュに問題があります。nginxは、ファイルの更新後、次の状態になるまで古いコンテンツを提供し続けます。

  • / var/cache/nginx /をクリアし、nginxを再起動します
  • またはこのサーバーにproxy_cache offを設定し、設定を再読み込みします

これが私の設定の詳細です:

サーバー(proxmox):

/ etc/nginx/nginx.conf

user www-data;
worker_processes 8;
pid /var/run/nginx.pid;

events {
    worker_connections 768;
    # multi_accept on;
    use epoll;
}

http {

    ##
    # Basic Settings
    ##

    sendfile on;
    #tcp_nopush on;
    tcp_nodelay on;
    #keepalive_timeout 65;
    types_hash_max_size 2048;
    server_tokens off;

    # server_names_hash_bucket_size 64;
    # server_name_in_redirect off;

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

    client_body_buffer_size 1k;
    client_max_body_size    8m;
    large_client_header_buffers 1 1K;
    ignore_invalid_headers on;

    client_body_timeout 5;
    client_header_timeout 5;
    keepalive_timeout 5 5;
    send_timeout 5;
    server_name_in_redirect off;

    ##
    # Logging Settings
    ##

    access_log /var/log/nginx/access.log;
    error_log /var/log/nginx/error.log;

    ##
    # Gzip Settings
    ##

    gzip on;
    gzip_disable "MSIE [1-6]\.(?!.*SV1)";

    gzip_vary on;
    gzip_proxied any;
    gzip_comp_level 6;
    # gzip_buffers 16 8k;
    gzip_http_version 1.1;
    gzip_types text/plain text/css application/json application/x-javascript text/xml application/xml application/xml+rss text/javascript;


    limit_conn_zone $binary_remote_addr zone=gulag:1m;
    limit_conn gulag 50;

    ##
    # Virtual Host Configs
    ##

    include /etc/nginx/conf.d/*.conf;
    include /etc/nginx/sites-enabled/*;
}

/ etc/nginx/conf.d/proxy.conf:

proxy_redirect          off;
proxy_set_header        Host            $Host;
proxy_set_header        X-Real-IP       $remote_addr;
proxy_set_header        X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_hide_header       X-Powered-By;
proxy_intercept_errors  on;
proxy_buffering         on;

proxy_cache_key         "$scheme://$Host$request_uri";
proxy_cache_path        /var/cache/nginx levels=1:2 keys_zone=cache:10m inactive=7d max_size=700m;

/ etc/nginx/sites-available/my-domain.conf:

server {
    listen 80;
    server_name .my-domain.com;

    access_log off;

    location / {
            proxy_pass http://my-domain.local:80/;
            proxy_cache cache;
            proxy_cache_valid 12h;
            expires 30d;
            proxy_cache_use_stale error timeout invalid_header updating;
    }
}

コンテナ(my-domain.local):

nginx.conf:(すべてがメインの構成ファイル内にあります-すぐに完了します...)

user  www-data;
worker_processes  1;

error_log  logs/error.log;

events {
    worker_connections  1024;
}


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

    sendfile        on;
    #tcp_nopush     on;

    keepalive_timeout  65;

    gzip  off;

    server {
        listen       80;
        server_name  .my-domain.com;
        root /var/www;

        access_log  logs/Host.access.log;
    }
}

自分の質問を投稿する前に、多くのブログ投稿と回答を読みました...ほとんどの回答はsendfile off;を設定することをお勧めしますが、それは私にとってはうまくいきませんでした。私は他の多くのことを試しました、私の設定を再確認しました、そしてすべては問題ないようです。

だから私は私がnginxのキャッシュがそれが意図されていない何かをすることを期待していないのかどうか疑問に思っています...?

基本的に、コンテナー内の静的ファイルの1つが更新されると、リバースプロキシのキャッシュが無効になり、ブラウザーが要求したときにファイルの新しいバージョンをブラウザーが取得すると思いました...

しかし、私は今、多くのことを誤解している感情を持っています。

とりわけ、serverのnginxがcontainer変更されましたか?ディレクティブproxy_header_pass(または同様のもの)を見たことがあります。これを使用して、コンテナからのnginxインスタンスに、更新されたファイルについてProxmoxのインスタンスに何らかの方法で通知させますか?

この期待は単なる夢ですか、それとも現在のアーキテクチャでnginxを使用して実現できますか?

5
Olivier Lance

あなたがしたいことは不可能です。プロキシによってURLがキャッシュされると、キャッシュの有効期限が切れるまで、このURLのバックエンドに対してそれ以上のクエリは行われません。バックエンドでファイルが更新されたことをプロキシが認識する方法はありません。

Varnishのような一部の高度なキャッシュは、ヘッダーまたはPURGEリクエストを通じて無効化要求を処理できます。たとえば、ユーザーがメディアウィキページを編集すると、POSTリクエストへの応答には、記事のキャッシュエントリを無効にするヘッダーが含まれます。ただし、このプロセスは、リソースがURLを使用して変更された場合にのみ機能します呼び出し:バックエンドの静的ファイルを変更しても、プロキシキャッシュに通知されません。

Luaモジュールを通じてnginxにこのタイプの無効化を実装できます: http://syshero.org/post/68479556365/nginx-passive-cache-invalidation

3

この機能は、スタンドアロンキャッシュ(memcachedやredisなど)を使用して実現できます。 nginxには、それらを操作するためのモジュールがあります。キャッシュキーに関するいくつかの規則が必要になります(たとえば、ユーザーのCookieとURLからキーを作成します)。この場合、無効化や更新など、キャッシュアイテムをバックエンドから制御できます。

1
muodov