LNMP集群缓存优化&添加动态请求

php增加memcache模块

将phpize加入环境变量

vim  ~/.bash_profile
PATH=$PATH:$HOME/bin:/usr/local/lnmp/mysql/bin:/usr/local/lnmp/php/bin
source ~/.bash_profile 

编译memcache

yum install autoconf
tar zxf memcache-2.2.5.tgz 
cd memcache-2.2.5 
phpize  
./configure
make && make install

memcache目录中本来没有configure文件,所以没法编译,需要运行phpize,会生成configure文件

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

修改php主配置文件,增加memcache模块,重新加载php

vim /usr/local/lnmp/php/etc/php.ini
873 extension=memcache.so

/etc/init.d/php-fpm reload

php -m | grep memcache 可以查看是否加载成功
php -m | grep mysql

安装并启动memcached

yum install -y memcached

vim /etc/sysconfig/memcached 
PORT="11211"
USER="memcached"
MAXCONN="1024" ##最大链接数1024
CACHESIZE="64"
OPTIONS="" 

/etc/init.d/memcached start
如果写为OPTIONS="-l 127.0.0.1" 即为只监听本机的11211端口

telnet测试

yum install -y telnet
telnet localhost 11211
stats

quit	#退出
telnet输出如下

stats(查看状态)
set name 0 0 6 (0编号 0缓存时间(此处0代表不限制时间) 6限制字符数) key:name;编号:0;缓存时间:0(永久)valuce值:6位
westosawd
CLIENT_ERROR bad data chunk
ERROR
westos
STORED
get name
VALUE name 0 6
westos
END
delete name
DELETED
set name 0 5 6		##设置缓存5s,过5s再获取name,为空
westos
STORED
get name
END

拷贝php页面到nginx默认发布目录

cp memcache.php example.php /usr/local/lnmp/nginx/html/

vim memcache.php
define('ADMIN_USERNAME','memcache');    ## Admin Username(自定义)
define('ADMIN_PASSWORD','westos');      ## Admin Password(自定义)

$MEMCACHE_SERVERS[] = '172.25.230.5:11211'; // add more as an array
#$MEMCACHE_SERVERS[] = 'mymemcache-server2:11211'; // add more as an array

只留一个主机,memcache没有转发或负载均衡机制,只能一个一个添加(因为本实验只有一个主机,其实可以添加多个)

memcache.php监控页面;example.php测memcache命中率

测试

访问http://172.25.230.5/memcache.php
输入用户名密码,可以查看memcache命中率,使用http://172.25.230.5/example.php不停刷新来测试

ab -c 10 -n 5000  http://172.25.230.5/index.php
ab -c 10 -n 5000  http://172.25.230.5/example.php

在物理机上分别对两个页面进行压测
[root@localhost ~]# ab -c 10 -n 5000 http://172.25.230.5/index.php #很慢,因为没有缓存,而且failed比较多 10个并发,5000个请求
[root@localhost ~]# ab -c 10 -n 5000 http://172.25.230.5/example.php #很快,因为访问缓存,而且没有failed的

nginx配置

添加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)等来访问数据库再返回,这大大提高了应用的性能。
参考openresty中文官网 http://openresty.org/cn/

关闭原来的nginx,编译openresty

原nginx不支持memcache,给nginx添加memc和sr cache模块,让nginx直接访问memcache来提高速度,openresty也是nginx

nginx -s stop

tar zxf openresty-1.13.6.1.tar.gz
cd openresty
./configure --prefix=/usr/local/openresty
gmake && gmake install

cd /usr/local/openresty/nginx/html
cp /usr/local/lnmp/nginx/html/index.php .
cp /usr/local/lnmp/nginx/html/example.php .
把在nginx的发布文件拷贝过来

修改openresty配置文件

vim /usr/local/openresty/nginx/conf/nginx.conf

    upstream memcache {
        server localhost:11211;
        keepalive 512;
    }


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

        location ~ \.php$ {
            set $key $uri$args;
	    ##http的GET方法表示get、PUT方法表示set
            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;
        }

./sbin/nginx -s reload
其中
internal;  # 只接收内部访问,不接受外部http访问。比较安全
memc_connect_timeout 100ms;
memc_send_timeout 100ms;   ##后端服务器数据回传时间
memc_read_timeout 100ms;   ##连接成功后,后端服务器响应时间
srcache_fetch GET /memc $key;(这两个配置的作用是:请求php页面时,先会去memcache中找,如果没有,正常访问;
srcache_store PUT /memc $key; 访问结束后将结果存到memcache,下次访问时直接从缓存中)

测试

再次进行压测,速度会比之前只加了php的缓存更快

重点说明一下对index.php页面的访问 ,访问速度有了明显的差别, 因为php是没有缓存的

配置tomcat

配置jdk和tomcat

tar zxf jdk-7u79-linux-x64.tar.gz -C /usr/local/
tar zxf apache-tomcat-7.0.37.tar.gz -C /usr/local/

做好软连接便于访问
cd /usr/local
ln -s jdk1.7.0_79/ java
ln -s apache-tomcat-7.0.37/ tomcat

配置环境变量
vim /etc/profile
export JAVA_HOME=/usr/local/java
export CLASSPATH=.:$JAVA_HOME/lib:$JAVA_HOME/jre/lib
export PATH=$PATH:$JAVA_HOME/bin
source /etc/profile


echo $PATH
echo $CLASSPATH
echo $JAVA_HOME
which java
which javac
java -version


cd /usr/local/tomcat/bin
./startup.sh

浏览器访问tomcat

给nginx添加动态请求

修改nginx的配置文件

vim /usr/local/openresty/nginx/conf/nginx.conf

    upstream memcache {
        server localhost:11211;
        keepalive 512;
    }


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

		location ~ \.jsp$ {
			proxy_pass  http://127.0.0.1:8080
		}

        location ~ \.php$ {
            set $key $uri$args;
	    ##http的GET方法表示get、PUT方法表示set
            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;
        }


./sbin/nginx -s reload
vim test.java
public class test
{
    public static void main(String[] args)
    {
        System.out.println("Hello World1");
    }
}
javac test.java
java test
cd /usr/local/tomcat
bin/startup.sh
cd /usr/local/tomcat/webapps/ROOT/
vim time_test.jsp
server1-The time is: <%=new java.util.Date() %>
vim /usr/local/apache-tomcat-7.0.37/webapps/ROOT/test.jsp
<%@ page contentType="text/html; charset=GBK" %>
<%@ page import="java.util.*" %>
<html><head><title>Cluster App Test</title></head>
<body>
Server Info:
<%
out.println(request.getLocalAddr() + " : " + request.getLocalPort()+"<br>");%>
<%
out.println("<br> ID " + session.getId()+"<br>");
String dataName = request.getParameter("dataName");
if (dataName != null && dataName.length() > 0) {
String dataValue = request.getParameter("dataValue");
session.setAttribute(dataName, dataValue);
}
out.print("<b>Session list</b>");
Enumeration e = session.getAttributeNames();
while (e.hasMoreElements()) {
String name = (String)e.nextElement();
String value = session.getAttribute(name).toString();
out.println( name + " = " + value+"<br>");
System.out.println( name + " = " + value);
}
%>
<form action="test.jsp" method="POST">
name:<input type=text size=20 name="dataName">
<br>
key:<input type=text size=20 name="dataValue">
<br>
<input type=submit>
</form>
</body>
</html>

未完

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值