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

[经验分享] Nginx+Tomcat+Memcached+kryo序列化集群Session共享

[复制链接]
累计签到:1 天
连续签到:1 天
发表于 2016-4-18 10:42:57 | 显示全部楼层 |阅读模式
架构(一共使用3台主机,其中nginx主机上运行2个memcached实例,端口分别是11211、11212)
wKiom1cTNb7T2e_eAABhFO3HtQQ489.jpg

环境配置说明:
软件:Centos6.7、tomcat8.0、memcached1.4.4、nginx1.4.7、jdk-8u65-linux-x64、
实现msm+kryo必须的包,一共9个:
(注意:不同版本的tomcat,必须下载对应的memcached-session-manager包)
        spymemcached-2.11.4
         reflectasm-1.01
         msm-kryo-serializer-1.8.2
         minlog-1.2
         memcached-session-manager-tc8-1.8.2
         memcached-session-manager-1.8.2
         kryo-serializers-0.11
         kryo-1.04
         asm-3.2

nginx服务器 IP:192.168.61.161
tomcat223服务器IP :192.168.61.223
tomcat224服务器IP: 192.168.61.224


1、nginx服务器配置
(1)
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
/etc/nginx/nginx.conf内容如下:
worker_processes  1;
  events {
      worker_connections  1024;
   }

  http {
      include       mime.types;
      default_type  application/octet-stream;
      sendfile        on;
     keepalive_timeout  65;

upstream tomcatserver{
server 192.168.61.224:8080;
server 192.168.61.223:8080;
  }

     server {
         listen       80;
         server_name  192.168.61.161;
        location / {
             root   html;
          proxy_pass http://tomcatserver;
          proxy_set_header  X-Real-IP  $remote_addr;
          client_max_body_size  100m;
             index  index.html index.htm;
         }
         error_page   500 502 503 504  /50x.html;
         location = /50x.html {
             root   html;
         }

      }
  }





(2)memcached安装
yum -y install memcached
启动两个memcached实例
memcached -d -p 11211
memcached -d -p 11212

2、tomcat223服务器安装
(1)安装JDK
    rpm -ivh jdk-8u65-linux-x64.rpm
    配置环境:
    vim /etc/profile.d/java.sh
      export JAVA_HOME=/usr/java/latest
      export PATH=$JAVA_HOME/bin:$PATH

保存后source /etc/profile.d/java.sh立即生效

(2)安装tomcat
tar -xvzf apache-tomcat-8.0.28.tar -C/usr/local/
ln -sv /usr/local/apache-tomcat-8.0.28/usr/local/tomcat
配置环境变量:
vim /etc/profile.d/tomcat.sh
exportCATALINA_HOME="/usr/local/tomcat"
export PATH=$CATALINA_HOME/bin:$PATH

保存后source /etc/profile.d/tomcat.sh 立即生效

(3)测试主页添加与session共享配置
添加一个test应用和test.jsp
mkdir -pv/usr/local/tomcat/webapps/test/{WEB-INF,lib,class,META-INF}
vim /usr/local/tomcat/webapps/test/test.jsp
  SessionID:<%=session.getId()%>
  

  SessionIP:<%=request.getServerName()%>
  

  SessionPort:<%=request.getServerPort()%>
  <%
  out.println("This is Tomcat Server 8080 8080 ");
  %>

编辑/usr/local/tomcat/conf/server.xml 在Host段中添加以下Context内容
  
<managerclassname="de.javakaffee.web.msm.memcachedbackupsessionmanager"
  memcachedNodes="n1:192.168.61.161:11211,n2:192.168.61.161:11212"
  failoverNodes="n1"
  requestUriIgnorePattern=".*.(ico|png|gif|jpg|css|js)$"
  transcoderFactoryClass="de.javakaffee.web.msm.serializer.kryo.KryoTranscoderFactory"
  />
</managerclassname="de.javakaffee.web.msm.memcachedbackupsessionmanager"


重启tomcat
catalina.sh stop
catalina.sh start


3、tomcat224服务器安装
安装步骤同上,只是/usr/local/tomcat/conf/server.xml 添加的Context内容有点不一样

  
<manager classname="de.javakaffee.web.msm.MemcachedBackupSessionManager"
  memcachedNodes="n1:192.168.61.161:11211,n2:192.168.61.161:11212"
  failoverNodes="n2"
  requestUriIgnorePattern=".*.(ico|png|gif|jpg|css|js)$"
  transcoderFactoryClass="de.javakaffee.web.msm.serializer.kryo.KryoTranscoderFactory"
  />



4、测试
访问http://192.168.61.161/test/test.jsp
wKioL1cTNpDCXvPqAAA4BNDFM94631.jpg

SessionID始终是不变的,可以测试把tomcat223和tomcat224服务器的tomcat服务停止一段时间再启动,再次访问,还是之前那个SessionID,由此可见,tomcat的Session是保存在memcached上的


wKioL1cTNpDCXvPqAAA4BNDFM94631.jpg
wKiom1cTNb7T2e_eAABhFO3HtQQ489.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-205569-1-1.html 上篇帖子: nginx+tomcat实现动静分离 下篇帖子: 收集整理的Nginx的面试题
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

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

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

扫描微信二维码查看详情

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


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


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


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



合作伙伴: 青云cloud

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