openResty实现lnmp缓存的前移

一.什么是OpenResty
OpenResty® 是一个基于 Nginx 与 Lua 的高性能 Web 平台,用于方便地搭建能够处理超高并发、扩展性极高的动态 Web 应用、Web 服务和动态网关。通过汇聚各种设计精良的 Nginx 模块,从而将 Nginx 有效地变成一个强大的通用 Web 应用平台。这样,Web 开发人员和系统工程师可以使用 Lua 脚本语言调动 Nginx 支持的各种 C 以及 Lua 模块,快速构造出足以胜任 10K 乃至 1000K 以上单机并发连接的高性能 Web 应用系统。
OpenResty® 的目标是让你的Web服务直接跑在 Nginx 服务内部,充分利用 Nginx 的非阻塞 I/O 模型,不仅仅对 HTTP 客户端请求,甚至于对远程后端诸如 MySQL、PostgreSQL、Memcached 以及 Redis 等都进行一致的高性能响应。
二.缓存前移的实现(本实验是为了与上篇博客中的实验做对比,基于上边的实验)

1.关闭之前的nginx服务,因为我们要安装可以代替普通nginx的openresty
nginx   -  s  stop
得到一个openresty的压缩包
tar  zxf   openresty-1.13.6.1.tar.gz
cd  openresty-1.13.6.1
ls


./configure   --prefix=/opt/nginx   --with-http_ssl_module  --with-http_stub_status_module  --with-threads   --with-file-aio
gmake
gmake  install
cd   /opt/nginx
cd  nginx
ls
cd  conf
ls
vim  nginx.conf   ##查看里面的内容和nginx的内容美啥不一样
cp    /usr/local/lnmp/nginx/conf/nginx.conf  .
/opt/nginx/nginx/sbin/nginx  -t
/opt/nginx/nginx/sbin/nginx
cd ..
cd  html
ls
cp   /usr/local/lnmp/nginx/html/example.php  .       #将这两个文件复制到当前文件中
cp  /usr/local/lnmp/nginx/html/index.php  .


ls  ##里面有复制过来的东西
cd  ..
cd   conf/
ls
vim  nginx.conf   ##改3处地方   ##修改配置文件

upstream属于handler,只是他不产生自己的内容,而是通过请求后端服务器得到内容,所以才称为upstream(上游)。请求并取得响应内容的整个过
#程已经被封装到nginx内部,所以upstream模块只需要开发若干回调函数,完成构造请求和解析响应等具体的工作。
# nginx将memcache缓存前移,客户端请求到来,先查看nginx缓存

http {
    upstream  memcache {
  server  localhost:11211;
  keepalive  512;
  }
    include       mime.types;
    default_type  application/octet-stream;

#所有请求都通过请求这个location来操作 memcache,memc-nginx-module存取memcache是基于http method语义的,
        #使用http的GET方法表示get、PUT方法表示set、这里我们将/memc设为internal表示只接受内部访问
        #不接收外部http请求,这是为了安全考虑,当然如果需要通过http协议开放外部访问,可以去掉internal然后使用deny和allow指令控制权限。比较重要的是memckey这个变量,它表示以什么作为key,
        #这里我们直接使用Nginx内置的query_string来作为key,$memc_exptime表示缓存失效时间,以秒记。
        #这里统一设为300(5分钟),在实际应用中可以根据具体情况为不同的内容设置不同的过期时间。

 location / {
            root   html;
            index   index.php index.html index.htm;
        }
       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;
   }

为“~ \.php$”这个location配置了缓存,这表示所有以“.php”结尾的请求都会结果被缓存,当然这里只是示例需要,实际中一般不会这么配,而是为特定需要缓存的location配置缓存。

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;
        }

/opt/nginx/nginx/sbin/nginx  -t
/opt/nginx/nginx/sbin/nginx
/opt/nginx/nginx/sbin/nginx   -s    reload
测试:在真机进行压力测试
ab  -c   10  -n 1000  http://172.25.17.11/index.php
ab  -c   10  -n 1000  http://172.25.17.11/example.php  ##明显速度比上次快


 

猜你喜欢

转载自blog.csdn.net/weixin_42709236/article/details/83088907