複製本機上的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
(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
,結果以下,此時結果一致。