在LNMP(Linux, Nginx, MySQL, PHP)環境下配置緩存系統可以顯著提高網站性能。以下是配置緩存系統的步驟:
Nginx提供了多種緩存機制,包括proxy_cache和fastcgi_cache。
確保你的Nginx版本支持緩存模塊。大多數現代Nginx版本都支持這些模塊。
編輯Nginx配置文件(通常是/etc/nginx/nginx.conf
或/etc/nginx/conf.d/default.conf
),添加以下內容:
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 {
listen 80;
server_name example.com;
location / {
proxy_pass http://backend;
proxy_cache my_cache;
proxy_cache_valid 200 302 10m;
proxy_cache_valid 404 1m;
add_header X-Proxy-Cache $upstream_cache_status;
}
}
}
如果你使用PHP-FPM,可以配置fastcgi_cache:
http {
fastcgi_cache_path /var/cache/nginx levels=1:2 keys_zone=php_cache:10m max_size=1g inactive=60m use_temp_path=off;
server {
listen 80;
server_name example.com;
location ~ \.php$ {
fastcgi_pass unix:/var/run/php/php7.4-fpm.sock;
fastcgi_cache php_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;
}
}
}
PHP有多種緩存擴展,如OPcache、APCu和Memcached。
OPcache是PHP內置的緩存擴展,通常默認啟用。你可以在php.ini
文件中調整其設置:
[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是另一個PHP緩存擴展,適用于用戶數據緩存。安裝APCu:
sudo apt-get install php-apcu
在php.ini
文件中啟用APCu:
[apcu]
extension=apcu.so
apcu.enable_cli=1
apcu.shm_size=32M
Memcached是一個高性能的分布式內存對象緩存系統。安裝Memcached:
sudo apt-get install memcached
啟動Memcached服務:
sudo systemctl start memcached
在PHP中使用Memcached擴展:
$memcached = new Memcached();
$memcached->addServer('127.0.0.1', 11211);
$key = 'my_cache_key';
$data = $memcached->get($key);
if (!$data) {
$data = 'some expensive data';
$memcached->set($key, $data, 3600); // Cache for 1 hour
}
echo $data;
MySQL提供了查詢緩存和InnoDB緩沖池等緩存機制。
編輯MySQL配置文件(通常是/etc/mysql/my.cnf
或/etc/mysql/mysql.conf.d/mysqld.cnf
),添加以下內容:
[mysqld]
query_cache_type=1
query_cache_size=64M
重啟MySQL服務:
sudo systemctl restart mysql
InnoDB緩沖池是MySQL的主要緩存機制。編輯MySQL配置文件,調整以下參數:
[mysqld]
innodb_buffer_pool_size=1G
innodb_buffer_pool_instances=8
重啟MySQL服務:
sudo systemctl restart mysql
配置緩存系統后,監控其性能并進行優化是必要的??梢允褂霉ぞ呷?code>nginx-stats、php-fpm-stat
和memcached-tool
來監控緩存命中率和性能指標。
通過以上步驟,你可以在LNMP環境下配置一個高效的緩存系統,顯著提升網站性能。