linux

LNMP中如何配置缓存提高访问速度

小樊
84
2025-02-15 17:12:17
栏目: 编程语言

在LNMP(Linux, Nginx, MySQL, PHP)架构中,配置缓存可以显著提高网站访问速度。以下是一些常见的缓存配置方法:

1. Nginx 缓存

Nginx 提供了多种缓存机制,包括代理缓存和FastCGI缓存。

代理缓存

在 Nginx 配置文件中添加以下内容来启用代理缓存:

http {
    proxy_cache_path /var/cache/nginx levels=1:2 keys_zone=my_cache:10m max_size=1g inactive=60m use_temp_path=off;

    server {
        location / {
            proxy_pass http://backend;
            proxy_cache my_cache;
            proxy_cache_valid 200 302 10m;
            proxy_cache_valid 404 1m;
        }
    }
}

FastCGI 缓存

在 Nginx 配置文件中添加以下内容来启用 FastCGI 缓存:

http {
    fastcgi_cache_path /var/cache/nginx levels=1:2 keys_zone=my_fcgi_cache:10m max_size=1g inactive=60m use_temp_path=off;

    server {
        location ~ \.php$ {
            fastcgi_pass unix:/var/run/php/php7.4-fpm.sock;
            fastcgi_cache my_fcgi_cache;
            fastcgi_cache_valid 200 302 10m;
            fastcgi_cache_valid 404 1m;
            include fastcgi_params;
            fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
            fastcgi_param PATH_INFO $fastcgi_path_info;
        }
    }
}

2. PHP 缓存

PHP 提供了多种缓存扩展,如 OPcache、APCu 和 Memcached。

OPcache

OPcache 是 PHP 的内置扩展,可以加速 PHP 脚本的编译和执行。在 php.ini 文件中启用 OPcache:

[opcache]
zend_extension=opcache.so
opcache.enable=1
opcache.memory_consumption=128
opcache.interned_strings_buffer=8
opcache.max_accelerated_files=4000
opcache.revalidate_freq=60

APCu

APCu 是一个用户空间缓存扩展,适用于存储和检索数据。在 php.ini 文件中启用 APCu:

[apcu]
extension=apcu.so
apcu.enable_cli=1
apcu.shm_size=32M

Memcached

Memcached 是一个分布式内存对象缓存系统。首先需要安装 Memcached 服务器和 PHP 扩展:

sudo apt-get install memcached php-memcached

然后在 php.ini 文件中启用 Memcached 扩展:

[memcached]
extension=memcached.so

在 PHP 代码中使用 Memcached:

$memcached = new Memcached();
$memcached->addServer('127.0.0.1', 11211);
$memcached->set('key', 'value', 3600); // 缓存 1 小时
$value = $memcached->get('key');

3. MySQL 缓存

MySQL 提供了查询缓存和 InnoDB 缓存池。

查询缓存

在 MySQL 配置文件(通常是 /etc/mysql/my.cnf/etc/my.cnf)中启用查询缓存:

[mysqld]
query_cache_type=1
query_cache_size=64M

InnoDB 缓存池

InnoDB 缓存池的大小可以通过以下参数调整:

[mysqld]
innodb_buffer_pool_size=1G
innodb_buffer_pool_instances=8

总结

通过配置 Nginx 缓存、PHP 缓存和 MySQL 缓存,可以显著提高 LNMP 架构的网站访问速度。根据具体需求选择合适的缓存策略,并进行相应的配置。

0
看了该问题的人还看了