使用memcached缓存tomcat7会话信息

简介:
tomcat7 + memcached

全部系统采用centos7.1 

各节点配置好hosts文件
cat /etc/hosts
172.16.92.1    node1.centos7.com    node1
172.16.92.2    node2.centos7.com    node2
172.16.92.3    node3.centos7.com    node3
172.16.92.6    node6.centos7.com    node6
172.16.92.7    node7.centos7.com    node7

node1 --> nginx反向代理至两个tomcat节点
node2, node3 --> tomcat把session信息存储在两个memcached中
node6, node7 --> memcached ()


================ node6 172.16.92.6/16 ===================
mount /dev/cdrom /mnt/cdrom/
yum -y install memcached
systemctl start memcached
netstat -taunl | grep 11211


================ node7 172.16.92.7/16 ===================
mount /dev/cdrom /mnt/cdrom/
yum -y install memcached
systemctl start memcached
netstat -taunl | grep 11211


================ node2 172.16.92.2/16 ===================

mount /dev/cdrom /mnt/cdrom/
yum -y install tomcat
mkdir -pv /data/webapps/ROOT/{lib,classes,META-INF,WEB-INF}
vim /data/webapps/ROOT/index.jsp
<%@ page language="java" %>
<html>
  <head><title>TomcatA</title></head>
  <body>
    <h1><font color="red">TomcatA.centos7.com</font></h1>
    <table align="centre" border="1">
      <tr>
        <td>Session ID</td>
    <% session.setAttribute("centos7.com","centos7.com"); %>
        <td><%= session.getId() %></td>
      </tr>
      <tr>
        <td>Created on</td>
        <td><%= session.getCreationTime() %></td>
     </tr>
    </table>
  </body>
</html>
============================
cd /usr/share/tomcat/lib
wget http://repo1.maven.org/maven2/de/javakaffee/msm/memcached-session-manager-tc7/1.8.3/memcached-session-manager-tc7-1.8.3.jar
wget http://repo1.maven.org/maven2/de/javakaffee/msm/memcached-session-manager/1.8.3/memcached-session-manager-1.8.3.jar
wget http://repo1.maven.org/maven2/de/javakaffee/msm/msm-javolution-serializer/1.8.3/msm-javolution-serializer-1.8.3.jar
wget http://mirrors.ibiblio.org/maven2/net/spy/spymemcached/2.11.1/spymemcached-2.11.1.jar
wget http://www.java2s.com/Code/JarDownload/javolution/javolution-5.4.3.1.jar.zip
unzip javolution-5.4.3.1.jar.zip

cp /etc/tomcat/server.xml{,.bak}
vim /etc/tomcat/server.xml
<Engine name="Catalina" defaultHost="node2.centos7.com">
<Host name="node2.centos7.com"  appBase="/data/webapps"
            unpackWARs="true" autoDeploy="true">
        <Context path="" docBase="/data/webapps/ROOT" reloadable="true">
                <Manager className="de.javakaffee.web.msm.MemcachedBackupSessionManager"
                        memcachedNodes="n1:172.16.92.6:11211,n2:172.16.92.7:11211"
                        failoverNodes="n1"
                        requestUriIgnorePattern=".*\.(ico|png|gif|jpg|css|js)$"
                        transcoderFactoryClass="de.javakaffee.web.msm.serializer.javolution.JavolutionTranscoderFactory"/>
        </Context>
============================
systemctl start tomcat.service


windows浏览器访问 http://172.16.92.2:8080/
TomcatA.centos7.com
Session ID     AB327A3B9B86D87D51CB2D31297D2C4A-n2
Created on     1446005990634







================ node3 172.16.92.3/16 ===================

mount /dev/cdrom /mnt/cdrom/
yum -y install tomcat
mkdir -pv /data/webapps/ROOT/{lib,classes,META-INF,WEB-INF}
vim /data/webapps/ROOT/index.jsp
<%@ page language="java" %>
<html>
  <head><title>TomcatB</title></head>
  <body>
    <h1><font color="blue">TomcatB.centos7.com</font></h1>
    <table align="centre" border="1">
      <tr>
        <td>Session ID</td>
    <% session.setAttribute("centos7.com","centos7.com"); %>        
        <td><%= session.getId() %></td>
      </tr>
      <tr>
        <td>Created on</td>
        <td><%= session.getCreationTime() %></td>
     </tr>    </table>
  </body>
</html>
============================
cd /usr/share/tomcat/lib
wget http://www.java2s.com/Code/JarDownload/javolution/javolution-5.4.3.1.jar.zip
wget http://mirrors.ibiblio.org/maven2/net/spy/spymemcached/2.11.1/spymemcached-2.11.1.jar
wget http://repo1.maven.org/maven2/de/javakaffee/msm/msm-javolution-serializer/1.8.3/msm-javolution-serializer-1.8.3.jar
wget http://repo1.maven.org/maven2/de/javakaffee/msm/memcached-session-manager/1.8.3/memcached-session-manager-1.8.3.jar
wget http://repo1.maven.org/maven2/de/javakaffee/msm/memcached-session-manager-tc7/1.8.3/memcached-session-manager-tc7-1.8.3.jar
unzip javolution-5.4.3.1.jar.zip

cp /etc/tomcat/server.xml{,.bak}
vim /etc/tomcat/server.xml
<Engine name="Catalina" defaultHost="node3.centos7.com">
<Host name="node3.centos7.com"  appBase="/data/webapps"
            unpackWARs="true" autoDeploy="true">
        <Context path="" docBase="/data/webapps/ROOT" reloadable="true">
                <Manager className="de.javakaffee.web.msm.MemcachedBackupSessionManager"
                        memcachedNodes="n1:172.16.92.6:11211,n2:172.16.92.7:11211"
                        failoverNodes="n1"
                        requestUriIgnorePattern=".*\.(ico|png|gif|jpg|css|js)$"
                        transcoderFactoryClass="de.javakaffee.web.msm.serializer.javolution.JavolutionTranscoderFactory"/>
        </Context>
============================
systemctl start tomcat.service



windows浏览器访问 http://172.16.92.3:8080/
TomcatB.centos7.com
Session ID     B22E48AA2A89BCE2BAD4021D9E912E03-n2
Created on     1446005950406










================ node1 172.16.92.1/16 ===================
nginx做tomcat1,2的反向代理和负载均衡

安装epel源
wget -O /etc/yum.repos.d/epel7.repo http://mirrors.aliyun.com/repo/epel-7.repo
yum -y install nginx
cd /etc/nginx
cp nginx.conf{,.bak}
vim nginx.conf
:1,$d -- 删除全部内容
:set paste --> 再粘贴如下内容
################
user nginx;
worker_processes auto;
error_log /var/log/nginx/error.log;
pid /run/nginx.pid;

events {
    worker_connections 1024;
}

http {
    log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '
                      '$status $body_bytes_sent "$http_referer" '
                      '"$http_user_agent" "$http_x_forwarded_for"';

    access_log  /var/log/nginx/access.log  main;

    sendfile            on;
    tcp_nopush          on;
    tcp_nodelay         on;
    keepalive_timeout   65;
    types_hash_max_size 2048;

    include             /etc/nginx/mime.types;
    default_type        application/octet-stream;
    include /etc/nginx/conf.d/*.conf;
    upstream tcsrvs {
        server node2.centos7.com:8080;
        server node3.centos7.com:8080;
    }
    server {
        listen       80 default_server;
        listen       [::]:80 default_server;
        server_name  _;
        root         /usr/share/nginx/html;

        # Load configuration files for the default server block.
        include /etc/nginx/default.d/*.conf;

        location / {
        }
        location ~* \.(jsp|do)$ {
                proxy_pass http://tcsrvs;
        }

        error_page 404 /404.html;
            location = /40x.html {
        }

        error_page 500 502 503 504 /50x.html;
            location = /50x.html {
        }
    }
}
==================end of nginx.conf
nginx -t
>出现ok和successful相关句子就没问题了
systemctl start nginx.service
ss -tanl | grep 80



windows浏览器访问 http://172.16.92.1/index.jsp, 在下面两个页面轮询,但是会话ID是一样的
-----------------------------------------------------------------------
TomcatA.centos7.com
Session ID     DE4FB78238A882475C86E1735779F5C9-n2
Created on     1446006726402
-----------------------------------------------------------------------
TomcatB.centos7.com
Session ID     DE4FB78238A882475C86E1735779F5C9-n2
Created on     1446006726402
-----------------------------------------------------------------------





================ node7 172.16.92.6/16 ===================
systemctl stop memcached

windows浏览器访问 http://172.16.92.1/index.jsp, 在下面两个页面轮询,
但是会话ID是一样的, 并且会话ID是从另一个缓存服务器取得.
-----------------------------------------------------------------------
TomcatA.centos7.com
Session ID     DE4FB78238A882475C86E1735779F5C9-n1
Created on     1446007835727
-----------------------------------------------------------------------
TomcatB.centos7.com
Session ID     DE4FB78238A882475C86E1735779F5C9-n1
Created on     1446007835727
-----------------------------------------------------------------------







本文转自 zhuhc1988 51CTO博客,原文链接:http://blog.51cto.com/changeflyhigh/1707491,如需转载请自行联系原作者
目录
相关文章
|
2月前
|
存储 缓存 Java
Java中的分布式缓存与Memcached集成实战
通过在Java项目中集成Memcached,可以显著提升系统的性能和响应速度。合理的缓存策略、分布式架构设计和异常处理机制是实现高效缓存的关键。希望本文提供的实战示例和优化建议能够帮助开发者更好地应用Memcached,实现高性能的分布式缓存解决方案。
51 9
|
4月前
|
存储 缓存 JavaScript
利用缓存布局信息来减少回流和重绘的发生
【10月更文挑战第24天】通过合理利用缓存布局信息,我们可以在一定程度上降低回流和重绘的发生频率,提高页面的性能和用户体验。这是前端性能优化中的一个重要环节,需要我们在实践中不断探索和总结经验,以找到最适合的解决方案。
|
5月前
|
存储 缓存 NoSQL
保持HTTP会话状态:缓存策略与实践
保持HTTP会话状态:缓存策略与实践
|
7月前
|
Java 应用服务中间件 开发工具
[App Service for Windows]通过 KUDU 查看 Tomcat 配置信息
[App Service for Windows]通过 KUDU 查看 Tomcat 配置信息
|
8月前
|
存储 缓存 算法
深入了解Memcached:缓存技术的利器
Memcached是一个开源的高性能分布式内存缓存系统,用于加速动态Web应用。它通过将数据库查询结果、API调用结果或其他数据缓存到内存中,减少对数据库的访问频率,从而提高应用的响应速度。本文详细介绍了Memcached的基本原理、架构、安装配置、使用方法、测试方法以及应用场景。通过Memcached,开发者可以有效提升Web应用的性能,减少数据库负载,改善用户体验。
141 5
|
7月前
|
存储 缓存 关系型数据库
Django后端架构开发:缓存机制,接口缓存、文件缓存、数据库缓存与Memcached缓存
Django后端架构开发:缓存机制,接口缓存、文件缓存、数据库缓存与Memcached缓存
180 0
|
7月前
|
缓存 前端开发 Java
【Azure 应用服务】App Service 使用Tomcat运行Java应用,如何设置前端网页缓存的相应参数呢(-Xms512m -Xmx1204m)?
【Azure 应用服务】App Service 使用Tomcat运行Java应用,如何设置前端网页缓存的相应参数呢(-Xms512m -Xmx1204m)?
|
7月前
|
缓存 关系型数据库 MySQL
【缓存大对决】Memcached VS MySQL查询缓存,谁才是真正的性能之王?
【8月更文挑战第24天】在现代Web应用中,缓存技术对于提升性能与响应速度至关重要。本文对比分析了Memcached与MySQL查询缓存这两种常用方案。Memcached是一款高性能分布式内存对象缓存系统,支持跨服务器共享缓存,具备灵活性与容错性,但受限于内存大小且不支持数据持久化。MySQL查询缓存内置在MySQL服务器中,简化了缓存管理,特别适用于重复查询,但功能较为单一且扩展性有限。两者各有所长,实际应用中可根据需求单独或结合使用,实现最佳性能优化。
268 0
|
9月前
|
缓存 负载均衡 NoSQL
Redis系列学习文章分享---第十四篇(Redis多级缓存--封装Http请求+向tomcat发送http请求+根据商品id对tomcat集群负载均衡)
Redis系列学习文章分享---第十四篇(Redis多级缓存--封装Http请求+向tomcat发送http请求+根据商品id对tomcat集群负载均衡)
109 1
|
9月前
|
缓存 Java Spring
SpringBoot配置第三方专业缓存技术Memcached 下载 安装 整合测试 2024年5000字详解
SpringBoot配置第三方专业缓存技术Memcached 下载 安装 整合测试 2024年5000字详解
69 0