随着站点的功能越来越多,用户量越来越庞大,单节点模式已经严重不能支撑整个系统的正常运作,轻则用户页面訪问时间越来越慢。重则就会导致整个系统瘫痪。这时候

就须要优化或调整眼下的架构,大部分人就会採用各种负载均衡软件比如nginx、hproxy、LVS等,也有的採用分布式的方式把系统依据功能拆分成非常多系统,也有的依据地域

和网络不同来实现訪问不同节点部署的系统。也有的大型高流量、高负载的系统把负载均衡、分布式及依据地域、网络等这些方式都整合在一起来实现系统的正常执行。

採用负载均衡软件是眼下大家採取的比較多的方式。可是在採用负载均衡软件时将会面临session同步的问题。

下面是解决这个问题的几种方式。

1. clientcookie加密的方式



把session数据存放在cookie中,当请求过来时。从cookie中获取session数据。这样的方式不须要不论什么的存储系统。也不会出现读写session数据带来的网络操作延时和不稳定性。

可是有下面缺点:

* Cookie有长度限制,这会影响session数据的长度。

* 安全性。

session数据本来存储在服务端的,而这个方法是让session数据转到外部网络或client中。所以会有安全性问题。只是能够对写入Cookie的session 数据做加密。

* 带宽消耗。因为加了session数据。带宽当然也会添加一点。

* 性能消耗。每次Http请求和响应都带有Session数据。对于Webserver来说,在相同的处理情况下,响应的结果输出越少,支持的并发请求越。



2. web server的session复制方式

大部分应用server都提供了session复制的功能来实现集群。tomcat、jboss、was都提供了这种功能。session复制就是每台应用服务。都保存会话session数据。

长处:

靠应用容器来完毕session共享,并不依赖应用。假设应用服务数量并非非常多,能够考虑。

缺点:



 
* 同步session数据带来都网络开销。

仅仅要session数据变化,就须要同步到全部机器上,机器越多,网络开销越大。

  * 因为每台server都保存session数据,假设集群的session数据非常多。比方90万人在訪问站点。每台机器用于保存session数据的内容占用非常严重。

3. 使用关系数据库保存session     

用mysql、sqlserver等数据库保存session,就算服务器宕机了也没事,session照样在。



缺点:



*程序须要定制。

  *每次请求都进行数据库读写开销不小(使用内存数据库能够提高性能,宕机就会丢失数据。

可供选择的内存数据库有BerkeleyDB,Mysql的内存表);

4.使用nosql数据库保存session



採用redis、mongodb、memcached等非关系数据库来实现session的共享。这些非关系数据库响应数据非常的快,并且支持的訪问量也比較大。系统资源消耗也比較少。这也是非常多系统所採用的方式。

可是也有缺点:

* 读写session引入了网络操作。相对于本机读写session,带来了延时和不稳定性。

* 如Session集中服务有问题,会影响应用。

5.採用Session Stick

在单机情况。session保存在单机上,请求也是到这台单机上,不会有问题。变成多台后,假设能保障每次请求都到同一台服务。那就和单机一样了。 这须要在负载均衡设备上改动。这就是Session Stick。这样的方式也会有问题:

* 假设某一台server宕机或重新启动。那么这台server上的session数据就丢失了。假设session数据中还有登录状态信息。那么用户须要重现登录。

* 负载均衡要处理详细的session到server的映射。

6.使用terracotta来保存session



跟memcached类似,可是数据不须要序列化。并且是Find-Grained Changes。性能更好。

配置对原来的应用全然透明,原有程序差点儿不用做不论什么改动。并且terracotta本身支持HA。

综上所述。我个人推荐使用第4、6种方式来解决session共享的问题。

web集群中经常使用的session同步解决方式及对照的更多相关文章

  1. 关于WEB集群中文件服务器的讨论

    原文地址: http://blog.itpub.net/29806344/viewspace-1364778/ 在WEB集群中一般都要上传和删除图片.小规模的时候,图片放在本地,再通过同步方式来保持一 ...

  2. spring 整合redis集群中使用@autowire无效问题的解决办法

    1.视频参考黑马32期宜立方商城第6课 redis对于的代码 我们先变向一个redis客户端的接口文件 package com.test; public interface JedisClient { ...

  3. 使用port-forward访问集群中的应用程序,以Redis 为例

    为Redis创建Deployment和Service 创建 Redis Deployment,YAML文件如下: apiVersion: apps/v1 kind: Deployment metada ...

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

    在网站使用nginx+php做负载均衡情况下,同一个IP访问同一个页面会被分配到不同的服务器上,如果session不同步的话,就会出现很多问题,比如说最常见的登录状态. 下面罗列几种nginx负载均衡 ...

  5. 【转】web集群时session同步的3种方法

    转载请注明作者:海底苍鹰地址:http://blog.51yip.com/server/922.html 在做了web集群后,你肯定会首先考虑session同步问题,因为通过负载均衡后,同一个IP访问 ...

  6. 关于 tomcat 集群中 session 共享的三种方法

    前两种均需要使用 memcached 或redis 存储 session ,最后一种使用 terracotta 服务器共享. 建议使用 redis,不仅仅因为它可以将缓存的内容持久化,还因为它支持的单 ...

  7. 负载均衡集群中的session解决方案

    前言 在我们给Web站点使用负载均衡之后,必须面临的一个重要问题就是Session的处理办法,无论是PHP.Python.Ruby还是Java,只要使用服务器保存Session,在做负载均衡时都需要考 ...

  8. 集群中几种session同步解决方案的比较

    1. 客户端cookie加密 .比较好的方法是自己采用cookie机制来实现一个session,在应用中使用此session实现. 问题:session中数据不能太多,最好只有个用户id. Sessi ...

  9. Apache shiro集群实现 (八) web集群时session同步的3种方法

    Apache shiro集群实现 (一) shiro入门介绍 Apache shiro集群实现 (二) shiro 的INI配置 Apache shiro集群实现 (三)shiro身份认证(Shiro ...

随机推荐

  1. Python-基础-day6

    1.二进制 前言:计算机一共就能做两件事:计算和通信 2.字符编码 生活中的数字要想让计算机理解就必须转换成二进制.十进制到二进制的转换只能解决计算机理解数字的问题,那么文字要怎么让计算机理解呢? 于 ...

  2. STM32 GPIO重映射(转)

    重映射就是将引脚功能重新定义到其他引脚, 例如PA9是USART1-TX默认的 管脚,但是现在PA9用做它用了,那可以将USART1-TX重新映射到PB6,当然这 种映射不是随意的想映射到哪个脚就哪个 ...

  3. HDU 4390 Number Sequence (容斥原理+组合计数)

    HDU 4390 题意: 大概就是这样.不翻译了: Given a number sequence b1,b2-bn. Please count how many number sequences a ...

  4. Executors线程池关闭时间计算

    Executors线程池关闭时间计算 学习了:http://blog.csdn.net/wo541075754/article/details/51564359 https://www.cnblogs ...

  5. [Python]threading local 线程局部变量小測试

    概念 有个概念叫做线程局部变量.一般我们对多线程中的全局变量都会加锁处理,这样的变量是共享变量,每一个线程都能够读写变量,为了保持同步我们会做枷锁处理.可是有些变量初始化以后.我们仅仅想让他们在每一个 ...

  6. Python爬糗百热门20条并邮件分发+wxPython简易GUI+py2app转成可运行文件

    学了一阵子Python,拿来做个什么有意思的东西呢?爬糗百好了.爬到的内容,邮件分发出去. 然后又啃了两天的wxpython,做了个简易的邮件管理界面,能够在这里添加或者删除邮件,而且一键爬虫发送. ...

  7. DNS Tunnel判定方法

    DNS Tunnel判定方法: 1.查询DNS请求的域名是否存在备案: 2.查询DNS请求的域名情报信息(以及域名的alex排名): 3.查看相同主域名下子域名编码格式及长度:(存在Base32和Ba ...

  8. jsp页面String path = request.getContextPath(); String basePath = request.getScheme() + "://" + request.getServerName() + ":" + request.getServerPort() + path + "/";作用!!!!!

    转自:https://blog.csdn.net/kiwangruikyo/article/details/81130311 <%String path = request.getContext ...

  9. CSS3的常用属性(一)

    选择器 属性选择器(通过标签属性来选择) E[attr]: 表示只要元素<E>存在属性attr就能被选中  如: div[class] E[attr=val]: 表示元素<E> ...

  10. 监控慢SQL

    SELECT G.TARGET || ' ' || S.MACHINE || ' ' || ceil((G.LAST_UPDATE_TIME - G.START_TIME)*86400)   FROM ...