1. 程式人生 > >Tomcat8+Redis+Nginx實現集群

Tomcat8+Redis+Nginx實現集群

pro sub .com lookup box 可靠性 ges 測試環境 version

Tomcat8.5.14+Redis+Nginx實現集群

知識點

1)什麽是集群
集群是一組相互獨立的、通過高速網絡互聯的計算機,它們構成了一個組,並以單一系統的模式加以管理。
說白了就是同一個業務,部署在多個服務器上。
2)集群所遇到的問題

session共享

  • 基於NFS的Session共享

  • 基於數據庫的Session共享

  • 基於Cookie的Session共享

  • 基於緩存的Session共享(本次選用這種方式)

3)集群優點

  • 提高性能

  • 降低成本

  • 提高可擴展性

  • 增強可靠性

測試環境

JDK版本:JDK8
Tomcat版本:apache-tomcat-8.5.14
Redis版本:redis-2.4.5
Nginx版本:nginx-1.11.6

需要的jar包

放入Tomcat下的lib文件夾下:
commons-pool2-2.4.2.jar
jedis-2.9.0.jar
javazhan-tomcat-redis-session.jar

下載地址:Tomcat8+Redis實現集群所需Jar架包 http://down.51cto.com/data/2449143

修改配置文件

1)Tomcat
復制apache-tomcat-8.5.14兩份,分別命名apache-tomcat-81與apache-tomcat-82。為了能啟動兩個tomcat需要修改server.xml的端口。

  1. 服務端口

<Server port="8005" shutdown="SHUTDOWN">

<Listener className="org.apache.catalina.startup.VersionLoggerListener" />

2.訪問連接端口

 第一個連接器監聽8080端口,負責建立HTTP連接。在通過瀏覽器訪問Tomcat服務器的Web應用時,使用的就是這個連接器。

<Connector port="8080" protocol="HTTP/1.1"

connectionTimeout="6000" enableLookups="flase" acceptCount="800"

redirectPort="8443" />

3.與HTTP服務器連接端口

 第二個連接器監聽8009端口,負責和其他的HTTP服務器建立連接。在把Tomcat與其他HTTP服務器集成時,就需要用到這個連接器。

<!-- Define an AJP 1.3 Connector on port 8009 -->

<Connector port="8009" protocol="AJP/1.3" redirectPort="8443" />



配置 context.xml 文件:session共享

<Context>

<WatchedResource>WEB-INF/web.xml</WatchedResource>

<WatchedResource>${catalina.base}/conf/web.xml</WatchedResource>

<Valve className="com.javazhan.tomcat.redis.session.RedisSessionHandlerValve" />

<Manager className="com.javazhan.tomcat.redis.session.RedisSessionManager"

host="127.0.0.1"

port="6379"

database="0"

maxInactiveInterval="60" />

</Context>

說明:
如果tomcat配置中,將manager放在server.xml中,那麽使用maven做熱部署時,會發生失敗。所以,推薦放在context.xml中。


2)Nginx


修改conf目錄下的nginx.conf文件


upstream javazhan.com {

server yan.10010.com:8881 weight=5;

server yan.10010.com:8882 weight=5 ;

}

server {

listen 80;

server_name api.xxx.com;

location /

{

proxy_set_header Host $host;

proxy_set_header X-Real-Ip $remote_addr;

proxy_set_header X-Forwarded-For $remote_addr;

proxy_pass http://javazhan.com;

}

}



新建web項目


新建文件夾ClusterTest ,新建sessiontest.jsp,放到tomcat文件夾下webapps下。


<%@ page language="java" contentType="text/html; charset=UTF-8"

pageEncoding="UTF-8"%>

<%@ page import="java.util.*"%>

<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">

<html>

<head>

<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">


<title>ClusterApp Test</title>

</head>

<body>

訪問的Nginx IP:<%=request.getServerName()%>

<BR>

Tomcat SessionPort:<%=request.getServerPort()%>

<%

out.println("Tomcat Server Info=" + request.getLocalAddr() + " : " + request.getLocalPort() + "<br>");

out.println("當前 Session 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.println("<b>Session列表</b><br>");

System.out.println("Session列表");

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="sessiontest.html" method="POST">

名稱:<input type=text size=20 name="dataName"> <br/>

值:<input type=text size=20 name="dataValue"> <br/>

<input type=submit text="提交">

</form>

</body>

</html>


測試

1)啟動nginx
2)啟動redis
3)啟動tomcat(兩個)
4)啟動瀏覽器
5)輸入地址 http://yan.10010.com/ClusterTest/sessiontest.jsp

技術分享圖片


技術分享圖片

可以看出同一地址,分別訪問兩個tomcat服務器,並且session值不變,實現了session共享。

Tomcat8+Redis+Nginx實現集群