设为首页 收藏本站
查看: 567|回复: 0

[经验分享] nginx+tomcat+memcached构建session共享集群

[复制链接]
累计签到:1 天
连续签到:1 天
发表于 2016-7-13 09:03:25 | 显示全部楼层 |阅读模式
一、安装配置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两种
tomcat的下载地址:http://tomcat.apache.org/
c1.xsllqs.com(192.168.1.114)下载安装jdk(建议加载到本地在传上去)和tomcat
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
[iyunv@c1 ~]# wget http://download.oracle.com/otn-p ... -8u73-linux-x64.rpm
[iyunv@c1 ~]# wget http://mirror.bit.edu.cn/apache/ ... omcat-8.0.36.tar.gz
[iyunv@c1 ~]# ls
apache-tomcat-8.0.36.tar.gz  jdk-8u73-linux-x64.rpm

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

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

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

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

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



c2.xsllqs.com(192.168.1.113)下载安装jdk和tomcat
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
[iyunv@c2 ~]# wget http://download.oracle.com/otn-p ... -8u73-linux-x64.rpm
[iyunv@c2 ~]# wget http://mirror.bit.edu.cn/apache/ ... omcat-8.0.36.tar.gz
[iyunv@c2 ~]# ls
apache-tomcat-8.0.36.tar.gz  jdk-8u73-linux-x64.rpm
[iyunv@c2 ~]# yum install jdk-8u73-linux-x64.rpm
[iyunv@c2 ~]# vim /etc/profile.d/java.sh
export JAVA_HOME=/usr/java/latest
export PATH=$JAVA_HOME/bin:$PATH

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

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

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

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



二、修改tomcat配置文件
1
2
3
[iyunv@c1 tomcat]# cd /usr/local/tomcat/webapps/
[iyunv@c1 webapps]# mkdir myapp/{lib,classes,WEB-INF,META-INF} -pv
[iyunv@c1 webapps]# cd myapp/



添加c1和c2的主页文件
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
[iyunv@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>

[iyunv@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都要改)
1
2
3
4
5
[iyunv@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都要改)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
[iyunv@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>



测试配置文件
1
2
3
4
[iyunv@c1 ~]# catalina.sh configtest
[iyunv@c2 ~]# catalina.sh configtest
[iyunv@c1 ~]# catalina.sh start
[iyunv@c2 ~]# catalina.sh start



三、安装msm
c1和c2上下载msm需要的jar包
1
2
3
4
5
6
7
[iyunv@c1 ~]# wget http://repo1.maven.org/maven2/de ... n-manager-1.9.4.jar
[iyunv@c1 ~]# wget http://repo1.maven.org/maven2/de ... nager-tc8-1.9.4.jar
[iyunv@c1 ~]# wget http://repo1.maven.org/maven2/de ... erializer-1.9.4.jar
[iyunv@c1 ~]# wget http://repo1.maven.org/maven2/ne ... emcached-2.11.1.jar
[iyunv@c1 ~]# wget http://www.java2s.com/Code/JarDo ... ion-5.4.3.1.jar.zip

[iyunv@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
1
2
[iyunv@m1 ~]# yum install memcached
[iyunv@c2 ~]# yum install memcached



m1上安装nginx修改nginx的配置文件
1
2
3
4
5
6
7
8
9
10
11
12
[iyunv@m1 ~]# yum install nginx
[iyunv@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;
    }
[iyunv@m1 ~]# nginx -t



启动服务
[iyunv@m1 ~]# systemctl start nginx.service[iyunv@m1 ~]# systemctl start memcached[iyunv@c2 ~]# systemctl start memcached四、测试
1466856090346241.jpg
1466856132442425.jpg
1466856090746365.jpg


运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-243360-1-1.html 上篇帖子: 利用Nginx sub模块对网页内容进行替换 下篇帖子: nginx简介及安装
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表