nginx+tomcat+memcached

本文介绍如何配置Nginx、Tomcat与Memcached实现负载均衡及会话共享,通过sticky模式确保同一用户的请求被发送到相同的Tomcat实例上处理,即使某个实例发生故障也能保证会话不丢失。

*********** nginx+tomcat+memcached ************

系统环境:    rhel6 x64 selinux and iptables disabled

主机角色:    node1: 172.25.62.2:nginx tomcat memcached

node2: 172.25.62:3:tomcat memcached

软件下载:    http://www.nginx.org

http://code.google.com/p/memcached-session-manager/

<T1>  <T2>

  . \/  .

  .  X  .

  . /\  .

<M1>  <M2>

    

Tomcat-1 (T1) 将 session 存储在 memcached-2 (T2)上。只有当 M2 不可用时,T1 才将 session 存储在 memcached-1 (M1 是 T1 failoverNode)。使用这种配置的好处是,当 T1 和 M1 同时崩溃时也不会丢失 session 会话,避免单点故障。

以下步骤在 node1 与 node2 上实施:

安装apache-tomcat

1).安装jdk(node1node2安装)

# tar zxf jdk-7u79-linux-x64.tar.gz -C /usr/local

# ln -s /usr/local/jdk1.7.0_79/  /usr/local/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

# echo $PATH

# echo $CLASSPATH

wKiom1l0qe2RpD-sAABm2RRFY9M457.png


测试:

# vim test.java

public class test {

public static void main(String[] arge) {

System.out.println("Hello World!");

}

}

# javac test.java        ##编译

# java test

Hello World!

wKioL1l0qe3B27cBAAGYpdSVgT4324.png


2).安装tomcat (node1node2安装)

# tar zxf apache-tomcat-7.0.37.tar.gz -C /usr/local

# ln -s /usr/local/apache-tomcat-7.0.37/  /usr/local/tomcat

cd /usr/local/tomcat/bin/

# ./startup.sh     ##开启tomcat

wKiom1l0qe7z407PAAIGUOa0upI693.png

# vim /usr/local/tomcat/webapps/ROOT/test.jsp

the time is:<%=new java.util.Date() %>

wKioL1l0qe_h1COFAABee9CjaXQ596.png

测试:172.25.7.2:8080172.25.7.2:8080/test.jsp

wKioL1l0qe-ikQ7BAAGYMAodgaQ159.png

wKiom1l0qfCC1TrjAAAwTPwgxCs896.png


在172.25.62.1端:

# /etc/init.d/php-fmp start

# vim /usr/local/lnmp/nginx/conf/nginx.conf

 19 http {

 20 

 21         upstream westos {

 22         #ip_hash;

 23         server 172.25.7.2:8080 ;

 24         server 172.25.7.3:8080;

 25         #server 172.25.7.1:8000 backup;

 26         }

 89         location ~ \.jsp$ {

 90                 proxy_pass http://westos;

 91         }

wKiom1l0qfGSMZq1AADQHHBbB7o497.png


# nginx -t 

# nginx -s reload

wKioL1l0qfGyfYD9AACu7GF9I0Q362.png


到此配置完成,可以测试了:

以下为测试页面,在172.25.62.2和172.25.62.3上保存以下内容到 /usr/local/tomcat/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>

wKioL1l0qfKTbBmTAAFzhxki2Kg404.png


访问 http://172.25.7.1/test.jsp,不同的主机访问时会调度到不同主机172.25.7.2或172.25.7.3的 tomcat 实例上处理来自同一主机的请求会交给同一个 tomcat 实例处理,此时你 down 掉当前正在响应的 tomcat 实例,nginx 会自动把用户的请求调度到另一个 tomcat 实例上,同时 session 也没有丢掉。

wKiom1l0qfLhw7PgAAAuEd2f75g843.png


当轮询时:T1上的数据存储在T2上,T2存储的数据在T1上。

wKiom1l0qfPSlUeTAABnibCfXSA663.png

wKiom1l0qfThy7dRAACFfMXncfg676.png

wKioL1l0rBKCZWwAAABx2De9mZA845.png

当ip_hash时,在同一主机上存储。

wKioL1l0qfWjKrsGAACj5bPnMDw980.png

wKioL1l0rBOD2wtlAACAvVLEoQs915.png

######  memcached 安装 ##########

在172.25.7.2和172.25.7.3上:

# yum install memcached -y

# service memcached start

# vim /usr/local/tomcat/conf/context.xml

<Context>

......

<Manager className="de.javakaffee.web.msm.MemcachedBackupSessionManager"

memcachedNodes="n1:192.168.0.91:11211,n2:192.168.0.92:11211"

failoverNodes="n1"

#在 node2 上此项设置为“n2”

requestUriIgnorePattern=".*\.(ico|png|gif|jpg|css|js)$"

transcoderFactoryClass="de.javakaffee.web.msm.serializer.kryo.KryoTranscoderFactory"

/>

</Context>

wKioL1l0rBTBHdRWAAC9aLySHiQ059.png

 

# cp jar/* /usr/local/tomcat/lib/

# cd /usr/local/tomcat/lib/

# rm -fr memcached-session-manager-tc6-1.6.3.jar

# /usr/local/tomcat/bin/shutdown.sh

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

当重新设置后要重启:

wKiom1l0rBSAZrDXAAG3zVRs6VE145.png


在172.25.62.2上存储数据时存到172.25.62.3上。

wKiom1l0rBWg91q3AACI1tGsdOU360.png

# telnet localhost 11211

wKiom1l0rBeQ9IorAAJBesX3Xxs990.png

wKiom1l0rBiyzf0TAAJyytQ-jdI378.png

# tail -f /usr/local/tomcat/logs/catalina.out

wKioL1l0rBaQP8b9AAIqkuRvfAU754.png


当172.25.62.2挂掉后,172.25.62.3存储的数据存到本机上:

wKiom1l0rvOx3DjeAACRFdzz4aI077.png

wKioL1l0rBnip1y5AAPaTApbesc186.png


wKioL1l0rB2yzQLSAAQs141aUDo752.png


在172.25.62.1上:

1).安装

# tar zxf nginx-goodies-nginx-sticky-module-ng-c78b7dd79d0d.tar.gz 
# tar zxf nginx-1.10.1.tar.gz 
# cd nginx-1.10.1 
# ./configure --prefix=/opt/nginx --user=nginx --group=nginx --with-threads --with-file-aio --with-http_ssl_module --with-http_stub_status_module --add-module=/root/nginx-goodies-nginx-sticky-module-ng-c78b7dd79d0d 
# make && make install  


nginx-sticky-module 为 nginx 的第三方模块,使 nginx 支持 sticky 模式,所谓 sticky 模式就是指同一个用户的访问请求都被发送到同一个 tomcat 实例上处理。 

2).配置
# vim /opt/nginx/conf/nginx.conf 
 17 http { 
 18  
 19         upstream westos { 
 20         sticky; 
 21         server 172.25.62.2:8080; 
 22         server 172.25.62.3:8080; 
 23         } 
 24     include       mime.types; 
 25     default_type  application/octet-stream; 
 69         location ~ \.jsp$ { 
 70                 proxy_pass   http://westos; 
 71         } 


# /opt/nginx/sbin/nginx     ##启动nginx


测试:当访问时不轮询,只在第一个出现的主机上发送数据并存储在其主机上。


wKiom1l19X2Ar1JJAAGcesf2b38586.png



本文转自cuijb0221 51CTO博客,原文链接:http://blog.51cto.com/cuijb/1950263

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值