iis服务器助手广告广告
返回顶部
首页 > 资讯 > 精选 >Nginx中怎么利用Tomcat搭建集群
  • 905
分享到

Nginx中怎么利用Tomcat搭建集群

2023-06-19 12:06:38 905人浏览 独家记忆
摘要

这篇文章将为大家详细讲解有关Nginx中怎么利用Tomcat搭建集群,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。创建Maven项目,添加依赖使用IntelliJ idea创建Maven项目

这篇文章将为大家详细讲解有关Nginx中怎么利用Tomcat搭建集群,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。

创建Maven项目,添加依赖

使用IntelliJ idea创建Maven项目,并添加相关依赖,依赖如下:

<dependencies>        <!-- Jedis -->        <dependency>            <groupId>redis.clients</groupId>            <artifactId>jedis</artifactId>            <version>2.9.0</version>        </dependency>        <!-- spring Data Redis -->        <dependency>            <groupId>org.springframework.data</groupId>            <artifactId>spring-data-redis</artifactId>            <version>1.8.4.RELEASE</version>        </dependency>        <!-- Spring Session -->        <dependency>            <groupId>org.springframework.session</groupId>            <artifactId>spring-session</artifactId>            <version>1.3.1.RELEASE</version>        </dependency>        <!-- Apache Commons Pool -->        <dependency>            <groupId>org.apache.commons</groupId>            <artifactId>commons-pool2</artifactId>            <version>2.4.2</version>        </dependency>        <dependency>            <groupId>org.springframework</groupId>            <artifactId>spring-WEBmvc</artifactId>            <version>${spring-framework.version}</version>        </dependency>    </dependencies>

这里要添加的依赖略多,不过大致可以分为如下三类:

Redis的Java客户端,这个通过Java代码来操作Redis
2.Spring Data Redis,这个用来简化Redis操作
3.Spring Session,这个用来进行Session的管理
4.Spring

搭建Spring+springMVC环境

首先在resources文件夹下创建spring+springmvc的配置文件:
Nginx中怎么利用Tomcat搭建集群
然后在web.xml文件中配置spring和springmvc,如下:

<context-param>        <param-name>contextConfigLocation</param-name>        <param-value>classpath:applicationContext.xml</param-value>    </context-param>    <listener>        <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>    </listener>    <servlet>        <servlet-name>springmvc</servlet-name>        <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>        <init-param>            <param-name>contextConfigLocation</param-name>            <param-value>classpath:spring-servlet.xml</param-value>        </init-param>        <load-on-startup>1</load-on-startup>    </servlet>    <servlet-mapping>        <servlet-name>springmvc</servlet-name>        <url-pattern>/</url-pattern>    </servlet-mapping>

然后在applicationContext.xml文件中简单的配置一下spring,如下:

<context:component-scan base-package="org.sang" use-default-filters="false">        <context:exclude-filter type="annotation" expression="org.springframework.stereotype.Controller"/>    </context:component-scan>

配置Spring容器要扫描的注解。
然后在spring-servlet.xml中配置SpringMVC容器要扫描的注解,如下:

<?xml version="1.0" encoding="UTF-8"?><beans xmlns="Http://www.springframework.org/schema/beans"       xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:mvc="http://www.springframework.org/schema/mvc"       xmlns:context="http://www.springframework.org/schema/context"       xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc.xsd http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context.xsd">    <mvc:annotation-driven/>    <context:component-scan base-package="org.sang" use-default-filters="false">        <context:include-filter type="annotation" expression="org.springframework.stereotype.Controller"/>    </context:component-scan></beans>

spring-servlet.xml的配置相对要简单一些。
OK,至此,Spring+SpringMVC的环境就搭建成功了。

配置Spring Session和Redis

Session一直是我们做集群时一个比较头疼的问题,之前有一个GitHub上的开源控件tomcat-redis-session-manager,但是这个东西目前只支持到Tomcat7,不是最佳选项,我们也可以使用Nginx提供的ip_tables,将同一个请求ip定位到同一台服务器上,但是这样没有办法充分利用服务集群的性能,Spring Session的出现可以很好的帮助我们解决这些问题,它具有如下特点:

Spring Session提供了redis、JVM的map、monGo、gemfire、hazelcast、jdbc等多种存储session的容器的方式。
2.同一个浏览器同一个网站,支持多个session。
3.不依赖于cookie。可通过header来传递sessionID
4.websocket和spring-session结合,同步生命周期管理。
5.使用简单

OK,接下来我们来看看怎么配置我们的Spring Session,首先在web.xml文件中添加过滤器:

<filter>        <filter-name>springSessionRepositoryFilter</filter-name>        <filter-class>org.springframework.web.filter.DelegatingFilterProxy</filter-class>    </filter>    <filter-mapping>        <filter-name>springSessionRepositoryFilter</filter-name>        <url-pattern>/*</url-pattern>    </filter-mapping>

这里使用了Spring Web提供的代理过滤器,将拦截到的请求全部交给一个名为springSessionRepositoryFilter的过滤器进行处理。OK,然后在applicationContext.xml中配置Spring Session和Redis,如下:

<bean class="org.springframework.session.data.redis.config.annotation.web.http.RedishttpsessionConfiguration"/>    <bean class="org.springframework.data.redis.connection.jedis.JedisConnectionFactory">        <property name="hostName" value="192.168.248.128"/>        <property name="port" value="6379"/>        <property name="database" value="0"/>    </bean>

hostName即为redis的地址,port为redis的服务端口。

OK,写完这一切就OK了,我们来写一个简单的jsp页面测试一下,测试前记得启动你的redis服务哦。

测试

index.jsp页面如下:

<%@ page contentType="text/html;charset=UTF-8" language="java" %><html><head>    <title>Title</title></head><body><fORM action="/setsession">    <input type="text" name="name"><input type="submit" value="提交"></form><form action="/getsession">    <input type="submit" value="获取"></form></body></html>

该页面我尽量做得简单,有两个按钮,第一个向session中存数据,第二个按钮从session中取数据,对应的Controller如下:

@Controllerpublic class HelloController {    @RequestMapping("/setsession")    @ResponseBody    public void setSession(HttpSession session, String name) {        session.setAttribute("name", name);    }    @RequestMapping(value = "/getsession",produces = "text/html;charset=utf-8")    @ResponseBody    public String getSession(HttpSession session, HttpServletRequest req) {        return session.getAttribute("name").toString()+"-----"+req.getServletContext().getRealPath("/");    }}

当我向httpsession中写数据时,这些数据会自动存储到redis缓存/数据库中。在返回session数据时我加上了项目部署路径,是为了在部署到集群上之后区分这个请求是由哪台服务器处理的。启动项目,页面如下:
Nginx中怎么利用Tomcat搭建集群
点击提交,会将数据保存到redis 中,如下:
Nginx中怎么利用Tomcat搭建集群
然后再回到起始页面,点击获取按钮,即可以拿到Session中的值,如下:
Nginx中怎么利用Tomcat搭建集群
OK,很简单吧!
至此,我们的Spring Session+Redis实现Session共享这个功能就完成了。接下来我们来看看如何为这个简单的web项目搭建集群。

搭建集群的准备工作

下载Nginx(地址http://nginx.org/),我这里使用的Nginx版本是nginx-1.12.0
2.下载Tomcat,我这里使用的Tomcat版本是apache-tomcat-8.5.12

网络拓扑图如下:
Nginx中怎么利用Tomcat搭建集群
将下载的Tomcat复制成两份,如下:
Nginx中怎么利用Tomcat搭建集群
修改Tomcat的配置文件(conf/server.xml),重新设置端口号,每一个Tomcat的server.xml都需要修改三处,如下:
Nginx中怎么利用Tomcat搭建集群
要修改的地方有三处,我将给默认的端口号前面都加1,然后第二个Tomcat我给这三个地方的端口号前面都加2,这样方便我一会在同一台机器上跑多个Tomcat。
OK,做好这一切之后,可以先启动这两个Tomcat,看看能不能正常访问。

部署项目

OK,两台Tomcat都配置好之后,我们将刚才的项目拷贝到tomcat的webapps目录下,给两个Tomcat都拷贝。这里就不赘述了。

配置Nginx

下载Nginx,解压后,配置conf/nginx.conf文件,如下:
Nginx中怎么利用Tomcat搭建集群
配置完成后,启动nginx。再测试。

测试

向session中存数据:
Nginx中怎么利用Tomcat搭建集群
从session中取数据:
多取几次,你会看到请求是由不同的服务器处理的,如下:
Nginx中怎么利用Tomcat搭建集群
Nginx中怎么利用Tomcat搭建集群

关于Nginx中怎么利用Tomcat搭建集群就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。

--结束END--

本文标题: Nginx中怎么利用Tomcat搭建集群

本文链接: https://www.lsjlt.com/news/296069.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • c++中int和double有什么区别
    int 和 double 是 c++ 的数据类型,用于表示整数和浮点数。它们的关键区别在于:1. 范围:int 为整数,double 为浮点数且范围更大;2. 存储大小:int 占 4 ...
    99+
    2024-05-14
    c++ 隐式转换
  • C++ 多线程程序测试的挑战和策略
    多线程程序测试面临不可重复性、并发错误、死锁和缺乏可视性等挑战。策略包括:单元测试:针对每个线程编写单元测试,验证线程行为。多线程模拟:使用模拟框架在控制线程调度的情况下测试程序。数据竞...
    99+
    2024-05-14
    c++ 多线程
  • c++中深拷贝和浅拷贝的应用时间
    浅拷贝复制对象指针或引用,仅适用于不含动态分配内存或简单数据结构的对象;深拷贝复制实际数据,包括动态分配内存,适用于包含动态分配内存或复杂数据结构的对象。 浅拷贝和深拷贝的应用时间 在...
    99+
    2024-05-14
    c++
  • 探索用于 C++ 服务器架构的高级数据结构
    在 c++++ 服务器架构中,选择适当的高级数据结构至关重要。哈希表用于快速数据查找,树用于表示数据层次结构,图用于表示对象之间的关系。这些数据结构在实践中有着广泛的应用,例如缓存系统、...
    99+
    2024-05-14
    c++ 数据结构 社交网络 键值对
  • fixed在c++中的作用
    fixed 关键字在 c++ 中用于将浮点数存储为固定小数,提供更高精度,尤其适用于需要高精度的金融计算。fixed 将浮点数表示为具有固定小数位数的小数,默认情况下使用十进制表示法,小...
    99+
    2024-05-14
    c++
  • insert在c++中怎么用
    insert() 函数在 c++ 中用于在容器(如 vector、set)中插入元素,提供了一种动态调整容器大小并添加新元素的方法。它需要两个参数:要插入元素的位置 (pos) 和要插入...
    99+
    2024-05-14
    c++ 标准库
  • 如何使用 Golang 构建 RESTful API 并处理 JSON 响应?
    如何使用 golang 构建和处理 json 响应的 restful api步骤:创建 golang 项目并安装 gorilla mux。定义路由并处理 http 请求。安装 json ...
    99+
    2024-05-14
    golang git
  • c++中int和long的区别
    int 和 long 都是 c++ 中的整型类型,主要区别在于范围和存储空间:范围:int 为 32 位整数,范围为 [-2^31, 2^31-1];long 为 64 位整数,范围为 ...
    99+
    2024-05-14
    c++ 数据丢失
  • c++中int a(n)和int a[n]的区别
    int a(n)声明一个不可变的整型变量,而int a[n]声明一个可修改元素的整型数组,用于存储和处理数据序列或集合。 int a(n) 和 int a[n] 在 C++ 中的区别 ...
    99+
    2024-05-14
    c++
  • C++ 多线程编程中调试和故障排除的技术
    c++++ 多线程编程的调试技巧包括:使用数据竞争分析器检测读写冲突,并使用同步机制(如互斥锁)解决。使用线程调试工具检测死锁,并通过避免嵌套锁和使用死锁检测机制来解决。使用数据竞争分析...
    99+
    2024-05-14
    c++ 多线程 故障排除 同步机制
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作