zoukankan      html  css  js  c++  java
  • 集群概述

    1.集群概述

    1.1什么是集群

    1.1.1集群概念

    集群是一种计算机系统, 它通过一组松散集成的计算机软件和/或硬件连接起来高度紧密地协作完成计算工作。在某种意义上,他们可以被看作是一台计算机。集群系统中的单个计算机通常称为节点,通常通过局域网连接,但也有其它的可能连接方式。集群计算机通常用来改进单个计算机的计算速度和/或可靠性。一般情况下集群计算机比单个计算机,比如工作站或超级计算机性能价格比要高得多。

     

    1.1.2集群的特点

    集群拥有以下两个特点:

    1.   可扩展性:集群的性能不限制于单一的服务实体,新的服务实体可以动态的添加到集群,从而增强集群的性能。

    2.   高可用性:集群当其中一个节点发生故障时,这台节点上面所运行的应用程序将在另一台节点被自动接管,消除单点故障对于增强数据可用性、可达性和可靠性是非常重要的。

    1.1.3集群的两大能力

    集群必须拥有以下两大能力:

    1.     负载均衡:负载均衡把任务比较均匀的分布到集群环境下的计算和网络资源,以提高数据吞吐量。

    2.     错误恢复:如果集群中的某一台服务器由于故障或者维护需要无法使用,资源和应用程序将转移到可用的集群节点上。这种由于某个节点的资源不能工作,另一个可用节点中的资源能够透明的接管并继续完成任务的过程,叫做错误恢复。

    负载均衡和错误恢复要求各服务实体中有执行同一任务的资源存在,而且对于同一任务的各个资源来说,执行任务所需的信息视图必须是相同的。

    1.2集群与分布式的区别

    说到集群,可能大家会立刻联想到另一个和它很相近的一个词----“分布式”。那么集群和分布式是一回事吗?有什么联系和区别呢?

    相同点:

    分布式和集群都是需要有很多节点服务器通过网络协同工作完成整体的任务目标。

    不同点:

    分布式是指将业务系统进行拆分,即分布式的每一个节点都是实现不同的功能。而集群每个节点做的是同一件事情。

    分布式是将一个业务分成n个子模块,运行在不同分web服务器上 (一个厨房大业务有不同的子业务,分为洗菜.切菜.炒菜)
    集群是把多个服务器集中起来用来实现一个业务或一个子模块,提高速度(洗菜是一个业务,请了5个洗菜的就是集群将五台服务器用来实现洗菜一个子业务,提高效率)
    分布式是软件形态 集群是物理形态
    分布式的每个节点或叫子模块都可以做集群
    集群不一定是分布式 一个单独业务也可以做集群 可能是垂直式

    如下图,每个人都有不同的分工,一起协作干一件事,叫做“分布式”

      

    再看下图:每个划桨人干的都是一样的活,叫做集群。

     

    分布式的每一个节点也可以做成集群。其实这个赛龙舟的图,总整体来看属于分布式,包括打鼓和划桨两个分布式节点,而划桨的节点又是集群的形态。

    现实生活中例子还有很多,例如,这样古代乐队的图就属于集群

     

    而现代乐队这样图就是分布式啦

     

    学习是个漫长的过程,勿忘初心!
  • 相关阅读:
    < java.util >-- Set接口
    Codeforces 627 A. XOR Equation (数学)
    Codeforces 161 B. Discounts (贪心)
    Codeforces 161 D. Distance in Tree (树dp)
    HDU 5534 Partial Tree (完全背包变形)
    HDU 5927 Auxiliary Set (dfs)
    Codeforces 27E. Number With The Given Amount Of Divisors (暴力)
    lght oj 1257
    Codeforces 219D. Choosing Capital for Treeland (树dp)
    Codeforces 479E. Riding in a Lift (dp + 前缀和优化)
  • 原文地址:https://www.cnblogs.com/javalhy/p/10124785.html
Copyright © 2011-2022 走看看