• 1
  • 2
  • 3
  • 4
  • 5
阿里云应用开发 首 页  »  帮助中心  »  云服务器  »  阿里云应用开发
并行计算和云计算学习笔记
发布日期:2016-7-22 10:7:42

  Erlang算不上是一种"大众流行"的程序设计语言,且即使是Erlang的支持者,大多数也对Erlang成为"主流语言"并不持乐观态度。但自从2006年以来,Erlang语言确实在国内外一批精英程序员中暗流涌动,光我所认识与听说的,就有不少于一打技术高手像着了魔一样迷上了这种已有二十多年历史的老牌语言。这是一件相当奇怪的事情。由于就年龄而言,Erlang大约同Perl同年,比C++年轻四岁,长Java差不多十岁,但是 Java早已是工业主流语言,C++和Perl甚至已进入其生命周期的下降阶段。照理说,一个被扔在角落里二十多载无人理睬的老家伙合理的命运就是坐以待毙,没想到Erlang却像是突然吃了返老还童丹似的在二十多岁的"高龄"又火了一把,不仅对它感兴趣的人数量激增,且还成立了一些组织,开发实施了一些非常有影响力的软件项目。这是怎么回事呢?

  根本原因在于Erlang天赋异禀恰好适应了计算环境变革的大趋势:CPU的多核化与云计算。

  自2005年C++标准委员会主席Herb Sutter在Dr. Dobb's Journal上发表《免费午餐已经结束》一文以来,人们已确凿无

  疑地认识到若未来不能有效地以并行化的软件充分利用并行化的硬件资源,我们的计算效率就会永远停滞在仅略高于当前的水平上,而不得动弹。所以未来的计算必然是并行的。Herb Sutter本人曾表示,若一个语言不能以优雅可靠的方式处理并行计算的问题,那它就失去在21世纪的生存权。"主流语言"当然不想真的丧失掉这个生存权,所以纷纷以不同的方式解决并行计算的问题。就C/C++而言,除标准委员会致力于以标准库的方式来提供并行计算库外,标准化的OpenMP与 MPI,以及Intel的Threading Building Blocks库也都是可信赖的解决方案;Java在5.0版中引入意义重大的concurrency库,得到Java社区的一致推崇;而微软更是采用了多种手段来应对这一问题:先是在.NET中引入APM,随后又在Robotics Studio中提供了CCR库,最近又发布了Parrallel FX和MPI.NET,可谓不遗余力。但这些手法都可以视为亡羊补牢,由于这些语言与基础设施在创造时都没有把并行化的问题放到优先的位置来考虑。同它们相反,Erlang从其构思时起,就把"并行"放到了中心位置,其语言机制与细节的设计无不从并行角度出发与考虑,且在长达二十年的发展完善中不断成熟。今天,Erlang可说是为数不多的天然适应多核的可靠计算环境,这不能不说是一种历史的机缘。

  还有可能更加迫切的变革,就是云计算。Google的实践表明,用廉价服务器组成的服务器集群,在计算能力、可靠性等方面能达到价格昂贵的大型计算机的水准,毫无疑问,这是大型、超大型网站与网络应用梦寐以求的境界。胆要到达这个境界并不容易。目前一般的网站为了达成较好的可延展性与运行效率,需要聘请有经验的架构师和系统管理人员,手工配置网络服务端架构,且常备一个高水准的系统运维部门,随时准备处理各种意外情况。可以说,尽管大多数Web企业只不过是想在这些基础设施上运行应用而已,但仅为了让基础设施正常运转,企业就必须投入巨大的资源与精力。现在甚至可说,这方面的能力成了大型和超大型网站的核心竞争力。这与操作系统成熟之前人们自己动手设置硬件并且编写驱动程序的情形类似----做应用的人要精通底层细节。这种格局的不合理性一望便知,而解决的思路也是一目了然----建立网络服务端计算的操作系统,也就是类似Google已经建立起来的"云计算"那样的平台。所谓"云计算",指的是结果,而当前的关键不是这个结果,而是作为手段的"计算云"。实际上计算云就是控制大型网络服务器集群计算资源的操作系统,它不但可自动将计算任务并行化,充分调动大型服务器集群的计算能力,且还可自动应对大多数系统故障,实现高水平的自主管理。

  计算云技术是网络计算时代的操作系统,是绝对的核心技术,也正因为这样,很多赫赫有名的中外大型IT企业都在不惜投入巨资研发计算云,想国外的亚马逊,国内的阿里云。包括我在内的很多人都相信,云计算将不仅从根本上改变我们的计算环境,且将从根本上改变IT产业的盈利模式,是真正几十年一遇的重大变革,对于一些企业与技术人员来说是重大的历史机遇。恰恰在这个主题上,Erlang又具有先天的优势,这当然也是归结于其与生俱来的并行计算能力,让开发计算云系统对于Erlang来说格外轻松容易。现在Erlang社区已经开发了一些在实践中被证明非常有效的云计算系统,学习Erlang和这些系统是迅速进入这个领域并且提高水平的捷径。

  所以Erlang虽然目前还不是主流语言,但可能会在未来一段时间发挥重要的作用,所以对于那些愿意领略技术前沿风景的"先锋派"程序员来说,了解与学习Erlang可能是非常有价值的投资。即使你未来不打算使用Erlang,也非常有可能从Erlang的设计和Erlang社区的智慧中得到启发,从而能够在其他语言的项目中更好地完成并行计算和云计算相关的设计和实现任务。再退一步说,就算只是从开启思路、全面认识计算本质和并行计算特性的角度出发,Erlang也值得了解。因此我很希望这本书在中国程序员社区中不要遭到冷遇。

  本书是由Erlang创造者Joe Armstrong亲自执笔撰写的Erlang语言权威参考书,原作以轻松引导的方式帮助读者在实践中理解Erlang的深刻设计思路,并掌握以 Erlang开发并行程序的技术,在技术图书中属于难得的佳作。两位译者我都认识,他们都是技术精湛而思想深刻

  的"先锋派",对Erlang有着极高的热情,因此翻译质量相当高,阅读起来流畅通顺,为此书中译本添色不少。有兴趣的读者集中一段时间按图索骥,完全有可能就此踏上理解Erlang、应用Erlang的大路。