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

基于LNMT的session持久机制的多种方法

[复制链接]

尚未签到

发表于 2017-11-27 13:54:18 | 显示全部楼层 |阅读模式
一. 为什么要实现会话保持
因为http是一种无状态协议,客户端和服务器建立连接传输完数据后即断开连接,客户端再次发起连接后,服务器端无法知道这个连接是否和上一个连接有什么关系,它只能认为是不同的连接。
二. 用什么方法实现
1. 客户端保持:即cookie机制
2. 服务器保持:即session机制,为了保持这个状态信息,它要让客户端至少保留一个session标识信息,即SessionID,也就说服务器端的session机制需要用到客户端cookie机制。
三. 具体方法
1) IP绑定
可以使用某种算法,建立客户端IP和后端服务器的映射关系,使得同一客户端总是访问同一个后端服务器。这样用户的session就总是有效。
nginx的upstream的ip_hash,LVS的sh调度算法,HAProxy的Source算法都实现了这一功能。
但这种调度一定程度上影响了负载均衡的效果,如果被调度到的后端服务器故障,session就丢失了。
2) session黏性
同一个session的请求将被调度到同一台服务器,粒度小,以session为调度单位。基于cookie实现。

以上两种方式,都一定程度解决了会话状态保持,但是,一旦某一台后端服务器故障,就会造成一定session数据的丢失。但是由于session sticky实现的粒度小,其负载均衡效果要好于IP绑定的方法。

2.1.2 Session 复制集群
可以使用Session Cluster,采用复制机制,这样每一台服务器都拥有全部的用户会话,无论前端均衡器如何调度,每一台后端服务器都可以和前客户端保持会话。缺点是显而易见的,对于访问大的站点,所有Session对内存的消耗非常大。

2.1.3 Session 服务器
可以使用session服务器,将session信息复制到共享的区域,所有服务器都可以借助这个共享区域拥有全部的session。
任何一台后端服务器故障,都不会影响客户端,因为其它服务器从共享区域中可以匹配到客户端提交的SessionID。

使用Tomcat + memcached-session-manager + Memcached实现。
四. 实验
利用nginx代理两台Tomcat,实现会话保持
watermark,size_16,text_QDUxQ1RP5Y2a5a6i,color_FFFFFF,t_100,g_se,x_10,y_10,shadow_90,type_ZmFuZ3poZW5naGVpdGk=.jpg

《因为一些原因,将nginx和tomcat1配置到了一起》
1. nginx的配置
upstream tomcat_cluster{
        server 172.17.252.64:8080 weight=1;   #tomcat1     
        server 172.17.250.2:8080 weight=2;     #tomcat2
}
    server {
        listen       80;
       server_name  localhost;
        #charset koi8-r;

        #access_log  logs/host.access.log  main;
        index index.jsp index.html;
#location / {
#       proxy_pass http://172.17.252.64:8080;
#}



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

}

2. Tomcat1的配置
Vim  /app/apache-tomcat-7.0.78/conf
<Cluster className="org.apache.catalina.ha.tcp.SimpleTcpCluster" channelSendOptions="8">
<Manager className="org.apache.catalina.ha.session.DeltaManager"
expireSessionsOnShutdown="false"
notifyListenersOnReplication="true"/>
<Channel className="org.apache.catalina.tribes.group.GroupChannel">
<Membership className="org.apache.catalina.tribes.membership.McastService"
address="228.0.0.4" port="45564" frequency="500" dropTime="3000"/>
<Receiver className="org.apache.catalina.tribes.transport.nio.NioReceiver"
address="auto" port="4000" autoBind="100" selectorTimeout="5000" maxThreads="6"/>
<Sender className="org.apache.catalina.tribes.transport.ReplicationTransmitter">
<Transport className="org.apache.catalina.tribes.transport.nio.PooledParallelSender"/>
</Sender>
<Interceptor className="org.apache.catalina.tribes.group.interceptors.TcpFailureDetector"/>
<Interceptor className="org.apache.catalina.tribes.group.interceptors.MessageDispatch15Interceptor"/>
</Channel>
<Valve className="org.apache.catalina.ha.tcp.ReplicationValve" filter="/"/>
<Valve className="org.apache.catalina.ha.session.JvmRouteBinderValve"/>
<ClusterListener className="org.apache.catalina.ha.session.ClusterSessionListener"/>
</Cluster>
3. Tomcat2的配置
Vim /app/apache-tomcat-7.0.78/conf
Vim  /app/apache-tomcat-7.0.78/conf
<Cluster className="org.apache.catalina.ha.tcp.SimpleTcpCluster" channelSendOptions="8">
<Manager className="org.apache.catalina.ha.session.DeltaManager"
expireSessionsOnShutdown="false"
notifyListenersOnReplication="true"/>
<Channel className="org.apache.catalina.tribes.group.GroupChannel">
<Membership className="org.apache.catalina.tribes.membership.McastService"
address="228.0.0.4" port="45564" frequency="500" dropTime="3000"/>
<Receiver className="org.apache.catalina.tribes.transport.nio.NioReceiver"
address="auto" port="4000" autoBind="100" selectorTimeout="5000" maxThreads="6"/>
<Sender className="org.apache.catalina.tribes.transport.ReplicationTransmitter">
<Transport className="org.apache.catalina.tribes.transport.nio.PooledParallelSender"/>
</Sender>
<Interceptor className="org.apache.catalina.tribes.group.interceptors.TcpFailureDetector"/>
<Interceptor className="org.apache.catalina.tribes.group.interceptors.MessageDispatch15Interceptor"/>
</Channel>
<Valve className="org.apache.catalina.ha.tcp.ReplicationValve" filter="/"/>
<Valve className="org.apache.catalina.ha.session.JvmRouteBinderValve"/>
<ClusterListener className="org.apache.catalina.ha.session.ClusterSessionListener"/>
</Cluster>
4.将<distributable/>写入Tomcat1和tomcat2的web.xml里
watermark,size_16,text_QDUxQ1RP5Y2a5a6i,color_FFFFFF,t_100,g_se,x_10,y_10,shadow_90,type_ZmFuZ3poZW5naGVpdGk=.jpg

5.实验效果
使sessionID不变


watermark,size_16,text_QDUxQ1RP5Y2a5a6i,color_FFFFFF,t_100,g_se,x_10,y_10,shadow_90,type_ZmFuZ3poZW5naGVpdGk=.jpg

watermark,size_16,text_QDUxQ1RP5Y2a5a6i,color_FFFFFF,t_100,g_se,x_10,y_10,shadow_90,type_ZmFuZ3poZW5naGVpdGk=.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-419602-1-1.html 上篇帖子: 基于haproxy+keepalive+varnish实现lnmp企业级架构 下篇帖子: LAMP环境的介绍
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

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

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

扫描微信二维码查看详情

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


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


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


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



合作伙伴: 青云cloud

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