189 8069 5689

Tomcat8+Redis+Nginx实现集群-创新互联

Tomcat8.5.14+Redis+Nginx实现集群

知识点

1)什么是集群 
集群是一组相互独立的、通过高速网络互联的计算机,它们构成了一个组,并以单一系统的模式加以管理。 
说白了就是同一个业务,部署在多个服务器上。 
2)集群所遇到的问题

10年积累的成都网站设计、做网站、成都外贸网站建设公司经验,可以快速应对客户对网站的新想法和需求。提供各种问题对应的解决方案。让选择我们的客户得到更好、更有力的网络服务。我虽然不认识你,你也不认识我。但先制作网站后付款的网站建设流程,更有太和免费网站建设让你可以放心的选择与我们合作。

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

另外有需要云服务器可以了解下创新互联cdcxhl.cn,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。


本文题目:Tomcat8+Redis+Nginx实现集群-创新互联
标题URL:http://cdxtjz.cn/article/echds.html

其他资讯