Java Web之Nginx+Tomcat+Memcached配置

一、配置多个Tomcat

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

三个tomcat.PNG

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

取值 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的首页。java

二、配置Nginx

下载稳定版Nginxnginx-1.12.2并解压,找到并修改nginx.conf配置文件,主要添加以下代码来配置集群和Nginx: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 web

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

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

<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信息是否一致,很显然是不一致的。 windows

Session不一致.gif

由于Session并无共享,那么多个服务器的Session如何进行共享?请看下面的配置。浏览器

三、配置Memcached

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

安装memcached服务器.PNG

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

须要的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,结果以下,此时结果一致。

Session一致.gif

四、总结

  • 前2步只要稍加注意应该问题不大(本人一次性成功)
  • 第3步我先下载了最新版的Tomcat 8.5,而后按照文中的配置,Tomcat启动一直报错,应该是jar包版本老了,这些jar包我也是从网上找来的,后来下降了Tomcat版本,成功了。因此注意Tomcat的版本与Memcached的Jar包对应。
  • 第3步配置好了之后,若是立马刷新网页,发现仍是不一致,过一会会就行了
  • 全部资料共享地址
相关文章
相关标签/搜索