nginx+tomcat+memcached構建session共享集群

一、安裝配置tomcat

配置前說明:

系統為centos7

m1.xsllqs.com地址為192.168.1.107

c1.xsllqs.com地址為192.168.1.114

c2.xsllqs.com地址為192.168.1.113

安裝tomcat需要配合JDK使用,JDK有oracle JDK和open JDK兩種

oracle JDK8的下載地址:http://www.oracle.com/technetwork/cn/java/javase/downloads/jdk8-downloads-2133151-zhs.html

tomcat的下載地址:http://tomcat.apache.org/

c1.xsllqs.com(192.168.1.114)下載安裝jdk(建議加載到本地在傳上去)和tomcat

[root@c1 ~]# wget http://download.oracle.com/otn-pub/java/jdk/8u73-b02/jdk-8u73-linux-x64.rpm
[root@c1 ~]# wget http://mirror.bit.edu.cn/apache/tomcat/tomcat-8/v8.0.36/bin/apache-tomcat-8.0.36.tar.gz
[root@c1 ~]# ls
apache-tomcat-8.0.36.tar.gz  jdk-8u73-linux-x64.rpm

[root@c1 ~]# yum install jdk-8u73-linux-x64.rpm
[root@c1 ~]# vim /etc/profile.d/java.sh
export JAVA_HOME=/usr/java/latest
export PATH=$JAVA_HOME/bin:$PATH

[root@c1 ~]# . /etc/profile.d/java.sh
[root@c1 ~]# java -version
java version "1.8.0_73"

[root@c1 ~]# tar xf apache-tomcat-8.0.36.tar.gz -C /usr/local
[root@c1 ~]# cd /usr/local/
[root@c1 local]# ln -sv apache-tomcat-8.0.36 tomcat
"tomcat" -> "apache-tomcat-8.0.36"

[root@c1 tomcat]# vim /etc/profile.d/tomcat.sh
export CATALINA_HOME=/usr/local/tomcat
export PATH=$CATALINA_HOME/bin:$PATH

[root@c1 tomcat]# . /etc/profile.d/tomcat.sh

c2.xsllqs.com(192.168.1.113)下載安裝jdk和tomcat

[root@c2 ~]# wget http://download.oracle.com/otn-pub/java/jdk/8u73-b02/jdk-8u73-linux-x64.rpm
[root@c2 ~]# wget http://mirror.bit.edu.cn/apache/tomcat/tomcat-8/v8.0.36/bin/apache-tomcat-8.0.36.tar.gz
[root@c2 ~]# ls
apache-tomcat-8.0.36.tar.gz  jdk-8u73-linux-x64.rpm
[root@c2 ~]# yum install jdk-8u73-linux-x64.rpm 
[root@c2 ~]# vim /etc/profile.d/java.sh
export JAVA_HOME=/usr/java/latest
export PATH=$JAVA_HOME/bin:$PATH

[root@c2 ~]# . /etc/profile.d/java.sh
[root@c2 ~]# java -version
java version "1.8.0_73"

[root@c2 ~]# tar xf apache-tomcat-8.0.36.tar.gz -C /usr/local
[root@c2 ~]# cd /usr/local/
[root@c2 local]# ln -sv apache-tomcat-8.0.36 tomcat
"tomcat" -> "apache-tomcat-8.0.36"

[root@c2 tomcat]# vim /etc/profile.d/tomcat.sh
export CATALINA_HOME=/usr/local/tomcat
export PATH=$CATALINA_HOME/bin:$PATH

[root@c2 tomcat]# . /etc/profile.d/tomcat.sh

二、修改tomcat配置文件

[root@c1 tomcat]# cd /usr/local/tomcat/webapps/
[root@c1 webapps]# mkdir myapp/{lib,classes,WEB-INF,META-INF} -pv
[root@c1 webapps]# cd myapp/

添加c1和c2的主頁文件

[root@c1 myapp]# vim indix.jsp
<%@ page language="java" %>
<html>
  <head><title>Tomcat1</title></head>
  <body>
    <h1><font color="red">c1.xsllqs.com</font></h1>
    <table align="centre" border="1">
      <tr>
        <td>Session ID</td>
    <% session.setAttribute("xsllqs.com","xsllqs.com"); %>
        <td><%= session.getId() %></td>
      </tr>
      <tr>
        <td>Created on</td>
        <td><%= session.getCreationTime() %></td>
     </tr>
    </table>
  </body>
</html>

[root@c2 myapp]# vim indix.jsp

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

修改tomcat-user.xml(c1和c2都要改)

[root@c1 conf]# vim /usr/local/tomcat/conf/tomcat-users.xml
#在</tomcat-users>中添加
  <role rolename="manager-gui"/>
  <role rolename="admin-gui"/>
  <user username="tomcat" password="<tomcat>" roles="manager-gui,admin-gui"/>

修改server.xml(c1和c2都要改)

[root@c1 conf]# vim /usr/local/tomcat/conf/server.xml
#修改主配置文件,appBase后面是應用的相對路徑也可以是絕對路徑
<Host name="localhost"  appBase="webapps"
unpackWARs="true" autoDeploy="true">
#這里是訪問日志的設置
<Valve className="org.apache.catalina.valves.AccessLogValve" directory="logs"
               prefix="localhost_access_log" suffix=".txt"
               pattern="%h %l %u %t &quot;%r&quot; %s %b" />
#這里設置Context調用msm需要的組件,m1為主c2為備,因為我這里只有3臺機器所以把c2作為備,正常情況是4臺,2臺memcached和2臺tomcat
<Context path="/myapp" docBase="/usr/local/tomcat/webapps/myapp" reloadable="true">
              <Manager className="de.javakaffee.web.msm.MemcachedBackupSessionManager"
               memcachedNodes="m1:192.168.1.107:11211,c2:192.168.1.113:11211"
                failoverNodes="m1"
                requestUriIgnorePattern=".*\.(ico|png|gif|jpg|css|js)$"
                transcoderFactoryClass="de.javakaffee.web.msm.serializer.javolution.JavolutionTranscoderFactory"
              />
             </Context>

測試配置文件

[root@c1 ~]# catalina.sh configtest
[root@c2 ~]# catalina.sh configtest
[root@c1 ~]# catalina.sh start
[root@c2 ~]# catalina.sh start

三、安裝msm

c1和c2上下載msm需要的jar包

[root@c1 ~]# wget http://repo1.maven.org/maven2/de/javakaffee/msm/memcached-session-manager/1.9.4/memcached-session-manager-1.9.4.jar
[root@c1 ~]# wget http://repo1.maven.org/maven2/de/javakaffee/msm/memcached-session-manager-tc8/1.9.4/memcached-session-manager-tc8-1.9.4.jar
[root@c1 ~]# wget http://repo1.maven.org/maven2/de/javakaffee/msm/msm-javolution-serializer/1.9.4/msm-javolution-serializer-1.9.4.jar
[root@c1 ~]# wget http://repo1.maven.org/maven2/net/spy/spymemcached/2.11.1/spymemcached-2.11.1.jar
[root@c1 ~]# wget http://www.java2s.com/Code/JarDownload/javolution/javolution-5.4.3.1.jar.zip

[root@c1 ~]# mv javolution-5.4.3.1.jar memcached-session-manager-1.9.4.jar memcached-session-manager-tc8-1.9.4.jar msm-javolution-serializer-1.9.4.jar spymemcached-2.11.1.jar /usr/local/tomcat/lib/

m1和c2上安裝memcached

[root@m1 ~]# yum install memcached
[root@c2 ~]# yum install memcached

m1上安裝nginx修改nginx的配置文件

[root@m1 ~]# yum install nginx
[root@m1 ~]# vim /etc/nginx/nginx.conf
#server外加入
upstream tcsrvs {
    server 192.168.1.114:8080;
    server 192.168.1.113:8080;
}
#server內加入
    location ~* \.(jsp|do)$ {
        proxy_pass http://tcsrvs;
    }
[root@m1 ~]# nginx -t

啟動服務

[root@m1 ~]# systemctl start nginx.service
[root@m1 ~]# systemctl start memcached
[root@c2 ~]# systemctl start memcached

四、測試

nginx+tomcat+memcached構建session共享集群

2016-6-25-tomcat-c2.jpg

nginx+tomcat+memcached構建session共享集群

原創文章,作者:N17_信風,如若轉載,請注明出處:http://www.www58058.com/20250

(0)
N17_信風N17_信風
上一篇 2016-06-26
下一篇 2016-06-26

相關推薦

  • 計算機的組成及其功能

        計算機是一種能接受和存儲信息,并按照存儲在其內部的程序對輸入的信息進行加工、處理,然后把處理結果輸出的高度自動化的電子設備。計算機是由運算器,控制器,存儲器,輸入裝置和輸出裝置五大部件組成,每一部件分別按要求執行特定的基本功能。如下圖所示: (1)  運算器或稱算術邏輯單元(Arithmetical and Logica…

    Linux干貨 2016-10-30
  • Nginx+resin調優文檔[原創]

    為什么不選擇Apache/mod+resin?       前面一直使用該模式,mod_caucho暴露源碼的bug一直未得到徹底的解決。因此切換到Nginx+resin平臺。硬件上要求除了內存一定要足夠大(建議>4G),無其它要求(當然也不能太破,呵呵)。操作系統強烈要求安裝64位,32位操…

    Linux干貨 2015-03-27
  • bash腳本編程實例

    bash腳本編程實例 1.寫一個腳本,判斷當前系統上所有用戶的shell是否為可登錄的shell(即用戶的shell不是/sbin/nologin),分別統計這兩類用戶的個數(通過字符串比較來實現) #!/bin/bash cat /etc/passwd|awk -F: ‘BEGIN{nologin=0;login=0}{if($NF==”/sbin/nol…

    Linux干貨 2017-08-28
  • 10月18日作業–hash,history

    1 生產環境發現一臺服務器系統時間產生偏差,造成服務異常,請幫忙校正。 1、使用ntpdate對時間進行同步,然后hwclock -w;并再建立Crontab每小時進行一次時間同步。 2 生產有一個數據同步腳本需要執行很長時間,怎樣做到無人值守,在管理工具退出的情況下,腳本依然能正常運行。 1、載光盤 2、進入/mnt/Packages 安裝共享screen…

    Linux干貨 2016-10-19
  • nfs,samba同步LAMP與Mysql

    使用nfs功能實現WEB頁面同步     拓撲圖見NFS實現LAMP冗余:     目的:使用網絡文件系實現LAMP的分步式資源共享    配置步驟:    配置test1:搭建NFS環境:&nbsp…

    2017-04-26
  • 26期全程班-第六周博客作業

    請詳細總結vim編輯器的使用并完成以下練習題 1、復制/etc/rc.d/rc.sysinit文件至/tmp目錄,將/tmp/rc.sysinit文件中的以至少一個空白字符開頭的行的行首加#; # cp /etc/rc.d/rc.sysinit /tmp # vim /tmp/rc.sysinit :%s@^\([[:space:]]\+\)@#\1@g 2…

    Linux干貨 2017-03-07

評論列表(2條)

欧美性久久久久