Tomcat8+Redis+Nginx实现集群
admin
2023-03-10 03:02:19
0

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. 服务端口

 

2.访问连接端口

 第一个连接器监听8080端口,负责建立HTTP连接。在通过浏览器访问Tomcat服务器的Web应用时,使用的就是这个连接器。

 

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

               redirectPort="8443" />

3.与HTTP服务器连接端口

 第二个连接器监听8009端口,负责和其他的HTTP服务器建立连接。在把Tomcat与其他HTTP服务器集成时,就需要用到这个连接器。

 

   



配置 context.xml 文件:session共享

    WEB-INF/web.xml

    ${catalina.base}/conf/web.xml

   

   

                 host="127.0.0.1"

                 port="6379"

                 database="0"

                 maxInactiveInterval="60" />

说明: 
如果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.*"%>


ClusterApp Test

        访问的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

Tomcat8+Redis+Nginx实现集群


Tomcat8+Redis+Nginx实现集群

可以看出同一地址,分别访问两个tomcat服务器,并且session值不变,实现了session共享。

相关内容

热门资讯

较真卖家驱车1600公里花费5... 极目新闻评论员 屈旌近日,河南濮阳一冷冻榴莲果肉商家“程大叔”反映,自己遭遇一名买家恶意“仅退款”。...
天花板上的吊顶先用什么样的材料... 楼上内容精辟.设为最佳答案. 现在装修不得不提集成吊顶,集合照明,换气,取暖与一体的,不仅美观...
冰箱数字越低就越冷吗? 本站小编大大来解答下冰箱数字越低就越冷的观点是否正确,以及冰箱数字与温度的关系。 冰箱数字越...
怎样翻新厕所墙面地板?卫生间地... 1、确定瓷砖数量。实际瓷砖数量比装修面积多出一点,防止损耗导致数量不足。2、敲掉原有瓷砖。由于卫生间...
装修胶水怎么选?装修胶水气味多... 本文介绍了如何选择适合的装修胶水,包括根据使用部位、施工条件和粘接材料的特性来选择胶水,以及如何处理...
原有乳胶墙面翻新需刷几遍 关于墙面刷漆是很麻烦的,那么原有乳胶墙面翻新需刷几遍? 通常情况下,墙面乳胶漆刷三遍就够了,俗称“...
男子殴打他人被刺伤起诉索赔30... 朋友遭遇殴打,他上前劝阻无效;当朋友再次面临殴打时,他用刀刺伤打人者,是否属于正当防卫?正当防卫是否...
不止聂永真,九把刀拿了上亿补助... 海峡导报综合报道 台电(台湾电力公司)近日更换新的LOGO引发争议,尤其是现在台电还在亏损3000多...
阿根廷法医披露马拉多纳去世前状... 阿根廷一名法医日前在足球名宿迭戈·马拉多纳死亡案件的审判中表示,马拉多纳去世前遭受了约12个小时的痛...
斯洛伐克总理在俄表态:我是欧盟... 【环球网报道 记者 索炎琦】据俄罗斯《消息报》《乌克兰真理报》等媒体报道,斯洛伐克总理菲佐8日在莫斯...