memcache与OpenResty-----缓存模块

本文介绍了Memcache的工作流程,强调其作为内存对象缓存系统提高读取速度的优势。同时,详细说明了如何在PHP环境中配置和使用Memcache。此外,文章还探讨了OpenResty作为基于NGINX的Web平台,如何利用Lua脚本提供高性能的Web应用服务,特别是在处理高并发和数据库访问方面的能力。OpenResty被多家知名公司广泛采用,证明了其在构建高性能Web服务方面的有效性。
摘要由CSDN通过智能技术生成

MemCache工作流程:先检查客户端的请求数据是否在memcached中,如有,直接把请求数据返回,不再对数据库进行任何操作;如果请求的数据不在memcached中,就去查数据库,把从数据库中获取的数据返回给客户端,同时把数据缓存一份到memcached中(memcached客户端不负责,需要程序明确实现);每次更新数据库的同时更新memcached中的数据,保证一致性;当分配给memcached内存空间用完之后,会使用LRU(Least Recently Used,最近最少使用)策略加上到期失效策略,失效数据首先被替换,然后再替换掉最近未使用的数据。
Memcache是一个高性能的分布式的内存对象缓存系统,通过在内存里维护一个统一的巨大的hash表,它能够用来存储各种格式的数据,包括图像、视频、文件以及数据库检索的结果等。简单的说就是将数据调用到内存中,然后从内存中读取,从而大大提高读取速度。

vim ~/.bash_profile   							##添加环境变量
	PATH=$PATH:$HOME/bin:/usr/local/lnmp/mysql/bin:/usr/local/lnmp/php/bin
source ~/.bash_profile                          ##环境变量生效	
cd memcache-2.2.5
phpize
yum install autoconf                              ##安装自动生成编译

memcache目录中本来没有configure文件,所以没法编译。phpize是用来扩展php扩展模块的,通过phpize可以建立php的外挂模块,比如你想在原来编译好的php中加入memcached或者ImageMagick等扩展模块,可以使用phpize。或者说,phpize的作用可以这样理解:侦测环境(phpize工具是在php安装目录下,基于这点phpize对应了当时的php环境,所以是要根据该php的配置情况生成对应的configure文件),建立一个configure文件。必须在一个目录下去运行phpize。那么phpize就知道你的的环境是哪个目录,并且configure文件建立在该目录下,会生成configure文件。

./configure                                   ##编译
make && make install                          ##	编译安装
vim /usr/local/lnmp/php/etc/php.ini       ##编译php初始化文件
	873 extension=memcache.so
/etc/init.d/php-fpm reload                ##重启php服务
php -m | grep memcache
yum install -y memcached                  ##安装memcache
cat /etc/sysconfig/memcached              ## 查看memcache信息
	PORT="11211"
	USER="memcached"
	MAXCONN="1024" 		 ##最大链接数1024
	CACHESIZE="64"
	OPTIONS=""			 ##如果写为OPTIONS="-l 127.0.0.1" 即为只监听本机的11211端口
systemctl start memcached                 ##开启memcache
yum install -y telnet                     ##安装telnet服务以获得键值
telnet localhost 11211                    ##监听本地11211端口
cp memcache.php example.php /usr/local/lnmp/nginx/html/
cd /usr/local/lnmp/nginx/html/            ##编辑memcache初始化界面
vim memcache.php
	define('ADMIN_USERNAME','memcache');    ## Admin Username(自定义)
	define('ADMIN_PASSWORD','westos');      ## Admin Password(自定义)
	$MEMCACHE_SERVERS[] = '172.25.30.1:11211'; // add more as an array
	##只留一个主机,memcache没有转发或负载均衡机制,只能一个一个添加(因为本实验只有一个主机,其实可以添加多个)

测试:

http://172.25.30.1/memcache.php
ab -c 10 -n 5000 http://172.25.30.1/example.php       ##压力测试,10人5000次测试
ab -c 10 -n 5000 http://172.25.30.1/index.php

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
可以看出添加了memcache的网络页面压力测试下所需时间较短,原始页面所需时间较长,由于其没有缓存。并且缓存命中率较高。
OpenResty:
OpenResty(又称:ngx_openresty) 是一个基于 NGINX 的可伸缩的 Web平台,由中国人章亦春发起,提供了很多高质量的第三方模块。
OpenResty 是一个强大的 Web 应用服务器,Web 开发人员可以使用 Lua 脚本语言调动 Nginx 支持的各种 C 以及Lua 模块,更主要的是在性能方面,OpenResty可以 快速构造出足以胜任 10K 以上并发连接响应的超高性能 Web 应用系统。360,UPYUN,阿里云,新浪,腾讯网,去哪儿网,酷狗音乐等都是 OpenResty 的深度用户。OpenResty 的目标是让你的 Web 服务直接跑在 Nginx 服务内部,充分利用 Nginx 的非阻塞 I/O 模型,不仅仅对 HTTP 客户端请求,甚至于对远程后端诸如 MySQL,PostgreSQL,~Memcaches 以及 ~Redis 等都进行一致的高性能响应。
所以对于一些高性能的服务来说,可以直接使用 OpenResty 访问 Mysql或Redis等,而不需要通过第三方语言(PHP、Python、Ruby)等来访问数据库再返回,这大大提高了应用的性能。

nginx -s stop                         ##关闭nginx服务
tar zxf openresty-1.13.6.1.tar.gz     ##解压openresty
cd openresty-1.13.6.1
./configure --prefix=/usr/local/openresty   ##编译到制定路径
gmake && gmake install                      ##编译,编译安装
cd /usr/local/lnmp/nginx/html/
vim /usr/local/openresty/nginx/conf/nginx.conf    ##编写openresty下nginx配置文件
/usr/local/openresty/nginx/sbin/nginx -t          ##检测nginx
/usr/local/openresty/nginx/sbin/nginx             ##开启nginx
vim /usr/local/openresty/nginx/conf/nginx.conf
upstream memcache {
        server localhost:11211;
        keepalive 512;
    }
location /memc {
            internal;  # 只接收内部访问,不接受外部http访问。比较安全
            memc_connect_timeout 100ms;
            memc_send_timeout 100ms;   ##后端服务器数据回传时间
            memc_read_timeout 100ms;   ##连接成功后,后端服务器响应时间
            set $memc_key $query_string;
            set $memc_exptime 300;
            memc_pass memcache;
        }

        location ~ \.php$ {
            set $key $uri$args;
            srcache_fetch GET /memc $key;
            srcache_store PUT /memc $key;
            root           html;
            fastcgi_pass   127.0.0.1:9000;
            fastcgi_index  index.php;
            #fastcgi_param  SCRIPT_FILENAME  /scripts$fastcgi_script_name;
            include        fastcgi.conf;
        }

测试:

ab -c 10 -n 5000 http://172.25.30.1/example.php       ##压力测试
ab -c 10 -n 5000 http://172.25.30.1/index.php

在这里插入图片描述
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值