Java Web之Nginx+Tomcat+Memcached配置

简介: 1、配置多个Tomcat复制本机上的Tomcat,分别为apache-tomcat-8.0.26-1,apache-tomcat-8.0.26-2,apache-tomcat-8.

1、配置多个Tomcat

复制本机上的Tomcat,分别为apache-tomcat-8.0.26-1,apache-tomcat-8.0.26-2,apache-tomcat-8.0.26-3,表示三个Web服务器,如下图所所示:

img_9b18efabb1a3efd0526663ef84a4194e.png
三个tomcat.PNG

然后修改三个Tomcat的server.xml配置文件,修改它们的端口分别如下表所示:

取值 Server Connector Connector
默认 8005 8080 8443 8009 8443
apache-tomcat-8.0.26-1 8015 8081 8443 8019 8443
apache-tomcat-8.0.26-2 8025 8082 8443 8029 8443
apache-tomcat-8.0.26-3 8035 8083 8443 8039 8443

然后分别启动三台Tomcat,可以顺利启动表示修改成功,然后分别通过浏览器来分别访问http://localhost:8081/http://localhost:8082/http://localhost:8083/都可以访问到Tomcat的首页。

2、配置Nginx

下载稳定版Nginxnginx-1.12.2并解压,找到并修改nginx.conf配置文件,主要添加如下代码来配置集群和Nginx:

    #服务器的集群,配置三个Tomcat
    upstream  tomcatCluster {  #服务器集群名字
        server   127.0.0.1:8081 weight=1;#服务器配置,weight是权重的意思,权重越大,分配的概率越大。
        server   127.0.0.1:8082 weight=2;
        server   127.0.0.1:8083 weight=3;
    }   

    #Nginx的配置
    server {
        listen       80;#监听80端口,可以改成其他端口
        server_name  localhost;#当前服务的域名

        location / {
            root   html;
            index  index.html index.htm;
            proxy_pass http://tomcatCluster;  #这里的名字和upstream后面的名字一致
           
        }

cmd下切换到nginx-1.12.2的目录,启动Nginx

img_fd6e4a43e5b83b8ab96a49812717da14.png
启动Nginx.PNG

如果没有报任何错误,说明启动成功,也可以去任务管理器看一下有没有该进程来验证一下。此时在浏览器输入 http://localhost/,可以打开Tomcat欢迎界面。
img_882143c1dc9936d4de7b5fe7f99f1fd3.png
配置Nginx后访问服务器.PNG

至此,Nginx配置多个Tomcat服务器已经完成,但是存在一个问题,就是Session共享问题。写一个简单的JSP界面test.jsp来输出Session信息,将该文件分别放到三个Tomcat的webapps\ROOT

<html> 
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>
<title>Session共享测试</title> 
</head>
<body>
  <p>SessionID:<%=session.getId()%></p>
  <p>SessionIP:<%=request.getServerName()%></p>
  <p>SessionPort:<%=request.getServerPort()%></p>
</body> 
</html>

然后通过http://localhost/test.jsp多访问几次,看看输出的Session信息是否一致,很显然是不一致的。

img_8adb33555d4d2c9c3761b584d1856cbf.gif
Session不一致.gif

因为Session并没有共享,那么多个服务器的Session如何进行共享?请看下面的配置。

3、配置Memcached

(1) 下载memcached-win64-1.4.4-14,并解压,然后在cmd下切换到该目录,执行memcached.exe –d install 安装windows服务,然后启动服务。

img_b237b5ab4891b9a16f5e7c6cbd1be52c.png
安装memcached服务器.PNG

(2) 关闭启动的Tomcat ,将下图的jar包放入三个Tomcat的lib目录下

img_d5e4a33ce4828bd00e04b3fa076aea80.png
需要的jar包.PNG

(3) 配置三个Tomcat的 context.xml,加入如下的代码

  <Manager  className="de.javakaffee.web.msm.MemcachedBackupSessionManager"
                memcachedNodes="n1:127.0.0.1:11211"   
                lockingMode="auto"
                sticky="false" 
                requestUriIgnorePattern= ".*\.(png|gif|jpg|css|js)$"    
                sessionBackupAsync= "false"   
                sessionBackupTimeout= "100"    
                copyCollectionsForSerialization="true"   
                transcoderFactoryClass="de.javakaffee.web.msm.serializer.kryo.KryoTranscoderFactory" />

重新启动三个Tomcat,再次访问http://localhost/test.jsp,结果如下,此时结果一致。

img_fa6c2d7a96036baff816f197b7b80138.gif
Session一致.gif

4、总结

  • 前2步只要稍加注意应该问题不大(本人一次性成功)
  • 第3步我先下载了最新版的Tomcat 8.5,然后按照文中的配置,Tomcat启动一直报错,应该是jar包版本老了,这些jar包我也是从网上找来的,后来降低了Tomcat版本,成功了。所以注意Tomcat的版本与Memcached的Jar包对应。
  • 第3步配置好了以后,如果立马刷新网页,发现还是不一致,过一会会就好了
  • 所有资料共享地址:http://pan.baidu.com/s/1c15ldEK
目录
相关文章
|
4月前
|
Ubuntu 安全 应用服务中间件
详细指南:配置Nginx服务器在Ubuntu平台上
以上步骤涵盖了基本流程:从软件包管理器获取 Ngnix, 设置系统服务, 调整UFW规则, 创建并激活服务器块(也称作虚拟主机), 并进行了初步优化与加固措施。这些操作都是建立在命令行界面上,并假设用户具有必要权限(通常是root用户)来执行这些命令。每个操作都有其特定原因:例如,设置开机启动确保了即使重启后也能自动运行 Ngnix;而编辑server block则定义了如何处理进入特定域名请求等等。
326 18
|
4月前
|
Ubuntu 安全 应用服务中间件
详细指南:配置Nginx服务器在Ubuntu平台上
以上步骤涵盖了基本流程:从软件包管理器获取 Ngnix, 设置系统服务, 调整UFW规则, 创建并激活服务器块(也称作虚拟主机), 并进行了初步优化与加固措施。这些操作都是建立在命令行界面上,并假设用户具有必要权限(通常是root用户)来执行这些命令。每个操作都有其特定原因:例如,设置开机启动确保了即使重启后也能自动运行 Ngnix;而编辑server block则定义了如何处理进入特定域名请求等等。
424 17
|
4月前
|
存储 前端开发 Java
【JAVA】Java 项目实战之 Java Web 在线商城项目开发实战指南
本文介绍基于Java Web的在线商城技术方案与实现,涵盖三层架构设计、MySQL数据库建模及核心功能开发。通过Spring MVC + MyBatis + Thymeleaf实现商品展示、购物车等模块,提供完整代码示例,助力掌握Java Web项目实战技能。(238字)
501 0
|
4月前
|
安全 Java API
Java Web 在线商城项目最新技术实操指南帮助开发者高效完成商城项目开发
本项目基于Spring Boot 3.2与Vue 3构建现代化在线商城,涵盖技术选型、核心功能实现、安全控制与容器化部署,助开发者掌握最新Java Web全栈开发实践。
499 1
|
4月前
|
编解码 应用服务中间件 Linux
centos配置nginx-rtmp实现ffmpeg转码rtsp为rtmp视频流
centos配置nginx-rtmp实现ffmpeg转码rtsp为rtmp视频流
473 1
|
5月前
|
前端开发 Java 数据库
Java 项目实战从入门到精通 :Java Web 在线商城项目开发指南
本文介绍了一个基于Java Web的在线商城项目,涵盖技术方案与应用实例。项目采用Spring、Spring MVC和MyBatis框架,结合MySQL数据库,实现商品展示、购物车、用户注册登录等核心功能。通过Spring Boot快速搭建项目结构,使用JPA进行数据持久化,并通过Thymeleaf模板展示页面。项目结构清晰,适合Java Web初学者学习与拓展。
443 1
|
5月前
|
数据建模 应用服务中间件 PHP
配置nginx容器和php容器协同工作成功,使用ip加端口的方式进行通信
本示例演示如何通过Docker挂载同一宿主目录至Nginx与PHP容器,实现PHP项目运行环境配置。需注意PHP容器中监听地址修改为0.0.0.0:9000,并调整Nginx配置中fastcgi_pass指向正确的IP与端口。同时确保Nginx容器中/var/www/html权限正确,以避免访问问题。
配置nginx容器和php容器协同工作成功,使用ip加端口的方式进行通信
|
5月前
|
Ubuntu 应用服务中间件 Linux
在Ubuntu上配置Nginx实现开机自启功能
至此,Nginx应该已经被正确地设置为开机自启。在Ubuntu中利用 `systemd`对服务进行管理是一种高效的方式,为系统管理员提供了强大的服务管理能力,包括但不限于启动、停止、重启服务,以及配置服务的开机自启动。通过这些简洁的命令,即使是对Linux不太熟悉的用户也能轻松地进行配置。
271 0
|
5月前
|
JavaScript Java 微服务
现代化 Java Web 在线商城项目技术方案与实战开发流程及核心功能实现详解
本项目基于Spring Boot 3与Vue 3构建现代化在线商城系统,采用微服务架构,整合Spring Cloud、Redis、MySQL等技术,涵盖用户认证、商品管理、购物车功能,并支持Docker容器化部署与Kubernetes编排。提供完整CI/CD流程,助力高效开发与扩展。
681 64
|
6月前
|
缓存 NoSQL Java
Java Web 从入门到精通之苍穹外卖项目实战技巧
本项目为JavaWeb综合实战案例——苍穹外卖系统,涵盖Spring Boot 3、Spring Cloud Alibaba、Vue 3等主流技术栈,涉及用户认证、订单处理、Redis缓存、分布式事务、系统监控及Docker部署等核心功能,助你掌握企业级项目开发全流程。
744 0