Tomcat8.5.14+redis+Nginx实现集群
知识点
1)什么是集群 
集群是一组相互独立的、通过高速网络互联的计算机,它们构成了一个组,并以单一系统的模式加以管理。 
说白了就是同一个业务,部署在多个服务器上。 
2)集群所遇到的问题
专注于为中小企业提供成都网站设计、网站制作、外贸营销网站建设服务,电脑端+手机端+微信端的三站合一,更高效的管理,为中小企业盘州免费做网站提供优质的服务。我们立足成都,凝聚了一批互联网行业人才,有力地推动了上1000家企业的稳健成长,帮助中小企业通过网站建设实现规模扩充和转变。
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的端口。
- 服务端口 
  
2.访问连接端口
第一个连接器监听8080端口,负责建立HTTP连接。在通过浏览器访问Tomcat服务器的Web应用时,使用的就是这个连接器。
                 connectionTimeout="6000" enableLookups="flase" acceptCount="800"                redirectPort="8443" /> 3.与HTTP服务器连接端口 第二个连接器监听8009端口,负责和其他的HTTP服务器建立连接。在把Tomcat与其他HTTP服务器集成时,就需要用到这个连接器。        配置 context.xml 文件:session共享                                      host="127.0.0.1"                  port="6379"                  database="0"                  maxInactiveInterval="60" /> 说明:  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.*"%>
如果tomcat配置中,将manager放在server.xml中,那么使用maven做热部署时,会发生失败。所以,推荐放在context.xml中。
访问的Nginx IP:<%=request.getServerName()%>
        
Tomcat SessionPort:<%=request.getServerPort()%>
<%
                out.println("Tomcat Server Info=" + request.getLocalAddr() + " : "     + request.getLocalPort() + "
");
                out.println("当前 Session ID=" + session.getId() + "
");
%>
<%
String dataName = request.getParameter("dataName");
if (dataName != null && dataName.length() > 0) {
String dataValue = request.getParameter("dataValue");
session.setAttribute(dataName, dataValue);
}
                out.println("Session列表
");
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 + "
");
System.out.println(name + " = " + value);
}
%>
测试
1)启动nginx 
2)启动redis 
3)启动tomcat(两个) 
4)启动浏览器 
5)输入地址 http://yan.10010.com/ClusterTest/sessiontest.jsp


可以看出同一地址,分别访问两个tomcat服务器,并且session值不变,实现了session共享。
网页标题:Tomcat8+Redis+Nginx实现集群
网站地址:http://www.scyingshan.cn/article/jijsih.html

 建站
建站
 咨询
咨询 售后
售后
 建站咨询
建站咨询 
 