nginx 缓存策略

本文介绍了Nginx的两种缓存策略:传统策略通过php-fpm和memcache,以及高效策略直接使用nginx与memcache进行交互。高效策略利用OpenResty实现,减少了后端负载,提升了Web应用的性能。通过配置nginx和memcache,实现了请求的快速响应和高并发处理。
摘要由CSDN通过智能技术生成

nginx 缓存策略

这里介绍两种策略:

1、 传统缓存策略: client -> nginx -> fastcgi_pass -> php-fpm:9000 -> memcache -> memcached:11211

缺点:传统缓存策略难以体现 nginx 高并发的特点,因为当 nginx 缓存中没有客户访问请求的响应时,交给 php-fpm 处理,一旦交给后端,nginx 会一直处于等待响应状态,直到后端处理完成,返回响应
在这里插入图片描述

2、高效缓存策略:client -> nginx -> memcache -> memcached:11211
在这里插入图片描述
主要结合 memcache(应用加速方式 memcache 模块 -> memcached:11211 服务)

什么是Memcached?
本质上是通用的免费和开放源代码,高性能,分布式内存对象缓存系统,但旨在通过减轻数据库负载来加速动态Web应用程序。

Memcached是一个内存中键值存储,用于存储来自数据库调用,API调用或页面呈现结果的任意小数据块(字符串,对象)。

Memcached简单而强大。其简单的设计可促进快速部署,易于开发,并解决了大型数据缓存面临的许多问题。它的API适用于大多数流行语言。

1、 传统缓存策略

client -> nginx -> fastcgi_pass -> php-fpm:9000 -> memcache -> memcached:11211

# 编译,安装 PHP 的 memcache 模块
tar zxf memcache-4.0.5.2.tgz 
cd memcache-4.0.5.2

# 安装 memcache 依赖性
yum install -y autoconf

# phpize 用于安装php拓展,生成 ./configure 文件
phpize

# 添加 memcache 模块
./configure --enable-memcache
make
make install

# 配置 PHP 主配置文件,启用 memcache 模块
vim /usr/local/php/etc/php.ini
	 913 extension=memcache 

# 重载 php-fpm 
systemctl reload php-fpm
php -m | grep memcache

# 安装 memcached 服务,默认监控 11211 端口
yum install -y memcached
systemctl start memcached
netstat -anltp | grep memcached

# memcached 服务配置文件
cat /etc/sysconfig/memcached 

# memcache 解压目录中包含,测试文件和监控文件,通过 nginx 发布出去,就可测试和监控。
cd memcache-4.0.5.2
#  测试文件
cp example.php /usr/local/nginx/html/
#  web监控文件
cp memcache.php /usr/local/nginx/html/

# memcached 的web监控文件配置
vim /usr/local/nginx/html/memcache.php
……
define('ADMIN_USERNAME','admin');       // Admin Username
define('ADMIN_PASSWORD','westos');      // Admin Password
……
$MEMCACHE_SERVERS[] = 'localhost:11211'; // add more as an array
#$MEMCACHE_SERVERS[] = 'mymemcache-server2:11211'; // add more as an array
……

示例截图
在这里插入图片描述在这里插入图片描述在这里插入图片描述在这里插入图片描述在这里插入图片描述在这里插入图片描述在这里插入图片描述在这里插入图片描述在这里插入图片描述在这里插入图片描述在这里插入图片描述在这里插入图片描述在这里插入图片描述在这里插入图片描述在这里插入图片描述测试:
在这里插入图片描述在这里插入图片描述

2、 高效缓存

client -> nginx -> memcache -> memcached:11211

由于之前的 nginx 是源码安装,这里用 openrestry 演示 nginx 的高效缓存。

OpenResty 是一个基于 Nginx 与 Lua 的高性能 Web 平台,其内部集成了大量精良的 Lua 库、第三方模块以及大多数的依赖项。用于方便地搭建能够处理超高并发、扩展性极高的动态 Web 应用、Web 服务和动态网关。

#  openrestry:


# 先停止已开启的nginx 服务
systemctl stop nginx

# 安装 openresty
tar axf openresty-1.19.3.1.tar.gz 
cd openresty-1.19.3.1
./configure 
gmake
gmake install

#  配置openresty 中 nginx 配置文件
vim /usr/local/openresty/nginx/conf/nginx.conf
……
user  nginx nginx;
worker_processes  1;
……
            index  index.php index.html index.htm;
……
        location ~ \.php$ {
            root           html;
            fastcgi_pass   127.0.0.1:9000;
            fastcgi_index  index.php;
            #fastcgi_param  SCRIPT_FILENAME  /scripts$fastcgi_script_name;
            include        fastcgi.conf;
        }
……


#  检测语法
/usr/local/openresty/nginx/sbin/nginx -t
#  启动服务
/usr/local/openresty/nginx/sbin/nginx
#  检测端口
netstat -anltp | grep 80

nginx + memcache 高效缓存

#  nginx 高效缓存:

#  拷贝测试文件
cd /usr/local/openresty/nginx/html
cp /root/memcache-4.0.5.2/example.php .

#  配置 nginx 服务
vim /usr/local/openresty/nginx/conf/nginx.conf
#  定义负载均衡器,这里只有 server1 一台服务器,定义一台主机。
……
http {
……
         upstream memcache {
         server 127.0.0.1:11211;
         keepalive 512;
         }
……
# 定义内部访问 memcahce
         location /memc {
         internal;
         memc_connect_timeout 100ms;
         memc_send_timeout 100ms;
         memc_read_timeout 100ms;
         set $memc_key $query_string;
         set $memc_exptime 300;
         memc_pass memcache;
         }
……
# 定义访问策略(client 访问时,先在nginx 缓存中找,没有再访问后面策略,访问到后存到nginx 缓存,下次直接从nginx 缓存中获取)
         location ~ \.php$ {
             set $key $uri$args;
             srcache_fetch GET /memc $key;
             srcache_store PUT /memc $key;
……

#  检测语法
/usr/local/openresty/nginx/sbin/nginx -t
#  重载 nginx 服务 
/usr/local/openresty/nginx/sbin/nginx -s reload

测试:
ab -c10 -n10000  http://172.25.9.1/example.php

示例截图
在这里插入图片描述在这里插入图片描述在这里插入图片描述在这里插入图片描述在这里插入图片描述在这里插入图片描述测试
在这里插入图片描述在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值