Nginx/httpd 代理兩個Tomcat

Nginx

前端代理服務器172.16.71.1

從ftp下載Nginx

安裝

vim /etc/nginx/nginx.conf

http {
...
# 添加以下內容
upstream tcsrvs {
        server 172.16.71.4:8080;
        server 172.16.71.5:8080;
    }
...
}
vim /etc/nginx/conf.d/default.conf

location / {
   root   /usr/share/nginx/html;
   proxy_pass http://tcsrvs/;  #添加此行
   index  index.html index.htm;
}

后端Tomcat服務器

172.16.71.4172.16.71.5

兩個主機都要安裝jdk和Tomcat

yum install java-1.8.0-openjdk-devel -y
yum install tomcat -y

主機1

mkdir -pv /var/lib/tomcat/webapps/test/{lib,classes,WEB-INF}
vim /var/lib/tomcat/webapps/test/index.jsp


<%@ page language="java" %>
<html>
 <head><title>TomcatA</title></head>
 <body>
   <h1><font color="red">TomcatA.magedu.com</font></h1>
   <table align="centre" border="1">
     <tr>
       <td>Session ID</td>
   <% session.setAttribute("magedu.com","magedu.com"); %>
       <td><%= session.getId() %></td>
     </tr>
     <tr>
       <td>Created on</td>
       <td><%= session.getCreationTime() %></td>
    </tr>
   </table>
 </body>
</html>


systemctl start tomcat

主機2

mkdir -pv /var/lib/tomcat/webapps/test/{lib,classes,WEB-INF}
vim /var/lib/tomcat/webapps/test/index.jsp


<%@ page language="java" %>
<html>
 <head><title>TomcatB</title></head>
 <body>
   <h1><font color="red">TomcatB.magedu.com</font></h1>
   <table align="centre" border="1">
     <tr>
       <td>Session ID</td>
   <% session.setAttribute("magedu.com","magedu.com"); %>
       <td><%= session.getId() %></td>
     </tr>
     <tr>
       <td>Created on</td>
       <td><%= session.getCreationTime() %></td>
    </tr>
   </table>
 </body>
</html>

systemctl start tomcat

前端代理

systemctl start nginx 

測試

從瀏覽器訪問172.16.71.1,顯示Tomcat歡迎頁面

從瀏覽器訪問172.16.71.1/test,顯示測試頁面信息,刷新會變化。


httpd

yum install httpd -y

vim /etc/httpd/conf.d/tomcat_httpd.conf

<proxy balancer://tcsrvs>
   BalancerMember http://172.16.71.4:8080
   BalancerMember http://172.16.71.5:8080
   ProxySet lbmethod=byrequests
</Proxy>
<VirtualHost *:80>
   ServerName www.magedu.com
   ProxyVia On
   ProxyRequests Off
   ProxyPreserveHost On
   <Proxy *>
       Require all granted
   </Proxy>
       ProxyPass / balancer://tcsrvs/
       ProxyPassReverse / balancer://tcsrvs/
   <Location />
       Require all granted
   </Location>
</VirtualHost>    

systemctl start httpd

測試

從瀏覽器訪問172.16.71.1,顯示Tomcat歡迎頁面

從瀏覽器訪問172.16.71.1/test,顯示測試頁面信息,刷新會變化。


實現會話粘性方法

172.16.71.4

vim /etc/tomcat/server.xml

   <Engine name="Catalina" defaultHost="localhost" jvmRoute="TomcatA"> #修改此行


systemctl restart tomcat

172.16.71.5

vim /etc/tomcat/server.xml

   <Engine name="Catalina" defaultHost="localhost" jvmRoute="TomcatB"> #修改此行

systemctl restart tomcat

172.16.71.1

vim /etc/httpd/conf.d/tomcat_httpd.conf

Header add Set-Cookie "ROUTEID=.%{BALANCER_WORKER_ROUTE}e; path=/" env=BALANCER_ROUTE_CHANGED
<proxy balancer://tcsrvs>
   BalancerMember http://172.18.100.67:8080 route=TomcatA loadfactor=1
   BalancerMember http://172.18.100.68:8080 route=TomcatB loadfactor=2
   ProxySet lbmethod=byrequests
   ProxySet stickysession=ROUTEID
</Proxy>
<VirtualHost *:80>
   ServerName lb.magedu.com
   ProxyVia On
   ProxyRequests Off
   ProxyPreserveHost On
   <Proxy *>
       Require all granted
   </Proxy>
   ProxyPass / balancer://tcsrvs/
   ProxyPassReverse / balancer://tcsrvs/
   <Location />
       Require all granted
   </Location>
</VirtualHost>  

systemctl restart httpd

測試

從瀏覽器訪問172.16.71.1,顯示Tomcat歡迎頁面

從瀏覽器訪問172.16.71.1/test,顯示測試頁面信息,刷新不會變化。


啟用管理接口

vim /etc/httpd/conf.d/balaner_manager.conf

<Location /balancer-manager>
   SetHandler balancer-manager
   ProxyPass !
   Require all granted
</Location>            

systemctl restart httpd

測試

瀏覽器訪問172.16.71.1/balancer-manager會出現管理接口

ajp balancer

vim /etc/httpd/conf.d/tomcat-ajp.conf

<proxy balancer://tcsrvs>
   BalancerMember ajp://172.16.71.4:8009
   BalancerMember ajp://172.16.71.5:8009
   ProxySet lbmethod=byrequests
</Proxy>
<VirtualHost *:80>
   ServerName lb.magedu.com
   ProxyVia On
   ProxyRequests Off
   ProxyPreserveHost On
   <Proxy *>
       Require all granted
   </Proxy>
   ProxyPass / balancer://tcsrvs/
   ProxyPassReverse / balancer://tcsrvs/
   <Location />
       Require all granted
   </Location>
   <Location /balancer-manager>
       SetHandler balancer-manager
       ProxyPass !
       Require all granted
   </Location>
</VirtualHost>  

測試

從瀏覽器訪問172.16.71.1,顯示Tomcat歡迎頁面

從瀏覽器訪問172.16.71.1/test,顯示測試頁面信息,刷新會變化。

會話綁定與前面相似

vim /etc/httpd/conf.d/tomcat-ajp.conf

<proxy balancer://tcsrvs>
   BalancerMember ajp://172.16.71.4:8009 route=TomcatA loadfactor=1
   BalancerMember ajp://172.16.71.5:8009 route=TomcatB loadfactor=1
   ProxySet lbmethod=byrequests
</Proxy>
<VirtualHost *:80>
   ServerName lb.magedu.com
   ProxyVia On
   ProxyRequests Off
   ProxyPreserveHost On
   <Proxy *>
       Require all granted
   </Proxy>
   ProxyPass / balancer://tcsrvs/
   ProxyPassReverse / balancer://tcsrvs/
   <Location />
       Require all granted
   </Location>
   <Location /balancer-manager>
       SetHandler balancer-manager
       ProxyPass !
       Require all granted
   </Location>
</VirtualHost>  

Tomcat集群

172.16.71.4

vim /etc/tomcat/server.xml

    <Engine name="Catalina" defaultHost="localhost" jvmRoute="TomcatA"> # jvmRoute 一定要有

       <Cluster className="org.apache.catalina.ha.tcp.SimpleTcpCluster"
                channelSendOptions="8">

         <Manager className="org.apache.catalina.ha.session.DeltaManager"
                  expireSessionsOnShutdown="false"
                  notifyListenersOnReplication="true"/>

         <Channel className="org.apache.catalina.tribes.group.GroupChannel">
           <Membership className="org.apache.catalina.tribes.membership.McastService"
                       address="228.0.71.4"
                       port="45564"
                       frequency="500"
                       dropTime="3000"/>
           <Receiver className="org.apache.catalina.tribes.transport.nio.NioReceiver"
                     address="172.16.71.4"
                     port="4000"
                     autoBind="100"
                     selectorTimeout="5000"
                     maxThreads="6"/>

           <Sender className="org.apache.catalina.tribes.transport.ReplicationTransmitter">
             <Transport className="org.apache.catalina.tribes.transport.nio.PooledParallelSender"/>
           </Sender>
           <Interceptor className="org.apache.catalina.tribes.group.interceptors.TcpFailureDetector"/>
           <Interceptor className="org.apache.catalina.tribes.group.interceptors.MessageDispatch15Interceptor"/>
         </Channel>

         <Valve className="org.apache.catalina.ha.tcp.ReplicationValve"
                filter=""/>
         <Valve className="org.apache.catalina.ha.session.JvmRouteBinderValve"/>

         <Deployer className="org.apache.catalina.ha.deploy.FarmWarDeployer"
                   tempDir="/tmp/war-temp/"
                   deployDir="/tmp/war-deploy/"
                   watchDir="/tmp/war-listen/"
                   watchEnabled="false"/>

         <ClusterListener className="org.apache.catalina.ha.session.ClusterSessionListener"/>
       </Cluster>
cp /etc/tomcat/web.xml  /var/lib/tomcat/webapps/test/WEB-INF/
vim /var/lib/tomcat/webapps/test/WEB-INF/web.xml

<distributable/> # 添加

systemctl restart tomcat

172.16.71.5同理

vim /etc/tomcat/server.xml

    <Engine name="Catalina" defaultHost="localhost" jvmRoute="TomcatB"> # jvmRoute 一定要有

       <Cluster className="org.apache.catalina.ha.tcp.SimpleTcpCluster"
                channelSendOptions="8">

         <Manager className="org.apache.catalina.ha.session.DeltaManager"
                  expireSessionsOnShutdown="false"
                  notifyListenersOnReplication="true"/>

         <Channel className="org.apache.catalina.tribes.group.GroupChannel">
           <Membership className="org.apache.catalina.tribes.membership.McastService"
                       address="228.0.71.4"
                       port="45564"
                       frequency="500"
                       dropTime="3000"/>
           <Receiver className="org.apache.catalina.tribes.transport.nio.NioReceiver"
                     address="172.16.71.5"
                     port="4000"
                     autoBind="100"
                     selectorTimeout="5000"
                     maxThreads="6"/>

           <Sender className="org.apache.catalina.tribes.transport.ReplicationTransmitter">
             <Transport className="org.apache.catalina.tribes.transport.nio.PooledParallelSender"/>
           </Sender>
           <Interceptor className="org.apache.catalina.tribes.group.interceptors.TcpFailureDetector"/>
           <Interceptor className="org.apache.catalina.tribes.group.interceptors.MessageDispatch15Interceptor"/>
         </Channel>

         <Valve className="org.apache.catalina.ha.tcp.ReplicationValve"
                filter=""/>
         <Valve className="org.apache.catalina.ha.session.JvmRouteBinderValve"/>

         <Deployer className="org.apache.catalina.ha.deploy.FarmWarDeployer"
                   tempDir="/tmp/war-temp/"
                   deployDir="/tmp/war-deploy/"
                   watchDir="/tmp/war-listen/"
                   watchEnabled="false"/>

         <ClusterListener className="org.apache.catalina.ha.session.ClusterSessionListener"/>
       </Cluster>
cp /etc/tomcat/web.xml  /var/lib/tomcat/webapps/test/WEB-INF/
vim /var/lib/tomcat/webapps/test/WEB-INF/web.xml

<distributable/> # 添加

systemctl restart tomcat

測試

從瀏覽器訪問172.16.71.1,顯示Tomcat歡迎頁面

從瀏覽器訪問172.16.71.1/test,顯示測試頁面信息,刷新不會變化。

注意:一定要先為主機配置網關,否則Tomcat將無法啟動


memcached 實現session存儲

172.16.71.4172.16.71.5

vim /etc/tomcat/server.xml

# 刪除上一步添加的內容

systemctl stop tomcat
yum install memcached -y

systemctl start memcached

下載類庫

cd /usr/share/tomcat/lib
lftp 172.16.0.1
cd pub/Sources/7.x86_64/msm/
mget *
bye
vim /etc/tomcat/server.xml

#在<Host>中添加:
<Context path="/" docBase="test" reloadable="true">
</Context>

systemctl start tomcat

測試

從瀏覽器訪問172.16.71.1,顯示Tomcat歡迎頁面

從瀏覽器訪問172.16.71.1/test,顯示測試頁面信息,刷新不會變化。

添加session保持

172.16.71.4 172.16.71.5

vim /etc/tomcat/server.xml

     <Host name="localhost"  appBase="webapps"
           unpackWARs="true" autoDeploy="true">
               <Context path="/sample" docBase="sample" reloadable="true">
                 <Manager className="de.javakaffee.web.msm.MemcachedBackupSessionManager"
                     memcachedNodes="n1:172.16.71.4:11211,n2:172.16.71.5:11211"
                     failoverNodes="n1"
                     requestUriIgnorePattern=".*\.(ico|png|gif|jpg|css|js)$"
                     transcoderFactoryClass="de.javakaffee.web.msm.serializer.javolution.JavolutionTranscoderFactory"


systemctl restart tomcat

測試

從瀏覽器訪問172.16.71.1,顯示Tomcat歡迎頁面

從瀏覽器訪問172.16.71.1/sample,顯示測試頁面信息,刷新session不會變化,內容會變化。

注意:此處前端要使用Nginx,httpd不能實現以上功能,原因未知。

原創文章,作者:wangshuai,如若轉載,請注明出處:http://www.www58058.com/68251

(1)
wangshuaiwangshuai
上一篇 2017-02-12
下一篇 2017-02-13

相關推薦

  • 磁盤管理

    設備文件 I/O Ports: I/O 設備地址 一切皆文件: open(), read(), write(), close() 設備類型: 塊設備:block ,存取單位“塊”,磁盤 [root@localhost ~]# ll /dev/ brw-rw—-. 1 root disk 253, 0 Apr 29 03:53 dm-0 塊設備 brw-r…

    2017-04-28
  • 鏈接分析算法之:HITS算法

     HITS(HITS(Hyperlink – Induced Topic Search) ) 算法是由康奈爾大學( Cornell University ) 的Jon Kleinberg 博士于1997 年首先提出的,為IBM 公司阿爾馬登研究中心( IBM Almaden Research Center) 的名為“CLEVER”的研究…

    開發運維 2015-07-20
  • bash特性

    一、命令歷史     概念:shell進程能夠將之前執行過的命令保存記錄下來     存儲位置:         1、命令歷史的文件             使用以下環境變量查看相關參數:     &…

    Linux干貨 2016-09-19
  • 第一周初入Linux世界 —馬哥教育網絡班N22_第一周課程練習

    一、描述計算機的組成及其功能        計算機體系結構以圖靈機理論為基礎,屬于馮·諾依曼體系結構。    計算機由運算器、控制器、寄存器、輸入輸出設備組成            運算器:是計算機中執行各種算術和邏輯運算操作的部件。運算器…

    Linux干貨 2016-08-15
  • haproxy 動靜分離負載均衡、?stats頁面實現?。

    實驗環境:一臺主機提供haproxy、nfs、mariadb,后端2臺apache部署wordpress。 實驗目的:haproxy使得動靜分離、以及開啟stats頁面。 haproxy簡單介紹 負載均衡的解決方案,支持4、7層,特點是單進程模型(可配置為多進程模型)單進程能支持非常大的并發鏈接數量(相比較其他軟件)。 到今天,馬哥課程中的負載均衡方案(lv…

    Linux干貨 2017-02-18
  • Linux shell之bash特性大全詳解(持續更新ing)

    一、shell是什么?     Shell本身是一個用C語言編寫的程序,它是用戶使用Unix/Linux的橋梁,用戶的大部分工作都是通過Shell完成的。Shell既是一種命令語言,又是一種程序設計語言。作為命令語言,它交互式地解釋和執行用戶輸入的命令;作為程序設計語言,它定義了各種變量和參數,并提供了許多在高級語言中…

    Linux干貨 2016-03-09
欧美性久久久久