复制本机上的Tomcat,分别为apache-tomcat-8.0.26-1,apache-tomcat-8.0.26-2,apache-tomcat-8.0.26-3
,表示三个Web服务器,以下图所所示: css
而后修改三个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
下载稳定版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
http://localhost/
,能够打开Tomcat欢迎界面。
至此,Nginx配置多个Tomcat服务器已经完成,可是存在一个问题,就是Session共享问题。写一个简单的JSP界面test.jsp
来输出Session信息,将该文件分别放到三个Tomcat的webapps\ROOT
下apache
<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并无共享,那么多个服务器的Session如何进行共享?请看下面的配置。浏览器
(1) 下载memcached-win64-1.4.4-14,并解压,而后在cmd下切换到该目录,执行memcached.exe –d install
安装windows服务,而后启动服务。 tomcat
(2) 关闭启动的Tomcat ,将下图的jar包放入三个Tomcat的lib目录下 bash
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
,结果以下,此时结果一致。