Tomcat8.5.14+Redis+Nginx实现集群

4 篇文章 0 订阅
0 篇文章 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架包

修改配置文件

1)Tomcat
复制apache-tomcat-8.5.14两份,分别命名apache-tomcat-81与apache-tomcat-82。为了能启动两个tomcat需要修改server.xml的端口。如图:

修改tomcat的端口

修改tomcat的端口

修改tomcat的端口

配置 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共享。

  • 6
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 15
    评论
评论 15
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值