[转发] 负载均衡的服务器集群上如何进行缓存和会话数据的管理

2024-09-06 02:32

本文主要是介绍[转发] 负载均衡的服务器集群上如何进行缓存和会话数据的管理,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

会话数据管理方法
1. 不存储Session
对于一些不需要记录用户状态的Web应用,采用这种Stateless方式是最恰当的方式。
2. 基于Cookie的Session共享
这种策略也被称为客户端Session,即不将Session信息存储于服务器端,而是存储于客户端。这同时,也会带来一定的安全问题,因为Cookie是存储于客户端中的,也就意味着客户端可以修改Cookie文件,来进行Session劫持操作。安全性问题是这种策略最大的问题。
缺点:只能够存储字符串、数值等基本类型的数据;Cookie大小存在限制;安全性;带宽及数据解压缩、网络传输性能问题。
优点:节省服务器内存。
3. 集中式Session存储策略
集中式Session,顾名思义,将集群中所有用户机的Session都保存在同一台机器上(Session服务器)。
此时Session存储有如下集中方式:
1. Key/ValueStorage
一般,大型Web系统会采用Key/ValueStorage的方式存储Session。在这种存储方式的选择中,大多数的大型Web系统会选择memcached。
这种方式的优点在于:
 多数的Key/Value Storage支持Object作为它的Key或者Value
 多数的Key/Value Storage提供非常友好的API;
 Key/Valuestorage速度一般都远高于关系型数据库,非常适合Session这种存取非常频繁的情况,例如memcached支持全内存的工作方式,速度非常快;
 多数的Key/Value Storage支持良好的备份与恢复机制;
 多数的Key/Value Storage支持集群工作的方式,此时Session的总量也就不再局限于单Session服务器的内存大小。
这种方式的缺点在于:
 Key/ValueStorage部署有一定的复杂;
 多数Key/Value Storage对于CPU与内存的消耗较多;
 在使用这种方式时,需要注意以下几点:
 Key/ValueStorage对Object(对象)大小的限制。很多Key/ValueStorage会对所存储的对象的大小有所限制,比如memcached中,默认配置下单个对象的最大大小为 1MB;
 当与Session服务器的连接断开或者Session服务器宕机时的异常处理。

2. 基于数据库的Session共享,实现分布式应用间Session共享
优点:实现简单
缺点:由于数据库服务器相对于应用服务器更难扩展且资源更为宝贵,在高并发的Web应用中,最大的性能瓶颈通常在于数据库服务器。因此如果将 Session存储到数据库表,频繁的增加、删除、查询操作很容易造成数据库表争用及加锁,最终影响业务。
 
3. 基于内存的Session存储
在使用这种方式时,可以直接使用HashTable。至于为什么使用HashTable而非HashMap,原因非常简单HashTable是线程安全的,而且HashTable不支持null作为key或者value。HashTable中key可以用户名/用户ID,value为这个用户的Session。
这种方式的优点在于:
 实现简单;
 速度快。这种方式无疑是这三种方式中最为快速的;
这种方式的缺点在于:
 备份困难;
 所有的数据都在同一台机器上,这台机器容易成为单点故障;
 Session集合的总容量受到Session服务器的内存大小限制;
 难以以集群的方式进行工作;


4. StickySession
采用这种策略时,某一个用户所有的请求都会映射到某一台应用服务器。无论这台服务器是否是非常空闲,还是非常繁忙,这台机器上的用户请求仍然会再次映射到这台机器上。
为了达到Session Sticky,有多种负载的策略:
1. IP Hash
IP Hash策略下,将所有的应用服务器列成一个Hash表,这个表中的每一个元素即是一台应用服务器。负载均衡器的负载策略是根据用户的IP,将用户的IP Hash到以上所谈及到Hash表中。一般而言,用户的IP不会有变化,Hash值也是不会变化的,因而用户的请求会一直映射到某一台应用服务器上。当用户的数量非常庞大的时候,一般用户的IP也比较分散,这种策略的效果也比较好。而且,这种方式的实现也非常简单,只需要对负载均衡器进行一定的配置便可,而不需要对业务系统做出任何的修改。
2. 用户名Hash
在现在Web系统中,一般都会有注册用户,而且只有注册用户才可以使用其发布的服务。用户名Hash,其原理、优缺点与IP Hash基本上是相同的,只是Hash函数的输入不再是用户的IP地址,而是用户的用户名。而用户名的提供主要有两种方式,一种是每一个请求URL都会带上自己的用户名,第二种是将用户名放在客户端的Cookie中。在第二种方法中,如果客户端不提供Cookie,那这种策略将会无法执行。
3. 首次登陆时间Hash
这种Hash策略的原理也非常容易想象,不再是用户的IP地址或者用户名,而根据用户登陆系统的时间来进行Hash。同样,首次登陆时间的提供主要有两种方式,一种是每一个请求URL都会带上自己的登陆时间,第二种是将登陆时间放在客户端的Cookie中。在第二种方法中,如果客户端不提供Cookie,那这种策略将会无法执行。


缓存管理
1. 采用服务的方式
这是一种最直接的方式。当然服务的方式可以多种多样,比较简单的方式是提供一个ClearCache.aspx的页面,当实体数据发生变更之后调用N多台Web应该的这个页面。
2. 采用File Dependency的策略
这种策略让缓存依赖于一个指定的文件,通过改变文件的更新日期来清除缓存。这种方式的缺点是,如果缓存的数据比较多,相关的依赖文件比较松散,对管理这些依赖文件有一定的麻烦。对于负载均衡环境下,还需要同时更新多台Web服务器下的缓存文件,如果多个Web应用中的缓存依赖于同一个共享的文件,可能会省掉这个麻烦,但是对Web应用中运行帐号的权限所限,终归不是那么简洁。
3. 采用SqlCacheDependency的策略

 这种策略让缓存依赖与数据库中指定的数据(查询结果)。可以用Poll的方式主动调用,设定一个周期,循环调用查询语句,如果查询结果发生变化,就会清除缓存。也可以配合Sql Server 2005,采用Push的方式被动的被通知什么时候会清楚缓存。这种Push的方式是基于Sql Server 2005中Broker Service的订阅服务,SqlCacheDependency需要配合SqlDependency来实现这种方式。


文章原地址:http://www.douban.com/note/269093631/

这篇关于[转发] 负载均衡的服务器集群上如何进行缓存和会话数据的管理的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1140743

相关文章

大模型研发全揭秘:客服工单数据标注的完整攻略

在人工智能(AI)领域,数据标注是模型训练过程中至关重要的一步。无论你是新手还是有经验的从业者,掌握数据标注的技术细节和常见问题的解决方案都能为你的AI项目增添不少价值。在电信运营商的客服系统中,工单数据是客户问题和解决方案的重要记录。通过对这些工单数据进行有效标注,不仅能够帮助提升客服自动化系统的智能化水平,还能优化客户服务流程,提高客户满意度。本文将详细介绍如何在电信运营商客服工单的背景下进行

基于MySQL Binlog的Elasticsearch数据同步实践

一、为什么要做 随着马蜂窝的逐渐发展,我们的业务数据越来越多,单纯使用 MySQL 已经不能满足我们的数据查询需求,例如对于商品、订单等数据的多维度检索。 使用 Elasticsearch 存储业务数据可以很好的解决我们业务中的搜索需求。而数据进行异构存储后,随之而来的就是数据同步的问题。 二、现有方法及问题 对于数据同步,我们目前的解决方案是建立数据中间表。把需要检索的业务数据,统一放到一张M

服务器集群同步时间手记

1.时间服务器配置(必须root用户) (1)检查ntp是否安装 [root@node1 桌面]# rpm -qa|grep ntpntp-4.2.6p5-10.el6.centos.x86_64fontpackages-filesystem-1.41-1.1.el6.noarchntpdate-4.2.6p5-10.el6.centos.x86_64 (2)修改ntp配置文件 [r

关于数据埋点,你需要了解这些基本知识

产品汪每天都在和数据打交道,你知道数据来自哪里吗? 移动app端内的用户行为数据大多来自埋点,了解一些埋点知识,能和数据分析师、技术侃大山,参与到前期的数据采集,更重要是让最终的埋点数据能为我所用,否则可怜巴巴等上几个月是常有的事。   埋点类型 根据埋点方式,可以区分为: 手动埋点半自动埋点全自动埋点 秉承“任何事物都有两面性”的道理:自动程度高的,能解决通用统计,便于统一化管理,但个性化定

使用SecondaryNameNode恢复NameNode的数据

1)需求: NameNode进程挂了并且存储的数据也丢失了,如何恢复NameNode 此种方式恢复的数据可能存在小部分数据的丢失。 2)故障模拟 (1)kill -9 NameNode进程 [lytfly@hadoop102 current]$ kill -9 19886 (2)删除NameNode存储的数据(/opt/module/hadoop-3.1.4/data/tmp/dfs/na

异构存储(冷热数据分离)

异构存储主要解决不同的数据,存储在不同类型的硬盘中,达到最佳性能的问题。 异构存储Shell操作 (1)查看当前有哪些存储策略可以用 [lytfly@hadoop102 hadoop-3.1.4]$ hdfs storagepolicies -listPolicies (2)为指定路径(数据存储目录)设置指定的存储策略 hdfs storagepolicies -setStoragePo

HDFS—集群扩容及缩容

白名单:表示在白名单的主机IP地址可以,用来存储数据。 配置白名单步骤如下: 1)在NameNode节点的/opt/module/hadoop-3.1.4/etc/hadoop目录下分别创建whitelist 和blacklist文件 (1)创建白名单 [lytfly@hadoop102 hadoop]$ vim whitelist 在whitelist中添加如下主机名称,假如集群正常工作的节

Hadoop集群数据均衡之磁盘间数据均衡

生产环境,由于硬盘空间不足,往往需要增加一块硬盘。刚加载的硬盘没有数据时,可以执行磁盘数据均衡命令。(Hadoop3.x新特性) plan后面带的节点的名字必须是已经存在的,并且是需要均衡的节点。 如果节点不存在,会报如下错误: 如果节点只有一个硬盘的话,不会创建均衡计划: (1)生成均衡计划 hdfs diskbalancer -plan hadoop102 (2)执行均衡计划 hd

综合安防管理平台LntonAIServer视频监控汇聚抖动检测算法优势

LntonAIServer视频质量诊断功能中的抖动检测是一个专门针对视频稳定性进行分析的功能。抖动通常是指视频帧之间的不必要运动,这种运动可能是由于摄像机的移动、传输中的错误或编解码问题导致的。抖动检测对于确保视频内容的平滑性和观看体验至关重要。 优势 1. 提高图像质量 - 清晰度提升:减少抖动,提高图像的清晰度和细节表现力,使得监控画面更加真实可信。 - 细节增强:在低光条件下,抖

【Prometheus】PromQL向量匹配实现不同标签的向量数据进行运算

✨✨ 欢迎大家来到景天科技苑✨✨ 🎈🎈 养成好习惯,先赞后看哦~🎈🎈 🏆 作者简介:景天科技苑 🏆《头衔》:大厂架构师,华为云开发者社区专家博主,阿里云开发者社区专家博主,CSDN全栈领域优质创作者,掘金优秀博主,51CTO博客专家等。 🏆《博客》:Python全栈,前后端开发,小程序开发,人工智能,js逆向,App逆向,网络系统安全,数据分析,Django,fastapi