从卓越工程角度看微软中国开发团队的成长
开发团队的成长离不开优秀的人才,简捷有效的流程和高效率工具这三个卓越工程系统中的重要因素。本文作者从这三个因素分析了微软中国开发团队是如何“从优秀到卓越”的。
作者 高昂 发布于 2008年1月15日 上午7时9分
基于Rails框架应用开发的普及,在为用户带来众多创造性应用的同时,也赋予了开发者令人兴奋的高效与快捷体验。使用Rails开发Web应用的最后一个步骤,是要把Ruby代码从开发测试环境中迁移到实际生产模式之下。相比于开发过程来说,应用的部署并非易事。如何保证部署后站点的稳定和健壮性,并且可以从容应对大规模的并发访问,每一位富有经验的开发者或许都有自己的一套途径,就此,InfoQ中文站汇总了近期Rails部署问题的各方面观点,为您提供参考。
早在Rails应用普及之初,就时常会听见针对Rails部署问题的抱怨。对于PHP,一直以来都是以成熟的LAMP模式进行部署,讨论主要是集中在如何有效的进行服务器规模的拓展等等。而Rails方面则是没有统一的规则,Web服务器的组合方式和部署工具也都有各自的特色,应用的部署对开发新手来说,是个常会产生困惑的问题,在题为“我不喜欢RoR的原因”的帖子中,一位开发者提到:
RoR无疑是目前最具生产效率的开发框架之一,实现同样的应用,确使得开发时间缩减到原先的一半。但令我感到困扰的是,RoR对于开发者的确具有吸引力,但客户却并不这么认为。比方说,Rails应用的部署方式非常复杂,客户并不熟悉如何将开发好的应用部署在自己的服务器上,并且他们不喜欢使用命令行和脚本来操作Rails应用。
的确,相比PHP应用LAMP模式的部署,Rails的可选方案非常多。保持站点的稳定性和健壮性,所涉及的不仅仅是Rails或Ruby开发相关的技术,还有很多因素来自于Web服务器和应用服务器的选择与搭配。Rails部署常见的架构中,前端服务器加多个进程处理的方式如Fastcgi,Mongrel的选择以及与Web服务器的搭配使用,往往会给用户造成困扰。在《应用Rails进行敏捷Web开发》一书中,对于Rails的部署过程也作了简单的描述,但是所提供的部署方式并不十分合适于大规模网站的并发访问。论坛里的讨论中,常会针对于Lighttpd+FastCGI、Nginx+Mongrel、Apache+FastCGI等不同的搭配模式展开讨论。对于Mongrel服务器,Robbin在文章“RoR部署方案深度剖析”中评价道:
我们假设使用服务器端程序控制带权限的文件下载,某用户下载的是一个100MB的文件,该用户使用了多线程下载工具,他开了10个线程并发下载,那么每个线程Mongrel在响应之后,都会把整个文件读入到内存的StringIO对象当中,所以总共会创建出来10个StringIO对象保存10份文件内 容,所以Mongrel的内存会一下暴涨到1GB以上。而且最可怕的是,即使当用户下载结束以后,Mongrel的内存都不会迅速回落,而是一直保持如此 高的内存占用,这是因为Ruby的GC机制不好,不能够及时进行垃圾回收。
对此,robinlu根据自己的Rails部署经验写道:
Mongrel处理rails request和静态文件使用的是不同的handler。处理静态文件用的是DirHandler,DirHandler没有通过调用response的start方法使用到StringIO,而是直接调用了response的send_file方法,直接write socket。验证过程非常简单,自己起一个mongrel,在public下放一个100M的文件,通过浏览器下载一下。在我的mac上,本来是76M的mongrel,在下载结束后是74M,下载过程中也一直小于80M,最低到过68M。无论是过程中还是结束后,都没有出现占用内存暴涨的现象。
的确,针对Rails部署的Web服务器与应用服务器的搭配方案,会令客户面对众多的选择,并且JVM之上的JRuby以及微软.Net平台上的Ruby运行环境,都可能会使得Rails的部署呈现多元化发展的趋势。Robbin在文章中对于JavaEye站点部署方案的选择做出了如下的总结:
Lighttpd+FastCGI是性能最佳,服务器资源消耗最少的RoR部署方案,事实上目前RoR网站部署使用最多最流行的也是Lighttpd+FastCGI方式,而JavaEye网站,自然也是这种方式的部署。因此我们可以对各种方案进行一个性能优劣的排队,即Lighttpd+FastCGI是性能最佳方案,而Apache+FastCGI是性能最差方案。
从设计架构上来说,对静态文件的处理应尽量由Web服务器前端处理,避免多线程下载对cpu和带宽的影响。搭配的方式有很多,方案选择的优劣也不能一概而论,需要根据具体情况做出最合适自身的选择。在InfoQ中文站之前的一篇新闻“与时俱进的轻量级Web服务器”中,也解释了Lighttpd+FastCGI成为目前Rails网站优秀部署方案的原因。对于各种选择和经验之谈,毕竟是仁者见仁、智者见智的事情,但无疑,关注小型轻量级服务器的发展,及其自动化部署工具和一站式集成化生产环境,都会给应用的部署上线带来有益的帮助。
关于应用服务器部署的更多信息,可以在InfoQ中文站的部署或应用服务器相关主题,以及ChinaonRails的服务器架构讨论区中详细了解。
开发团队的成长离不开优秀的人才,简捷有效的流程和高效率工具这三个卓越工程系统中的重要因素。本文作者从这三个因素分析了微软中国开发团队是如何“从优秀到卓越”的。
本文是Productive Java with Ruby系列文章的第一篇,我将从单元测试这个话题开始,让Java的开发人员能够在实际工作中利用Ruby提高工作效率。
InfoQ中文站有幸与阿里软件的首席架构师赵进在一起探讨了SaaS的相关话题,包括SOA和ASP与SaaS的异同、云计算、SaaS的前景、它的关键技术、技术瓶颈等等。
在这篇文章中,Adrien Louis和Marc Dutoo在一个典型的ESB场景中讨论了编配和路由的区别和优缺点。他们讨论了几种连接服务的方法,从使用如自定义路由这样的低级别方法,到使用如工作流和编配这样面向业务的高级别方式,并总结说不存在“一边倒”的解决方案。
本文是根据7月26日InfoQ中文站在杭州举行的QClub活动(第三期)后半程小组讨论总结而成。主要内容包括如何在SOA系统中实现服务编排,如何保证分布式系统中的一致性和可用性,以及如何在实施SOA的过程中控制接口的粒度等。
人们很容易想当然的以为虚拟化技术仅仅应用于服务器。而在现实中,虚拟化这一苏醒的概念正被运用于各个层面,其中包括网络,存储以及应用基础架构。在这篇导论中,InfoQ将深入每个方面,详尽向您描述虚拟化技术的运用以及其优点与不足。
在这篇案例研究中,InfoQ对Adobe AIR和Amazon的简单存储服务(Simple Storage Service ,S3)在NASDAQ市场回放程序(NASDAQ Market Replay)中的应用进行了详细的分析。
没有回复
回复