大规模视频网站的计费与流量管理
本次分享将会就大规模视频网站的计费与流量管理这个话题,从操作层面细细进行讲解和分析,为系统工程师们揭示平日里我们没有关心的另一些内容。同时也希望本次分享能揭示行业中的一些“潜规则”,让互联网行业的流量与带宽管理更为开放与简洁。
本次演讲视频录制于QCon杭州2011。
该内容已经被标记书签!
标记书签错误,请重试!
作者 赵劼 发布于 2009年6月15日
Duck Typing是动态语言的重要特性之一,据Wikipedia中的定义,这个名称及概念由James Whitcomb Riley提出:
当一只鸟走路像鸭子,游泳像鸭子,叫起来也像鸭子,那么我们就认为它就是鸭子。
对于传统的静态类型的语言(如C#或Java),类型的判定会在编译期进行,如果一系列类型需要对外界释放出某种共同的行为,那么它们则必须符合一个共同的协议(如基类或接口)。在支持Duck Typing的语言(如JavaScript或Python)中,对于某个对象成员的访问会在运行时进行检查,正所谓“延迟判定”。关于Duck Typing的优劣,动态检查和静态检查之间的讨论已经数不胜数。
如果在C#等静态语言中希望实现Duck Typing一般都会借助反射或动态生成适配器的方式进行,而在C# 4.0中甚至增加了dynamic关键字从语法层面实现了Duck Typing。不过在F#中实现了一种在编译期进行检查的Duck Typing特性。Matthew Podwysocki在他的文章中展示了这样一个例子:
let inline flyAndWalk arg = let flying = ( ^a : (member Fly : unit -> string) arg) let walking = ( ^a : (member Walk : unit -> string) arg) (flying, walking) type Duck() = member this.Swim() = "paddling" member this.Fly() = "flapping" member this.Walk() = "waddling" type Eagle() = member this.Fly() = "soaring" member this.Walk() = "creeping" let (eFly, eWalk) = flyAndWalk (new Eagle()) let (dFly, dWalk) = flyAndWalk (new Duck())
在以上代码中,flyAndWalk方法限制了arg参数所必须具备的条件:“拥有特定签名的Fly和Walk方法”,而编译器则会对flyAndWalk方法的使用进行校验。F#提供了inline关键字使一个函数在编译时内联至调用方,不过它也限制了此类方法被.NET平台上的其他语言调用。此外,与“范型”在运行时生成新类型的方式有所不同,“^”符号表示在编译期对可变类型进行静态解析。有关inline和“^”符号的含义及作用,Michael Giagnocavo的文章对此有较为详细的解释及相关示例。
F#的强类型Duck Typing特性在编译期限制了可用类型的结构,在保证了类型安全的同时,避免使用特定的协议来强制约束不同的类型。在OCaml、Scala等语言中,类似的特性也被称作Structure Typing。Lmeyerov认为:
Duck typing看上去包含了动态的含义,而Structure subtyping是Ocaml静态世界中的瑰宝。
laogao也有类似的看法:
我觉得严格意义上我们不应该称其为duck typing,而是用structural typing,只是在跟别人解释的时候,也许可以说它类似动态语言如Python、Ruby、Groovy等中的duck typing的概念。“duck typing”这个概念还是留给动态语言吧,让它指代在运行期而非编译期对类型的判定,静态语言如Scala,还是叫“structural typing”吧。
您会在什么情况下使用这个特性呢?F#作为集成至VS 2010中的一线语言,已经展现出越来越强的生命力,您准备好了吗?
赵劼 网名为老赵,洋名Jeffrey Zhao,写有技术博客“老赵点滴”。关注前沿技术,并致力于开源社区与微软平台的组合优化。
本次分享将会就大规模视频网站的计费与流量管理这个话题,从操作层面细细进行讲解和分析,为系统工程师们揭示平日里我们没有关心的另一些内容。同时也希望本次分享能揭示行业中的一些“潜规则”,让互联网行业的流量与带宽管理更为开放与简洁。
本次演讲视频录制于QCon杭州2011。
Jeffrey Richter以其多本Windows核心技术的经典著作而闻名,同时,他深入掌握微软的.NET等一系列核心技术,2012年1月,Jeffrey Richter在北京接受了InfoQ中文站的专访,谈到Windows 8和WinRT编程,并就异步编程、Windows编程中的可扩展性、性能和安全性方面给出自己的建议。
云计算平台的可用性,相比传统互联网服务而言,更加复杂和困难,也更具有挑战性。本文借助新浪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。
本文将对特性注入以及相关方法做一个扫盲性的介绍。我们会解释这个框架的关键要素,并附上实例来证实它们。为了让文章保持相对较短,我们不会深入到某个工具或方法中,而是会给出一些参考资料,以便大家做进一步的研究。
没有回复
关注此讨论 回复