应用云平台的可用性——从新浪SAE看云平台设计
云计算平台的可用性,相比传统互联网服务而言,更加复杂和困难,也更具有挑战性。本文借助新浪SAE云平台为读者讲述了云平台可用性的定义、如何打造高可用的平台,以及对云计算的用户提出了建议。
该内容已经被标记书签!
标记书签错误,请重试!
作者 陈俊 发布于 2007年4月27日
Buffalo在经历了两年之久的考验后,近日正式发布2.0版本。Buffalo是一个J2EE轻量级AJAX框架,也是国内著名的开源项目。它与DWR 和JSON-RPC一样,着眼于Web远程调用(Web Remoting),其简洁而实用的特性一直以来深受开发者喜爱。 Buffalo2.0最大的特点在于其性能的提升,还有完全自行实现的Java到JavaScript协议转换。得益于新的协议实现以及为大规模AJAX调用而进行的优化,2.0版本比前一阶段版性能有进一步的提高。在国内,对JavaScript技术深入研究的人可谓凤毛麟角,Buffalo的作者陈金洲 (Michael Chen) 就是其中之一。关于这次Buffalo 2.0版本的新特性,陈金洲这样解释:
最令人振奋的特性应当是为大规模、频繁远程调用而进行优化的显著性能提升。在2.0-alpha1版本的性能测试中,性能最高提升达到了30%。即便不借助于高级的测试工具,从1.2升级到2.0的用户,应该能显著感受到速度的提升。
另外,Buffalo 1.x版本的用户都知道,之前的版本都基于Burlap协议,而Burlap协议的维护者Caucho公司已经很久没有更新这个库了。很多在Resin上使用Buffalo的用户发现这样或者那样基于Burlap的各种问题。种种考虑之后,2.0版本正式使用了完全自行编写的协议解析和转换。
当问到Buffalo希望在众多AJAX框架中扮演一个什么样的角色时,他回答:
最早的时候希望Buffalo成为一个全功能、全新的、Web 2.0时代的Web框架。异步传输只是其中最基础的一部分。后来发现凭借自己现有的资源(时间,、能力等)不太可能在能够预见的时间内完成这一目标。目前想达到的目标是:最简单最容易使用的AJAX框架。从使用者的反馈看来,这一目标完成的比较不错,大多数用户都能在很短的时间内配置Buffalo并开始使用。
那么和Web Remoting框架DWR 和JSON-RPC相比较,在JS-Java之间对象转换功能和协议上,Buffalo有何优势所在?
从整体产品上来说,最大的优势在于简单。核心API只有一个方法。在JS-Java对象转换上,谈不上优势吧,各有千秋:buffalo采用自我描述,完整的XML协议,DWR采用自定义文本协议,JSON对JavaScript更友好。
在一年多前的一次BEA活动上,就曾经听到满江红开源组织的负责人曹晓刚讲述“利用元数据和RIA简化企业应用程序的开发”的主题时推荐了Buffalo。时间过去了这么久,Buffalo并没有像许多的开源项目那样销声匿迹,而是还在不断完善,陈金洲解释了Buffalo的开发路线图和背后的支持动力:
2004年11月的时候我提出了AMOWA的概念——即面向消息的Web应用,第二年春即发布了1.0测试版本。具体的日程可以在Buffalo变更历史里看到。从Buffalo产生至今,整整两年了。新的开发计划,还有很多特性没有完成,例如跟Spring更紧密的集成;文件上载支持,以及更好的OPOA支持等。开发计划完全取决于社区的反馈,以及功能纯粹单一的综合衡量。我不希望Buffalo成为庞然大物。
其中的动力,我想最大程度上来自于Buffalo社区。在1.2版本发布的时候我写过一篇博客“写在Buffalo1.2发布之后”。我现在的想法虽然稍有不同,但归根结底就是:开源作者提出一个想法,需要得到社区的反馈;同时作者对反馈进行响应。这是一个长期的过程。对此我一直对处在社区中,对Buffalo进行贡献的用户心存感激。Buffalo方便了他们的工作,也满足了我作为一个软件作者某种程度上的虚荣心:),这种感觉,应该是最大的动力吧。
当Buffalo的用户遇到问题时,可以联系Buffalo邮件列表,绝大多数问题都可以找到答案,其他的开发者也会帮助你解决问题。
Buffalo社区能够不断成长,Michael Chen的努力让人感动。在remoting的时候选用不同的通讯方案是技术选型的一个比较关键的点,Buffalo选用xml的确能够满足一些团队的技术要求,提供了dwr以外的另外一个很好选择,同时大家也都愿意支持国人的开源项目。
愿Buffalo和amowa思想能够走的更远!
真是好多年了,自从BJUG上讲AMOWA,能走到现在真的很厉害,很佩服你。加油!
收藏
And the product keeps reporting ProtocolExceptions on high throughput w/o a reason. I guess it is not an industry-ready stuff. If you dig into the source you ll find nothing but craps.
云计算平台的可用性,相比传统互联网服务而言,更加复杂和困难,也更具有挑战性。本文借助新浪SAE云平台为读者讲述了云平台可用性的定义、如何打造高可用的平台,以及对云计算的用户提出了建议。
淘宝高度重视Java平台的健康发展,组建了一个团队专注于Java平台的底层部分的性能、功能与稳定性改进;工作主要基于OpenJDK中的HotSpot VM开展,其中一些通用的功能随后也会逐渐反馈给OpenJDK社区。希望能与使用Java平台开发应用的大家交流经验。
本次演讲视频录制于QCon杭州2011。
2011年4月21日至22日是值得云计算从业者纪念的日子。Amazon的IaaS服务出现故障,导致许多商业网站的服务中断,影响非常严重。作为云计算用户,我们需要思考的是,如何保证即便在云服务不可用的情况,我们的应用架构仍然能够屹立不倒?本文正是站在云计算用户的角度试图探讨这一问题。
12人的技术团队,4组刀片服务器,每月20亿的访问量,每日1次准时部署,99.9%的可用性。这可能吗?当然。想知道如何做的吗?百姓网将与您分享他们在DevOps实践过程中的经验和技巧。
本次演讲视频录制于QCon杭州2011。
篱笆作为一家起源于社区的电子商务公司,反映到技术层面就是同时要面对产品和业务,以及经营战略的变化调整。如何在产品和业务的夹缝之间完成技术架构的抽象与平衡,寻找更有效的价值定位,这当中有些经验教训和个人感悟愿与众人分享。
本次演讲视频录制于QCon杭州2011。
本文将对特性注入以及相关方法做一个扫盲性的介绍。我们会解释这个框架的关键要素,并附上实例来证实它们。为了让文章保持相对较短,我们不会深入到某个工具或方法中,而是会给出一些参考资料,以便大家做进一步的研究。
随着JDK 7的发布,字节码指令集终于迎来了第一位新成员——invokedynamic指令。这条新增加的指令是JDK 7实现“动态类型语言(Dynamically Typed Language)”支持而进行的改进之一,也是为JDK 8可以顺利实现Lambda表达式做技术准备。在这篇文章中,我们将去了解JDK 7这项新特性的出现前因后果和它的意义。
随着互联网应用的发展,Java分布式远程服务技术受到越来越多的关注,本文将对各种相关实现以示例的形式逐一介绍,并总结其中的优缺点,使读者能够在技术选型时有所准备。这是文章的下篇。
4 条回复
关注此讨论 回复