应用云平台的可用性——从新浪SAE看云平台设计
云计算平台的可用性,相比传统互联网服务而言,更加复杂和困难,也更具有挑战性。本文借助新浪SAE云平台为读者讲述了云平台可用性的定义、如何打造高可用的平台,以及对云计算的用户提出了建议。
该内容已经被标记书签!
标记书签错误,请重试!
作者 Robert Bazinet 译者 陈黎夫 发布于 2008年2月2日
C#开发团队中的Charlie Calvert和Mads Torgersen宣布他们将开始一个新的名为《Future Focus》的文章系列,其中将每月对C#最新的开发状况以及发展规划进行介绍。
据Charlie Calvert介绍,《Future Focus》系列的目的在于:
需要说明的是,读者必须对这个系列的文章内容有着正确的认识。文章中给出的信息仅仅是为了帮助C#开发者了解更多,而并不是任何形式的承诺。我们不会完完 整整地将所有的特性都一一列出,而只能尽力用一种通俗易懂的语言表达出来。Visual Studio的开发进度、不可预料的技术问题、知识产权事宜、来自竞争者的压力等等都可能影响到我们的进度,乃至我们能够在这里写出的内容。不过不管怎 样,我们都会在这个文章系列中尽力给出C#语言最新的发展方向。
可以看到,《Future Focus》系列文章并不会详细地给出C#未来版本的设计规范,而是会以一种更加容易理解的方式给出总览形式的介绍。
《Future Focus》的第一篇文章中介绍了有关动态查找(Dynamic Lookup)的功能。在下个版本的Visual Studio中,所有的.NET语言都将能够在运行时解析名称,而不是像现在这样只能在编译时进行。对于这个功能,Charlie是这样介绍的:
动态查找功能的实现最开始是从CLR开始的,不过很快该功能就变成了动态语言运行时(Dynamic Language Runtime,DLR)的一部分。有了DLR的支持,我们即可方便地创建一系列的动态工具。例如,DLR为IronRuby和IronPython二者都提供了基础支持。同样,C#开发团队也会借助于DLR所提供的基础设施来实现动态查找功能。
实际上,VB.NET中已经对动态查找提供了支持,不过它的动态查找通常被叫做延迟绑定(late binding)。新版本的.NET将会把这个功能引入到C#中来,同时也会为所有的.NET语言(包括VB)提供一个统一的运行时名称解析基础。
这篇文章中还介绍了动态查找的一些常见的应用场景:
Office编程:在下个版本的Visual Studio中,Office编程将会变得更加简单。开发人员再也无须引入众多的类库,或是指定调用方法时的可选参数了。对Office编程的支持也将成为对COM互操作以及OfficePIA增强的一部分。
对动态语言的支持:类似IronRuby和IronPython的动态语言正一天天地变得更加流行。目前,这些语言中可以直接调用C#代码,不过从C#中调用它们却并不容易。在下个版本的Visual Studio中,C#开发者能够非常容易地使用到IronPython 或IronRuby中定义的类型。这样,开发者就能够更容易地使用现有的动态语言代码,同时也为编写新功能提供了更多的选择。
调用反射:目前,C#开发者能够借助反射在运行时初始化类型并任意调用其方法。有了动态查找的支持,此类调用将会被大大简化。
动态语言运行时(DLR)对于现在正日益流行的动态语言来说非常重要,也为动态语言和非动态语言之间的交互搭起了一座桥梁。诸如Silverlight 2.0之类的产品将在发布时广泛应用到这些动态语言的特性。
Charlie还给出了一段使用动态查找的示例代码:
使用动态查找的语法还没有最终确定。下面的代码仅仅是开发团队的一段实验性质的尝试。
我们目前正在考虑添加一个名为dynamic的关键字来将动态代码块分隔开:
static void Main(string[] args)
{
dynamic
{
object myDynamicObject = GetDynamicObject();
myDynamicObject.SomeMethod(); // call a method
myDynamicObject.someString = "value"; // Set a field
myDynamicObject[0] = 25; // Access an indexer
}
}dynamic块中的所有代码都能够支持潜在需要的动态查找功能——哪怕代码中尝试访问的成员并不能在编译时确定,编译器也不会抛出异常。在运行时,DLR将会在myDynamciObject所引用的对象中查找相应的方法或属性。若能够找到的话,则进行调用,否则将抛出异常。而在dynamic块之外的代码仍将只支持静态访问,就和我们现在的写法一样。
若你对这些内容感兴趣,可以继续关注Charlie的博客中的这个《Future Focus》系列文章。
云计算平台的可用性,相比传统互联网服务而言,更加复杂和困难,也更具有挑战性。本文借助新浪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分布式远程服务技术受到越来越多的关注,本文将对各种相关实现以示例的形式逐一介绍,并总结其中的优缺点,使读者能够在技术选型时有所准备。这是文章的下篇。
没有回复
关注此讨论 回复