天天看點

Java Web之Nginx+Tomcat+Memcached配置

1、配置多個Tomcat

複制本機上的Tomcat,分别為

apache-tomcat-8.0.26-1,apache-tomcat-8.0.26-2,apache-tomcat-8.0.26-3

,表示三個Web伺服器,如下圖所所示:

Java Web之Nginx+Tomcat+Memcached配置

三個tomcat.PNG

然後修改三個Tomcat的

server.xml

配置檔案,修改它們的端口分别如下表所示:

取值 Server 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

下載下傳穩定版Nginx

nginx-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

Java Web之Nginx+Tomcat+Memcached配置

啟動Nginx.PNG

如果沒有報任何錯誤,說明啟動成功,也可以去任務管理器看一下有沒有該程序來驗證一下。此時在浏覽器輸入

http://localhost/

,可以打開Tomcat歡迎界面。

Java Web之Nginx+Tomcat+Memcached配置

配置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資訊是否一緻,很顯然是不一緻的。

Java Web之Nginx+Tomcat+Memcached配置

Session不一緻.gif

因為Session并沒有共享,那麼多個伺服器的Session如何進行共享?請看下面的配置。

3、配置Memcached

(1) 下載下傳memcached-win64-1.4.4-14,并解壓,然後在cmd下切換到該目錄,執行

memcached.exe –d install

安裝windows服務,然後啟動服務。

Java Web之Nginx+Tomcat+Memcached配置

安裝memcached伺服器.PNG

(2) 關閉啟動的Tomcat ,将下圖的jar包放入三個Tomcat的lib目錄下

Java Web之Nginx+Tomcat+Memcached配置

需要的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

,結果如下,此時結果一緻。

Java Web之Nginx+Tomcat+Memcached配置

Session一緻.gif

4、總結

  • 前2步隻要稍加注意應該問題不大(本人一次性成功)
  • 第3步我先下載下傳了最新版的Tomcat 8.5,然後按照文中的配置,Tomcat啟動一直報錯,應該是jar包版本老了,這些jar包我也是從網上找來的,後來降低了Tomcat版本,成功了。是以注意Tomcat的版本與Memcached的Jar包對應。
  • 第3步配置好了以後,如果立馬重新整理網頁,發現還是不一緻,過一會會就好了
  • 所有資料共享位址: http://pan.baidu.com/s/1c15ldEK