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步配置好了之後,若是立馬刷新網頁,發現仍是不一致,過一會會就行了
  • 全部資料共享地址
相關文章
相關標籤/搜索