集群软件的分类

集群软件的分类

在现在存储环境中,集群软件是一个很重要的模块。然而,很多人不清楚集群软件的分类,不知道oracle的RAC,IBM的HACMP,Symantec 的VCS和EMC的AutoStart,甚至一些用户写的脚本,分别属于哪一类,它们之间有什么相同和不同的地方:

一般来讲,集群软件根据侧重的方向和试图解决的问题,分为三大类:高性能集群(High performance cluster,HPC)、负载均衡集群(Load balance cluster, LBC),高可用性集群(High availability cluster,HAC)。有些软件可能夸口说它包含了超出单类型的功能,既可以做负载均衡集群,也可以做高可用性集群。姑且先不说该软件设计的侧重在哪里,但是用户到底需要什么要的集群呢?是负载均衡呢还是高可用性呢?用户肯不肯花两份钱来用其中一半的功能呢?

下面试三种集群类型的详细介绍:

[b]1,高性能集群(High performance cluster,HPC)[/b],它是利用一个集群中的多台机器共同完成同一件任务,使得完成任务的速度和可靠性都远远高于单机运行的效果。弥补了单机性能上的不足。该集群在天气预报、环境监控等数据量大,计算复杂的环境中应用比较多;

[b]2,负载均衡集群(Load balance cluster, LBC)[/b],它是利用一个集群中的多台单机,完成许多并行的小的工作。一般情况下,如果一个应用使用的人多了,那么用户请求的响应时间就会增大,机器的性能也会受到影响,如果使用负载均衡集群,那么集群中任意一台机器都能响应用户的请求,这样集群就会在用户发出服务请求之后,选择当时负载最小,能够提供最好的服务的这台机器来接受请求并相应,这样就可用集群来增加系统的可用性和稳定性。这类集群在网站中使用较多;

[b]3,高可用性集群(High availability cluster,HAC)[/b],它是利用集群中系统的冗余,当系统中某台机器发生损坏的时候,其他后备的机器可以迅速的接替它来启动服务,等待故障机的维修和返回。最大限度的保证集群中服务的可用性。这类系统一般在银行,电信服务这类对系统可靠性有高的要求的领域有着广泛的应用。
了解了集群的不同后,我们可以很容易的区分不同的集群。首先,一个集群环境中,如果只能由部分机器运行而其他机器作为后备,那么这个集群就属于高可用集群;如果集群环境中所有的机器都在做一件任务,每个单机的单CPU仅仅分担一件任务的一部分工作,那么这种属于高性能集群;如果集群中所有机器同时工作,完成很多不同的任务,那么它就是一个负载均衡集群,集群的功能是为了将不同任务分配到不同单机,分担运行负载。
现在,我们可以很容易知道现在市场上主流的集群软件的类型,oracle的RAC是多台单机同时访问的,完成不同用户的不同的数据库读写任务,所以它算是负载均衡集群;IBM的HACMP,从名字中就可以看出它是一个高可用性集群(HA)。Symantec的Veritas cluster server和EMC的Autostart也都是高可用性集群。高性能集群一般用在科学运算中,平时商用环境很少应用。
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
本文将详细介绍微信软件的架构,包括微信的模块划分、技术选型、开发模式等方面的内容,全面展示微信是如何实现高效、稳定、安全的。 一、微信的模块划分 微信的模块划分主要包括以下几个方面: 1. IM模块:IM模块是微信的核心功能之一,主要负责用户之间的即时通信功能,包括文字、语音、图片、表情、视频等多种形式的消息传输。 2. 朋友圈模块:朋友圈模块是微信的社交功能之一,主要负责用户之间的信息分享和互动,包括发表动态、点赞、评论、转发等。 3. 公众号模块:公众号模块是微信的商业化功能之一,主要负责用户关注公众号后,接收公众号推送的文章、消息、服务等。 4. 支付模块:支付模块是微信的金融功能之一,主要负责用户之间的支付和收款功能,包括红包、转账、付款码等。 5. 通讯录模块:通讯录模块是微信的基础功能之一,主要负责用户之间的联系人管理,包括添加好友、创建群聊、查找联系人等。 6. 小程序模块:小程序模块是微信的新兴功能之一,主要负责用户之间的轻量级应用程序,可以实现类似于APP的功能。 7. 其他模块:其他模块包括游戏中心、表情商店、附近的人、摇一摇等功能,主要为用户提供更加丰富的应用场景和互动体验。 二、微信的技术选型 微信的技术选型主要包括以下几个方面: 1. 服务端技术选型:微信的服务端主要采用Java语言开发,使用Spring框架、Mybatis框架、Dubbo框架等技术。 2. 数据库技术选型:微信的数据库主要采用MySQL数据库,使用MySQL Cluster实现高可用、高性能的数据库集群。 3. 前端技术选型:微信的前端主要采用HTML5、CSS3、JavaScript等技术,使用React、Vue等框架实现页面渲染和组件化开发。 4. 移动端技术选型:微信的移动端主要采用Native技术,使用Objective-C、Swift、Java等语言开发iOS和Android客户端应用。 5. 消息推送技术选型:微信的消息推送主要采用MQTT协议,使用阿里云MQTT服务实现消息的可靠传输和推送。 6. 安全技术选型:微信的安全技术主要包括数据加密、身份认证、访问授权等方面的技术,保障用户的隐私和信息安全。 三、微信的开发模式 微信的开发模式主要包括以下几个方面: 1. 敏捷开发:微信的开发采用敏捷开发模式,每周进行迭代开发,及时响应用户反馈和需求变化,保证产品的优化和升级。 2. 持续集成:微信的开发采用持续集成模式,将代码集成到主干分支后,立即进行自动化测试和发布,保证代码的质量和稳定性。 3. DevOps:微信的开发采用DevOps模式,将开发、测试、运维等环节进行集成,实现快速交付和高效运维,保证产品的高可用和性能。 4. 多团队协作:微信的开发采用多团队协作模式,不同团队负责不同模块的开发和维护,实现分工协作和高效沟通,保证产品的整体质量和效率。 四、微信的优势和不足 微信的优势主要包括以下几个方面: 1. 用户规模大:微信的用户规模超过10亿,是全球最大的即时通信社交应用之一。 2. 功能多样:微信的功能覆盖了社交、商业、金融、娱乐等多个领域,为用户提供了丰富的应用场景和服务。 3. 技术先进:微信的技术选型先进,使用了众多优秀的开源技术和自研技术,保证了产品的高效、稳定和安全。 4. 生态完善:微信的生态系统非常完善,包括公众号、小程序、开放平台等多个板块,为开发者和企业提供了广阔的发展空间。 微信的不足主要包括以下几个方面: 1. 信息泛滥:微信的信息量非常大,用户很容易受到信息泛滥的困扰,需要进行信息过滤和分类。 2. 隐私泄露:微信的隐私保护还有待完善,用户的个人信息有可能被泄露或滥用,需要加强隐私保护和监管。 3. 商业化倾向:微信的商业化趋势越来越明显,用户需要承受更多的广告和商业推广,需要更好的平衡商业利益和用户体验。 总之,微信作为一款全球领先的即时通信社交应用,其架构、技术选型和开发模式都非常优秀,为用户提供了高效、稳定、安全的服务。未来,微信将继续创新和发展,为用户和开发者带来更加丰富和有价值的体验。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值