谈谈云计算的部署方式

上传人:宝路 文档编号:23516994 上传时间:2017-12-01 格式:DOCX 页数:5 大小:91.56KB
返回 下载 相关 举报
谈谈云计算的部署方式_第1页
第1页 / 共5页
谈谈云计算的部署方式_第2页
第2页 / 共5页
谈谈云计算的部署方式_第3页
第3页 / 共5页
谈谈云计算的部署方式_第4页
第4页 / 共5页
谈谈云计算的部署方式_第5页
第5页 / 共5页
亲,该文档总共5页,全部预览完了,如果喜欢就下载吧!
资源描述

《谈谈云计算的部署方式》由会员分享,可在线阅读,更多相关《谈谈云计算的部署方式(5页珍藏版)》请在金锄头文库上搜索。

1、我们在以前的文章( 对云计算中几种基础设施(Dynamo,Bigtable,Map/Reduce 等)的朴素看法)中对云计算的概念和基础组织已作了较为详细的解释和分析,这次我们将继续云计算的话题进一步谈谈云计算在实际应用环境中的部署方法。我个人理解,云的主要精髓之一(除此以外,资源虚拟化动态分配和安全访问是另外两个核心,我们后面找机会讨论它们)在于数据存储和计算的分布化,因而需要在云部署上充分考虑如何满足分布性,以及如何方便的集中管理云自动化部署,启动,停止等。下文的主要内容将以我们的实际开发实践为基础展开,重在说明部署方法和管理方法,而不详细谈代码实现另外,可能的实现方法多会是种多样,但目的

2、殊途同归。云的分布性:我这里所说的云其实就是我们自己的具体应用程序,之所以叫它云是因为我们的应用无论是存储或者是计算都是分布实现的。这是因为我们所需要处理的数据量在单机上无论是存储或者是计算都无法完成,因此必须将数据处理任务分散开来,化整为零交给多台机器共同完成。我们的每个应用部署起来都是分布化的,我这里姑且叫它们为云好了这里先别去管所谓的云服务,重点关注它的分布性,或者并行性。下面的内容我们重点说说这种分布性的实现方法。派发服务首先看满足分布化所要求做的工作云中的和云之间的存储和运算点都是部署需要支持跨机器访问(可能还要跨 IDC喽)我们因此需要一个消息派发服务,即负责管理消息的分布通讯。在

3、谈派发服务前,我们简要说一下云应用如何被访问。云应用程序和单机应用程序从功能层面看应该是没有区别的,唯一的区别在于访问方式上有一点点差别。访问云应用时需要访问者给出云应用的名称(或者说是 namespace)外,还需要给出派发 KEY,用来觉得该任务应该下发给云中那个点负责。也许你要说 dynamo或者 google的 bigtable就没有见要指定派发 KEY呀,其实不然,他们的派发 KEY虽然没有被显示出现,但却被隐含在访问数据中了,比如 dyname中的访问键就是派发 KEY。有了这个派发 KEY的概念,我们就接着谈派发服务了。派发服务的责任具体的讲该服务需要负责:1.根据派发规则和云的

4、路由信息找到派发目标点所谓路由信息,其实就是云中各点的位置信息,比如 ip 地址和 port。2.建立和管理链接;3.发送和接受数据采用异步 IO处理模型应该更高效率。除此基本功能以外,最好还能做到一些附加功能:1.动态更新路由实时感知网络拓扑结构或者计算点和存储点的位置信息变化,以便能在不停服务的情况下,调整派发路线;2.统计各种通讯计数(包数,流量等),以便能分析云运行数据流的状态;3.对流量进行控制,以防止过载;4.上报错误(对于链接等异常,需要上报)派发服务算法基础和派发规则派发服务的主要算法是 DHT(分布 hash),数学描述忽略,我们找最简单的例子举例说明这个算法的含义。首先我们

5、所选定的派发 KEY的是由一个字符串做 MD5后获得的,它会是一个 128为数值做 MD5的目的是使得数据均匀分布和避免冲突。然后我们在逻辑上将 128位的数值空间均分成 N份,然后让每个机器负责其中 1/N的任务,从而让任务分布派发到不同机器上。很简单是吧,虽然有很多变种算法,但万变不离其宗。我们的分布基础多数就是依赖于该算法。分布系统的消息必定有其派发规则。这种规则随应用不同而相应变化,不过我们通常还是可以抽象出一些标准的派发规则。下面谈谈能抽象出来的派发规则。1.RR派发规则:就是随机的给目标云中的一组点上任意一个下发数据。这种规则的应用场景应该是数据之间没有逻辑关系,数据给哪个节点处理

6、都一样也就是说节点处理过程没有 session. RR规则的派发 KEY可以随机选取。2.SESSION 派发规则:和 RR派发不同之处就是节点处理有 Session后面的任务需要在前面的基础上进行,因此数据不能任意下发,而是要保证给定的数据集合发给同一个点。SESSION 规则的派发 KEY需要发送方给定。3.查表派发规则:有些派发无法用给定的规则做 partation因为需要某些预先给定的数据落到预先给定的点上处理 ,而不向 SESSION派发那样仅仅要求给定任务集合落到同一个点就行。那么可能需要具体的查预先定义的映射表,才能决定派发路径。查表派发规则的派发 KEY需要发送方给定。4.Dy

7、namo 式派发规则:这种派发遵循 dynamo系统采用的 N,W,R规则进行派发,具体看看 dynamo论文吧,对于冗余存储采用这种方式。除了上述派发规则外,很多应用会有自己特殊的派发规则。不过上述的规则最普遍,多数情况下都够用派发服务的部署 派发服务部署可采用多种方式:如做成一个 lib供应用程序(这里说的应用程序就是云的存储或者计算点)自己去调用;或者做成一个单独的服务进程独立于应用程序。这两种方式各有各的好处,我们下面具体谈谈这两种方式的区别。首先说说作为单独服务程序部署我们可认为它是一个负责派发逻辑的独立的消息中间件。这种作为部署方式有一些好处:1 系统的数据逻辑层次解耦合应用的计算

8、逻辑和 IO逻辑分离提高了程序的可维护性;2 跨机器间的数据都由消息中间件走减少了系统中的连接数目不需要云中计算点和点之间都建立点到点的连接了,而只需要机器到机器建立端到端的连接即可(因为一个机器只需要部署一个消息中间件就可)。鉴于以上好处,我们一般对于小数据都建议使用该方式传输。但是这样必然增加了进程见通讯负载,对于大数据传输这种消耗可能无法忍受,因此在这种情况下,可以将消息中间件“退化”成一个 lib供计算点内部调用。派发服务的路由组织派发服务必须知道云中个点的位置信息才能正确完成消息派发。这些位置信息记录在“路由表”中,路由表信息中需要包含派发规则(可以交给一个动态库完成);云中个点的

9、ID和其位置信息(即,个点的 location信息:如 ip,port等);以及其他诸如超时(timeout)等信息。比如 Dynamo 式派发规则的路由表信息需要如下部分:1.云的命名 作为一个云唯一的标示,用于数据发送时的制定目的地2.N (副本数), W(每次写需成功写入副本数) ,R(每次读需要读取的副本数) 参数值3.分段数目即 MD5值域被均匀切分总段数目,一般给成 2的次幂。4.具体的运算点或计算点位置信息ID ,LOCATION 我们记载全云路由信息,因此每个点的信息都需要记录。5.派发规则算法可以是以一个 provider,用于解析路由信息和实现派发逻辑6.其他辅助属性如连接

10、超时等参数 派发服务的路由查询云的路由信息作为元数据管理一般的设计方式是交给一个服务点做集中式管理,当发送方发送前访问该路由查询服务获取路由信息。这种传统方式的好处在于路由数据只有一点管理便于管理,尤其是更新。坏处是需要跨机器的额外查询,增加了交互,影响了性能当然可以做一定优化,让访问方在本地缓存以减少访问次数;另外一个坏处是系统存在单点,影响了系统可靠性。我们的方法是将路由信息(路由信息生成下一次将介绍)下放到路由服务机器上,让路由服务自己加载,这种本地管理避免了远程查询过程,带来了性能优化。可是也造成了路由更新实现的复杂性,要知道在分布系统更新路由并不能保证个点都同步和成功。因此需要解决个点路由不一致期间的数据的正确性。具体方法有很多,比如增加路由版本,更新保证分布事务等,这里不展开了。就我们的应用运行环境和应用要求(机房私有,环境稳定安全;云规模适中;要求高性能)而言,我们采用了第二种方法。 GOOGL 的 GFS采用的是第一种方式,具体那种需要看实际应用而言了。小结:关于分布化的实现就谈这么多了,虽然学院派会有更多的理论和方法,但我们认为企业应用不易复杂简单就是美。 下次我们继续谈谈关于云部署的其他服务组件以及管理方法了。

展开阅读全文
相关资源
正为您匹配相似的精品文档
相关搜索

最新文档


当前位置:首页 > 办公文档 > 其它办公文档

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号