`
peterwanghao
  • 浏览: 128362 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

集群环境下的缓存同步和出错恢复

 
阅读更多
概念:
集群是一组相互独立的、通过高速网络互联的计算机,它们构成了一个组,并以单一系统的模式加以管理。一个客户与集群相互作用时,集群像是一个独立的服务器。集群配置是用于提高可用性和可缩放性。
集群技术是一种通用的技术,其目的是为了解决单机运算能力的不足、IO能力的不足、提高服务的可靠性、获得规模可扩展能力,降低整体方案的运维成本(运行、升级、维护成本)。Cluster必须可以协调管理各分离的组件的错误和失败,并可透明地向Cluster中加入组件。一个Cluster包含多台(至少二台)拥有共享数据存储空间的服务器。任何一台服务器运行一个应用时,应用数据被存储在共享的数据空间内。每台服务器的操作系统和应用程序文件存储在其各自的本地储存空间上。Cluster内各节点服务器通过一内部局域网相互通讯。当一台节点服务器发生故障时,这台服务器上所运行的应用程序将在另一节点服务器上被自动接管。当一个应用服务发生故障时,应用服务将被重新启动或被另一台服务器接管。当以上的任一故障发生时,客户都将能很快连接到新的应用服务上。
缓存是介于应用程序和物理数据源之间,其作用是为了降低应用程序对物理数据源访问的频次,从而提高了应用的运行性能。缓存内的数据是对物理数据源中的数据的复制,应用程序在运行时从缓存读写数据,在特定的时刻或事件会同步缓存和物理数据源的数据。
问题:
当一个应用部署在集群环境下的不同节点上并行运行时,每个服务器节点都是单独缓存。这样就很容易导致不同节点的缓存内容出现版本上的不一致。一台机器上修改了数据只会影响到本地的内存,但不会通知其他服务器,导致其他节点的缓存数据实际已经失效了。这样就必须实现在集群环境下保持缓存同步。
当原先为用户创建session的服务器崩溃了,出错恢复允许用户无缝地从另一台server上获得session信息。
实现:
用数据库/文件系统实现
当集群中的一台server上的应用更新时,更新的部分写入数据库,然后缓存管理器把所有机器上的缓存设为无效,强迫它们下次重新获取新的。只有一个缺点,就是要花时间把数据从数据库或共享的文件系统中取出,调入内存中。
用数据库/文件系统实现session持久性的主要缺点在于:当存储大的或很多对象在session中时有限的伸缩性。用户每次向HttpSession增加一个对象,session中所有的对象都要序列化并写入数据库或共享的文件系统。大多数用数据库实现session持久化的application server都主张尽量少用session存储object,但这会限制Web application的结构和设计,特别是用HttpSession存储用户数据时。
基于内存的实现
把内存中的信息写到一个备份服务器上。有两种做法:第一种把信息写到一个集中式状态服务器,集群中的所有机器都要把数据写到这台server上;第二种是集群中每个节点任意地选择一个节点作为backup server,将存储在内存中的数据单独序列化写入那台backup server。
上面两种方法中,如果集群中的机器数较少,用专门的state server比任意指定backup server要好,这样可以节省CPU来处理transaction和动态网页的生成。另一方面,当集群的机器数很大时,专门的state server就成为瓶颈,而向任意指定的backup server复制内存的消耗将随着机器数的增长而线性增长。当增加机器时用专门的state server,你需要为它加上更多的RAM和CPU。用任意指定的backup server你仅仅增加机器而已,信息会平均地分布在所有机器之间。基于内存的持久化提供了灵活的Web application设计规模和高可靠性。
分享到:
评论

相关推荐

    Apache+Tomcat实现负载均衡及集群(session同步)--五、session同步(3)使用memcache

    本文将深入探讨如何使用memcache来实现Apache+Tomcat环境下的session同步。 首先,我们来理解一下session同步的重要性。在分布式系统中,用户的session信息可能存储在多个服务器上,当用户在集群中的不同节点之间...

    windows后台服务形式启动redis集群及powershell脚本

    Redis是一个开源的键值存储系统,常用于数据库、缓存和消息中间件,其高性能和丰富的数据结构为开发带来了便利。在Windows上部署Redis集群,我们可以借助PowerShell脚本来自动化这一过程。 首先,`redis.conf`是...

    shell监控redis集群节点异常发送邮件通知管理员.rar

    在IT行业中,管理和监控分布式系统,如Redis集群,是至关重要的任务。为了确保系统的稳定性,及时发现并处理问题,开发者通常会创建自动化监控脚本。本文将深入探讨如何使用Shell脚本来监控Redis集群节点,并在检测...

    linux环境下 使用的solr

    总的来说,Linux环境下的Solr是一个强大的搜索引擎工具,通过合理的配置和使用,可以极大地提升数据的搜索和分析效率。无论是同步数据库、处理中文分词,还是构建分布式集群,Solr都能提供灵活且高效的解决方案。

    谷歌开源的容器集群管理系统Kubernetes.zip

    3.1.7. Scheduler Scheduler收集和分析当前Kubernetes集群中所有Minion节点的资源(内存、CPU)负载情况,然后依此分发新建的Pod到Kubernetes集群中可用的节点。由于一旦Minion节点的资源被分配给Pod,那这些资源就不...

    vagrant-apache-cluster:用于配置集群Apache Kafka,Apache Zookeeper,Apache Cassandra,Apache Ignite的流浪者配置

    Apache Zookeeper 是一个分布式的,开放源码的分布式应用程序协调服务,它是集群的管理者,负责维护和提供配置信息、命名服务、分布式同步、组服务等。在Kafka中,Zookeeper用于管理主题(topics)、分区...

    Redis部署及理解

    配置项涉及数据写入本地、故障恢复策略、从节点读取以及集群的扩展和收缩。根据需求合理配置这些参数以保证数据安全和性能。 11. **注意事项** - 仅有一个数据库 0。 - 异步复制可能导致数据一致性问题。 - 多...

    Zookeeper文档

    由于协调服务在分布式环境中容易出错且难以恢复,Zookeeper的目的是为了减轻这类问题,让分布式应用能够更专注于业务逻辑。 **Zookeeper数据模型和节点** Zookeeper的数据模型采用了层次化的命名空间,类似于标准...

    SpringMVC+Nutz框架介绍范本模板.pdf

    2. **Apache Shiro** - 提供安全认证和授权服务,用于实现用户权限管理,支持二级缓存并借助Redis进行session同步。 3. **Nutz** - 作为ORM框架,简化了数据库操作,同时支持多种数据库,具备自动SQL注入防护。 4. *...

    Redis高级.docx

    在实际生产环境中,使用哨兵监控和管理 Redis 集群是必要的实践,它可以自动化处理许多故障情况,减轻运维人员的压力。同时,理解哨兵的工作原理和配置方法对于优化 Redis 集群的稳定性和性能至关重要。

    国基北盛云基础架构平台软件(私有云平台)用户手册

    安装服务通常通过脚本自动化完成,以提高效率和减少出错的可能性。 OpenStack的核心服务包括Keystone认证服务,它负责身份管理和授权;Glance镜像服务,用于存储和检索虚拟机镜像;Nova计算服务,处理虚拟机生命...

    互动教学平台安装指南(双机版)

    3. **双机部署**:在双机环境下,需要考虑高可用性和负载均衡,配置适当的集群策略,如Nginx反向代理或Heartbeat心跳同步,以保证服务的连续性和稳定性。 **附录** 附录部分通常包含额外的技术细节、故障排查指南...

    第三章 SpringCloud 使用Erueak服务注册中心.pdf

    ...SpringCloud提供了一种优雅的解决方案——使用Eureka作为服务注册中心,...同时,Eureka的集群部署和数据同步机制,确保了在单个节点故障时,整个服务注册中心仍然能够正常工作,从而构建了一个高可用的微服务架构。

    hadoop+hbase系列配置文档

    - **节点配置**:集群包含4个节点,其中1个名称节点(Namenode)和3个数据节点(Datanode)。 - **节点间通信**:节点之间能够通过ping命令相互通讯。 - **节点信息**:每个节点的IP地址和主机名已知。 #### 三、...

    ThinkPHP_3.1.2_Cluster

    ThinkPHP提供了简单易用的接口,使得开发者可以方便地进行数据同步和通信。 三、应用场景与实战技巧 3.1 高并发场景 对于大型电商平台、社交网络等高并发应用,Cluster模式可以显著提升系统吞吐量,保证用户在高峰...

    思科的FETURE 欢迎下载

    在大型网络环境中,手动分配IP地址既耗时又容易出错,DHCP则简化了这一过程。 **应用场景:** 适用于需要频繁变更IP地址分配的环境,如办公网络、公共Wi-Fi等。 **配置示例:** 1. 在路由器上配置DHCP服务。 2. ...

    传统java项目的构建思路以及相关技术使用

    本文总结了传统Java项目的构建思路和相关技术使用,涵盖文件分片上传、Jplag返回的数据类型、Spring Security、基础服务、Docker、线程池、同步互斥信号量、业务流程优化、SQL优化、MongoDB分片集群存储等多方面的...

    网络游戏-游戏服务器中的任务文件执行装置以及方法.zip

    5. **错误处理和回滚机制**:为防止任务执行出错导致数据不一致,服务器需要有健全的错误处理机制,并能回滚到错误发生前的状态。 6. **实时同步**:在网络游戏中,玩家的行动需要实时反映在其他玩家的游戏世界中。...

Global site tag (gtag.js) - Google Analytics