如何配置Nginx的FastCGI缓存验证?

  

Nginx提供了FastCGI缓存模块,可以缓存FastCGI应答内容,从而提升Web页面的访问速度。在使用FastCGI缓存的时候,我们需要检查缓存内容是否已经过期,并且需要验证缓存内容是否与源服务器的内容一致。

以下是如何配置Nginx的FastCGI缓存验证的完整攻略:

步骤1:启用FastCGI缓存

首先,我们需要在Nginx配置文件中开启FastCGI缓存。

http {
    # 设置FastCGI应答内容的缓存路径和最大缓存时间
    fastcgi_cache_path /var/cache/nginx levels=1:2 keys_zone=my_cache:10m inactive=60m;

    # 配置FastCGI应用的代理服务器
    upstream php-fpm {
        server unix:/var/run/php-fpm.sock;
    }

    # 配置Nginx缓存设置
    proxy_cache_path /var/cache/nginx/www-data levels=1:2 keys_zone=cache_zone:10m inactive=60m;

    # 配置Nginx服务
    server {
        listen 80;
        server_name example.com;

        # 开启代理请求头
        proxy_set_header Host $http_host;

        # 启用FastCGI缓存
        fastcgi_cache_key "$scheme$request_method$host$request_uri";
        fastcgi_cache_bypass $http_pragma;
        fastcgi_cache_revalidate on;
        fastcgi_cache_min_uses 1;
        fastcgi_cache_valid 200 302 10m;
        fastcgi_cache_valid 404      1m;
        fastcgi_cache_valid 500      1m;

        # 配置FastCGI缓存使用的代理服务器
        location ~ (\.php|\.phtml)$ {
            fastcgi_pass php-fpm;

            # 启用FastCGI缓存
            fastcgi_cache my_cache;
            fastcgi_cache_lock on;
            fastcgi_cache_lock_timeout 5s;
            fastcgi_cache_use_stale error timeout updating http_500 http_503;
            fastcgi_cache_valid 200 60m;
            fastcgi_cache_valid 404 1m;
            fastcgi_cache_valid 500 1m;

            # 验证FastCGI缓存内容是否过期
            add_header X-Cache-Status $upstream_cache_status;

            # 验证FastCGI缓存内容与源服务器内容是否一致
            fastcgi_cache_valid 200 10m; # 设置FastCGI应答内容与源服务器内容的最长验证时间
            fastcgi_cache_background_update on;
            fastcgi_cache_revalidate on;
            fastcgi_cache_min_uses 3;
        }
    }
}

在上述代码中,我们设置了FastCGI应答内容的缓存路径和最大缓存时间,然后配置了代理服务器和Nginx缓存设置。在配置服务器时,我们开启了FastCGI缓存,并且配置了FastCGI缓存使用的代理服务器。最后,我们在FastCGI配置中增加了FastCGI缓存验证的内容。

步骤2:验证FastCGI缓存

在配置完FastCGI缓存后,我们需要验证FastCGI缓存是否生效。我们可以使用curl工具访问Nginx服务器并查看缓存验证相关的HTTP头信息。例如:

$ curl -I -H 'Pragma: no-cache' http://example.com/index.php

上述命令中,我们使用-c来发送HEAD请求,-H参数向请求中添加了Pragma: no-cache头信息。这个头信息将使得FastCGI缓存失效,从而重新获取FastCGI应答内容。在运行完上述命令后,我们可以查看到类似下面的相关HTTP头信息:

HTTP/1.1 200 OK
Server: nginx/1.18.0 (Ubuntu)
Date: Fri, 10 Sep 2021 06:19:10 GMT
Content-Type: text/html; charset=UTF-8
Connection: keep-alive
Cache-Control: no-store, no-cache, must-revalidate
X-Cache-Status: MISS
...

在上述HTTP头信息中,我们可以看到X-Cache-Status头信息的值为MISS,这表示FastCGI缓存没有生效,而是直接从FastCGI服务器获取应答内容。如果FastCGI缓存正常工作,那么值为HIT。

步骤3:增加FastCGI缓存验证的代码块

接下来,我们需要在PHP脚本的代码中增加FastCGI缓存验证的代码块,从而判断缓存内容是否过期,以及是否与源服务器内容一致。

<?php
// 缓存验证
header('Cache-Control: public, max-age=60');
header('Expires: ' . gmdate('D, d M Y H:i:s', time() + 60) . ' GMT');
$max_age = 60 * 60 * 24;
if (isset($_SERVER['HTTP_CACHE_CONTROL']) && $_SERVER['HTTP_CACHE_CONTROL'] === 'no-cache') {
    $max_age = 0;
}
header('Cache-Control: public, max-age=' . $max_age);

if (function_exists('opcache_invalidate')) {
    opcache_invalidate(__FILE__);
}

在上述代码中,我们使用了header函数来设置缓存相关的HTTP头信息,并使用opcache_invalidate函数来使得PHP脚本中使用的缓存失效。这些代码块可以验证FastCGI缓存是否过期,并且可以保证缓存内容与源服务器的内容一致。

示例1:使用FastCGI缓存的WordPress网站

以下是如何使用FastCGI缓存来加速WordPress网站的示例。

首先,我们需要安装必要的PHP扩展和Nginx FastCGI缓存模块。

$ sudo apt-get install php-fpm php-apcu nginx

$ sudo apt-get install nginx nginx-module-cache-purge

接下来,我们需要修改Nginx配置文件。在以下示例中,我们使用了WordPress默认的Nginx配置文件,并且在配置文件中增加了FastCGI缓存相关的内容。

http {
    # 启用FastCGI缓存
    fastcgi_cache_path /var/cache/nginx levels=1:2 keys_zone=wordpress_cache:100m inactive=60m;
    fastcgi_cache_key "$scheme$request_method$host$request_uri";

    # 配置WordPress站点
    server {
        listen 80;
        server_name example.com;

        root /var/www/example.com/;

        # 启用FastCGI缓存
        location / {
            try_files $uri $uri/ /index.php?q=$uri&$args;
            expires 1h;

            fastcgi_cache_bypass $http_pragma;
            fastcgi_cache_revalidate on;
            fastcgi_cache_min_uses 1;

            set $skipcache 0;
            if ($http_cookie ~* "comment_author_|wordpress_(?!test_cookie)|wp-postpass_" ) {
              set $skipcache 1;
            }

            # 偏移量和PostID缓存
            fastcgi_cache_valid 404      1m;
            fastcgi_cache_valid 200 60s;

            # 验证FastCGI缓存内容是否过期
            add_header X-Cache-Status $upstream_cache_status;

            # 验证FastCGI缓存内容与源服务器内容是否一致
            fastcgi_cache_valid 200 10m;
        }

        # WordPress PHP代码
        include /etc/nginx/php.conf;
    }
}

在上述代码中,我们指定了FastCGI缓存路径和最大缓存时间,并且在WordPress站点的配置中启用了FastCGI缓存。我们还增加了FastCGI缓存验证的代码块。最后,我们使用了/etc/nginx/php.conf文件来配置WordPress的PHP执行环境。

示例2:使用FastCGI缓存的Django网站

以下是如何使用FastCGI缓存来加速Django网站的示例。

首先,我们需要安装必要的Python扩展和Nginx FastCGI缓存模块。

$ sudo apt-get install python3 python3-pip python3-dev python3-setuptools python3-wheel python3-cffi python3-virtualenv nginx

$ sudo apt-get install nginx nginx-module-cache-purge

接下来,我们需要在Django项目的设置文件中增加FastCGI缓存相关的代码。在以下示例中,我们使用了Django默认的settings.py文件,并在文件中增加了FastCGI缓存相关的代码。

CACHES = {
    'default': {
        'BACKEND': 'django.core.cache.backends.filebased.FileBasedCache',
        'LOCATION': '/var/cache/django_cache',
        'OPTIONS': {
            'MAX_ENTRIES': 1000,
            'CULL_FREQUENCY': 3,
        }
    }
}

MIDDLEWARE_CLASSES = [
    'django.middleware.cache.UpdateCacheMiddleware',
    'django.middleware.common.CommonMiddleware',
    'django.middleware.cache.FetchFromCacheMiddleware',
]

在上述代码中,我们使用了Django自带的缓存系统,并在中间件中启用了FastCGI缓存。我们还指定了FastCGI缓存的最大条目数和清除频率。最后,我们指定了缓存的位置。

接下来,我们需要在Nginx配置文件中配置FastCGI缓存。在以下示例中,我们使用了Django默认的Nginx配置文件,并在文件中增加了FastCGI缓存相关的代码。

http {
    # 启用FastCGI缓存
    fastcgi_cache_path /var/cache/nginx levels=1:2 keys_zone=django_cache:10m inactive=60m;
    fastcgi_cache_key "$scheme$request_method$host$request_uri";

    # 启用Django站点
    server {
        listen 80;
        server_name example.com;

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

        root /var/www/example.com/;

        # 启用FastCGI缓存
        location / {
            uwsgi_pass unix:///var/run/example.sock;
            include uwsgi_params;

            fastcgi_cache_bypass $http_pragma;
            fastcgi_cache_revalidate on;
            fastcgi_cache_min_uses 1;

            # 偏移量和缓存时间
            fastcgi_cache_valid 404      1m;
            fastcgi_cache_valid 200 60s;

            # 验证FastCGI缓存内容是否过期
            add_header X-Cache-Status $upstream_cache_status;

            # 验证FastCGI缓存内容与源服务器内容是否一致
            fastcgi_cache_valid 200 10m;
        }
    }
}

在上述代码中,我们指定了FastCGI缓存路径和最大缓存时间,并且在Django站点的配置中启用了FastCGI缓存。我们还增加了FastCGI缓存验证的代码块,以及uwsgi_pass指令。最后,我们使用了uwsgi_params文件来配置Django和Nginx的通信。

相关文章