实验环境:server5:172.25.23.5 nginx tomcat memcache
server4:172.25.23.4 tomcat memcache
server5:
开启nginx php服务
具体关于nginx操作请去查找
nginx
/etc/init.d/php-fpm start
tar zxf jdk-7u79-linux-x64.tar.gz -C /usr/local/
cd /usr/local/
ln -s jdk1.7.0_79/ java
vim /etc/profile
source /etc/profile
tar zxf apache-tomcat-7.0.37.tar.gz -C /usr/local/
ln -s /usr/local/apache-tomcat-7.0.90/ /usr/local/tomcat
cd /usr/local/tomcat/
bin/startup.sh
scp jar/* /usr/local/tomcat/lib
cd /usr/local/tomcat/sbin
./startup.sh
cd /usr/local/tomcat/logs
cat catalina.out
cd /usr/local/tomcat/conf/
vim context.xml
<Manager className="de.javakaffee.web.msm.MemcachedBackupSessionManager"
memcachedNodes="n1:172.25.23.5:11211,n2:172.25.23.4:11211"
failoverNodes="n1"
requestUriIgnorePattern=".*\.(ico|png|gif|jpg|css|js)$"
transcoderFactoryClass="de.javakaffee.web.msm.serializer.kryo.KryoTranscoderFactory"
/>
两个主机文件一致
cd /usr/local/tomcat/webapps/ROOT
vim 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>
cd /usr/local/lnmp/nginx/conf/
vim nginx.conf
#user nobody;
user nginx;
worker_processes 1;
#error_log logs/error.log;
#error_log logs/error.log notice;
#error_log logs/error.log info;
#pid logs/nginx.pid;
events {
worker_connections 50000;
}
http {
upstream tomcat {
server 172.25.23.4:8080;
server 172.25.23.5:8080;
}
include mime.types;
default_type application/octet-stream;
location ~ \.jsp$ {
proxy_pass http://tomcat;
}
# pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000
#
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;
}
nginx -s reload
server4:
/etc/init.d/php-fpm start
tar zxf jdk-7u79-linux-x64.tar.gz -C /usr/local/
cd /usr/local/
ln -s jdk1.7.0_79/ java
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
tar zxf apache-tomcat-7.0.37.tar.gz -C /usr/local/
ln -s /usr/local/apache-tomcat-7.0.90/ /usr/local/tomcat
cd /usr/local/tomcat/bin
./startup.sh
yum install memcached -y
/etc/init.d/memcached start
cd /usr/local/tomcat/conf/
vim context.xml
<Manager className="de.javakaffee.web.msm.MemcachedBackupSessionManager"
memcachedNodes="n1:172.25.23.5:11211,n2:172.25.23.4:11211"
failoverNodes="n2"
requestUriIgnorePattern=".*\.(ico|png|gif|jpg|css|js)$"
transcoderFactoryClass="de.javakaffee.web.msm.serializer.kryo.KryoTranscoderFactory"
/>
cd /usr/local/tomcat/webapps/ROOT
vim 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>
scp jar/* /usr/local/tomcat/lib
apache-tomcat-7.0.37.tar.gz memcached-session-manager-1.6.3.jar reflectasm-1.01.jar
asm-3.2.jar memcached-session-manager-tc7-1.6.3.jar root@172.25.23.5
kryo-1.04.jar minlog-1.2.jar spymemcached-2.7.3.jar
kryo-serializers-0.10.jar msm-kryo-serializer-1.6.3.jar
查看日志:
cd /usr/local/tomcat/logs
cat catalina.out
测试:
第一步:
浏览器输入:172.25.23.5/test.jsp
输入信息,操作主机和存储数据的不是同一台主机,server ip主机和id-n2
yum install tclnet
telnet localhost
get id(再浏览器上查看)