nginx+tomcat+memcached实现信息的交叉存储

实验环境: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

/etc/profile
这里写图片描述

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(再浏览器上查看)

这里写图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值