天天看點

nginx+tomcat+memcached

*********** 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(node1和node2安裝)

# 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

nginx+tomcat+memcached

測試:

# vim test.java

public class test {

public static void main(String[] arge) {

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

}

# javac test.java        ##編譯

# java test

Hello World!

nginx+tomcat+memcached

2).安裝tomcat (node1和node2安裝)

# 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

nginx+tomcat+memcached

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

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

nginx+tomcat+memcached

測試:172.25.7.2:8080和172.25.7.2:8080/test.jsp

nginx+tomcat+memcached
nginx+tomcat+memcached

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

nginx+tomcat+memcached

# nginx -t 

# nginx -s reload

nginx+tomcat+memcached

到此配置完成,可以測試了:

以下為測試頁面,在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">

<input type=submit>

</form>

</body>

</html>

nginx+tomcat+memcached

通路 http://172.25.7.1/test.jsp,不同的主機通路時會排程到不同主機172.25.7.2或172.25.7.3的 tomcat 執行個體上處理來自同一主機的請求會交給同一個 tomcat 執行個體處理,此時你 down 掉目前正在響應的 tomcat 執行個體,nginx 會自動把使用者的請求排程到另一個 tomcat 執行個體上,同時 session 也沒有丢掉。

nginx+tomcat+memcached

當輪詢時:T1上的資料存儲在T2上,T2存儲的資料在T1上。

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

當ip_hash時,在同一主機上存儲。

nginx+tomcat+memcached
nginx+tomcat+memcached

######  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>

nginx+tomcat+memcached

# 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

當重新設定後要重新開機:

nginx+tomcat+memcached

在172.25.62.2上存儲資料時存到172.25.62.3上。

nginx+tomcat+memcached

# telnet localhost 11211

nginx+tomcat+memcached
nginx+tomcat+memcached

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

nginx+tomcat+memcached

當172.25.62.2挂掉後,172.25.62.3存儲的資料存到本機上:

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

在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

測試:當通路時不輪詢,隻在第一個出現的主機上發送資料并存儲在其主機上。

nginx+tomcat+memcached

繼續閱讀