Nginx+Tomcat+Memcached 实现集群部署时Session共享

一.简介

我们系统经常要保存用户登录信息,有Cookie和Session机制,Cookie客户端保存用户信息,Session在服务端保存用户信息,如果浏览器不支持Cookie或者用户把Cookie禁掉了,Cookie就用不了,还有不同的浏览器采用不用方式保存Cookie,所以我们采用Session服务端来保存,上一节我们有介绍了Tomcat集群部署,怎么样集群的Tomcat对同个用户请求的都能获取保存在Session的用户信息,采用了Memcached管理Session,Memcached 是一个高性能的分布式内存对象缓存系统,接下来我们介绍Nginx+Tomcat+Memcached实现Session共享。

二.Tomcat、Nginx、Memcached配置

第一步:Memcached的安装部署Memcached部署 这查看这篇文章

第二步:Nginx的安装 Nginx的安装部署 这查看这篇文章

第三步:Tomcat和JDK的安装和环境配置 Tomcat和JDK的安装部署 这查看这篇文章

三.实现

我们采用Memcached管理Session,主要是memcached-session-manager开源tomcat插件改变Tomcat原始的Session存储机制,将session的存储放到分布式缓存Memcached中,从而实现对Session的共享。

  第一步:我们在Apache-tomcat-8081和Apache-tomcat-8082 下的ROOT实现一个index.jsp,如下代码所示:

     Apache-tomcat-8081的index.jsp

<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>Insert title here</title>
</head>
<body>

hello  apache-tomcat-8081 index.jsp

sessionId:<%=session.getId()%>
<BR>
sessionIp:<%=request.getServerName()%>
<BR>
sessionPort:<%=request.getServerPort()%>
</body>
</html>

Apache-tomcat-8082的index.jsp

<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>Insert title here</title>
</head>
<body>

hello  apache-tomcat-8082 index.jsp

sessionId:<%=session.getId()%>
<BR>
sessionIp:<%=request.getServerName()%>
<BR>
sessionPort:<%=request.getServerPort()%>
</body>
</html>

 第二步:启动Memcached服务

#/opt/bin/memcached -d -m 5 -u root -l 192.168.74.129 -p 12000 -c 256 -P /tmp/memcached.pid ,如图所示:

第三步:Nginx作为了代理服务器,客服端请求服务器端时,采用了负载均衡来处理,这样就能平均的把客服端请求分发到每一天服务器,这样减少服务器端的压力。实现动静态分离,配置Nginx下的nginx.conf文件。

#vi /usr/local/nginx/conf/nginx.conf

<span style="color:#333333;">#user  nobody;
worker_processes  1;
error_log  logs/error.log;
pid       logs/nginx.pid;

events {
    use epoll;
    worker_connections  1024;
}

http {
    include       mime.types;
    default_type  application/octet-stream;
    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  logs/access.log  main;
    sendfile        on;
keepalive_timeout  65;
gzip on;
gzip_min_length  1k;
gzip_buffers     4  16k;
gzip_http_version 1.0;
gzip_comp_level 2;
gzip_types  text/plain application/x-javascript text/css application/xml;
gzip_vary on;
</span><span style="color:#ff0000;">upstream localhost_server {
        ip_hash;
        server 192.168.74.129:8081;
        server 192.168.74.129:8082;
    }</span><span style="color:#333333;">

    server {
        listen       80 default;
        server_name  localhost;
      </span><span style="color:#ff0000;">   location ~ .*\.(html|htm|gif|jpg|jpeg|bmp|png|ico|txt|js|css)$ //由nginx处理静态页面</span><span style="color:#333333;">
             {
                  root   /usr/tomcat/apache-tomcat-8081/webapps/ROOT;
                   expires      30d; //缓存到客户端30天
               }
        error_page  404              /404.html;

        #redirect server error pages to the static page /50x.html

        error_page   500 502 503 504  /50x.html;
        location = /50x.html {
            root   html;
        }
         </span><span style="color:#ff6666;"> location ~  \.(jsp|do)$  {//所有jsp的动态请求都交给Tomcat处理 </span><span style="color:#333333;">
           </span><span style="color:#c0c0c0;">proxy_pass http://localhost_server;  //来自jsp或者do的后缀的请求交给tomcat处理</span><span style="color:#333333;">
            proxy_redirect off;
            proxy_set_header Host $host;    //后端的Web服务器可以通过X-Forwarded-For获取用户真实IP
            proxy_set_header X-Real-IP $remote_addr;
            proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
            client_max_body_size 10m;   //允许客户端请求的最大单文件字节数
            client_body_buffer_size 128k; //缓冲区代理缓冲用户端请求的最大字节数
             proxy_connect_timeout 90;   //nginx跟后端服务器连接超时时间
             proxy_read_timeout 90;     //连接成功后,后端服务器响应时间
             proxy_buffer_size 4k;      //设置代理服务器(nginx)保存用户头信息的缓冲区大小
             proxy_buffers  6  32k;       //proxy_buffers缓冲区,网页平均在32k以下的话,这样设置
            proxy_busy_buffers_size 64k;//高负荷下缓冲大小(proxy_buffers*2)
           proxy_temp_file_write_size 64k; //设定缓存文件夹大小,大于这个值,将从upstream服务器传
        }

    }  

}</span>

 第四步:修改了Apache-tomcat-8081和Apache-tomcat-8082下的conf/context.xml 文件,修改session的存储方式。

在<Context></Context>标签里加入

 <Manager className="de.javakaffee.web.msm.MemcachedBackupSessionManager" memcachedNodes="<span style="color:#ff0000;">n1:192.168.74.129:12000</span>" sessionBackupAsync="false" sessionBackupTimeout="100" transcoderFactoryClass="de.javakaffee.web.msm.serializer.javolution.JavolutionTranscoderFactory" copyCollectionsForSerialization="false" requestUriIgnorePattern=".*\.(png|gif|jpg|css|js)$"/>

说明:

1.requestUriIgnorePatter:过滤图片等静态文件去触发Session备份到Memcached。

2.sessionBackupAsync:指定Session是否应该被异步保存到Memcached中。

3.backupThreadCount :用来异步保存Session的线程数。

4.sessionBackupTimeout :默认100毫秒,操作超过时间那么保存失败。

第五步:  要引入memcached-session-manager所需要的jar包

如果在tomcat/lib下没引入时,会报找不到对应的类,如图所示:

需要的jar

memcached-session-manager-1.6.3.jar

javolution-5.5.1.jar

spymemcached-2.7.1.jar

memcached-session-manager-tc6-1.6.3.jar

msm-javolution-serializer-1.6.3.jar

msm-xstream-serializer-1.6.3.jar

到这里下载 所需JAR

1.这边需要注意的是,我们那时引入这个memcached-2.6.jar包,而不是映入spymemcached-2.7.1.jar时会报这个错误,如图所示:

2.memcached-session-manager-tc6-1.6.3.jar这个包时针对tomcat6

第六步:启动Nginx、Tomcat服务

1.启动Tomcat

#./bin/startup.sh;tail -f ./logs/catalina.out,这边可以查看到修改保存session的方式,并查看是否配置正确,如图所示:

2.启动Nginx

#cd /usr/local/nginx

#sbin/nginx

第七步:访问index.jsp

1.我们先试一下不通过Nginx反向代理,我们直接访问tomcat是否能访问jsp,并测试我们所写的JSP是否正确,并sessionId能正常显示,如图所示:

2.我们访问Nginx反向代理,我们部署了Apache-tomcat-8081和Apache-tomcat-8082两个集群,我们查看一下是否能共用一个session,我们在页面打印出来,看sessionId是否一样?

请求地址都是192.168.74.129/index.jsp,我们多刷几次,页面的端口就会改变,我们查看调用Apache-tomcat-8081的index.jsp与调用Apache-tomcat-8082的index.jsp的sessionId会不会改变,如图所示:

Apache-tomcat-8081的index.jsp并显示SessionId

Apache-tomcat-8082的index.jsp并显示SessionId

这时发现调用Apache-tomcat-8081的index.jsp与调用Apache-tomcat-8082的index.jsp的SessionId一样,说明共用同一个session。

时间: 2024-10-23 01:14:43

Nginx+Tomcat+Memcached 实现集群部署时Session共享的相关文章

Memcached 在集群中的 session 共享存储

以下是 PHP Web 环境集群中的 session 共享存储设置: [[email protected] ~]# cat /etc/php.inisession.save_handler = memcache session.save_path = "tcp://192.168.5.131:11211" 配置完在 phpinfo 页面中查看:

Apache + Tomcat + mod_jk实现集群服务及session共享

实现效果:用apache 分发请求到tomcat中的对应的项目 原理: 环境说明: 操作系统:win7   64位 Javajdk: 1.7 Apache:httpd-2.2.25-win32-x86-no_ssl.msi    (本地安装路径:D:\Program Files (x86)\Apache2.2\)Tomcat: 7.0.42  ( http://tomcat.apache.org/download-70.cgi ),如果在同一台机器上模拟,下载zip版本. 实例中展示了2个节点m

Nginx+tomcat+memcached解决集群的session问题

Tomcat集群session同步方案有以下几种方式: · 使用tomcat自带的cluster方式,多个tomcat间自动实时复制session信息,配置起来很简单.但这个方案的效率比较低,在大并发下表现并不好.原理:http://zyycaesar.iteye.com/blog/296606 · 利用nginx的基于访问ip的hash路由策略,保证访问的ip始终被路由到同一个tomcat上,这个配置更简单.但如果应用是某一个局域网大量用户同时登录,这样负载均衡就没什么作用了. · 利用ngi

memcached实现集群中的session共享存储优缺点

优点说明: 1. memcached是内存缓存,在读写速度上会比普通files时快很多 2. 可以解决多个服务器公用session的难题 缺点说明: 1. session数据都保存在memory中,持久化方面有所欠缺,但对session数据来说不是问题 2. 也可以用其它的持久化系统存储sessions,例如:redis,ttserver 3. 高性能高并发场景,cookies的效率比session更好很多,因此,很多大网站都会用cookies解决会话共享问题 ①web服务器上配置PHP文件,指

nginx+tomact+memcached(缓存)集群

关于Nginx+tomcat+memcached(缓存)配置集群负载均衡的下载与安装流程: 实现的整体步骤 一:安装memcached.(memcached可以一个或者多个) 二:安装两个tomcat 三:配置msm. 四:安装nginx,实现负载均衡. 以下是详细步骤: 第一步:安装memcached 1.       下载memcached服务端memcached-1.2.6-win32-bin.zip,地址:csdn 第二步:安装tomcat 1.       安装两个tomcat6,如果

LVS+Keepalived+Nginx+Tomcat高可用集群搭建(转)

LVS+Keepalived+Nginx+Tomcat高可用集群搭建 最近公司重整架构,十几台服务器而且还要尽可能节约成本.我就谷歌了一下在几种集群之前进行比较最终采用了Keepalived+Nginx做负债均衡高可用.虽然之前也研究过集群,看过很多集群方面的原理和架构,但毕竟没有真正操作过以下案例是在虚拟机中完成实验其实对于高可用搭建来说只用给出Keepalived和Nginx的配置即可后面的一些安装搭建完全是本人项目需要可以不用理睬仅供参考. 本文只是实验搭建记录方便以后在服务器中实施搭建.

Tomcat集群环境下session共享方案梳理(1)-通过memcached(MSM)方法实现

对于web应用集群的技术实现而言,最大的难点就是:如何能在集群中的多个节点之间保持数据的一致性,会话(Session)信息是这些数据中最重要的一块.要实现这一点, 大体上有两种方式: 一种是把所有Session数据放到一台服务器上或者数据库中,集群中的所有节点通过访问这台Session服务器来获取数据: 另一种就是在集群中的所有节点间进行Session数据的同步拷贝,任何一个节点均保存了所有的Session数据. Tomcat集群session同步方案有以下几种方式: 1)使用tomcat自带的

大厂面试题:集群部署时的分布式 session 如何实现?

面试官心理分析面试官问了你一堆 dubbo 是怎么玩儿的,你会玩儿 dubbo 就可以把单块系统弄成分布式系统,然后分布式之后接踵而来的就是一堆问题,最大的问题就是分布式事务.接口幂等性.分布式锁,还有最后一个就是分布式 session. 当然了,分布式系统中的问题何止这么一点,非常之多,复杂度很高,这里只是说一下常见的几个问题,也是面试的时候常问的几个. 面试题剖析session 是啥?浏览器有个 cookie,在一段时间内这个 cookie 都存在,然后每次发请求过来都带上一个特殊的 jse

nginx负载均衡集群中的session共享说明

在网站使用nginx+php做负载均衡情况下,同一个IP访问同一个页面会被分配到不同的服务器上,如果session不同步的话,就会出现很多问题,比如说最常见的登录状态. 下面罗列几种nginx负载均衡中session同步的方式 1)不使用session,换用cookiesession是存放在服务器端的,cookie是存放在客户端的,我们可以把用户访问页面产生的session放到cookie里面,就是以cookie为中转站.你访问web服务器A,产生了session然后把它放到cookie里面,当