应用云平台的可用性——从新浪SAE看云平台设计
云计算平台的可用性,相比传统互联网服务而言,更加复杂和困难,也更具有挑战性。本文借助新浪SAE云平台为读者讲述了云平台可用性的定义、如何打造高可用的平台,以及对云计算的用户提出了建议。
该内容已经被标记书签!
标记书签错误,请重试!
作者 Bryan Clauser and Scott Delap 译者 张凯峰 发布于 2007年10月14日
虽然有时认为是理所当然,但Java Collections API无疑在每天的Java软件开发中扮演着重要的角色。然而API和相关的项目从未停止过发展。Alex Miller最近提到了Java 6中API的变化:
- 一个名为Deque (发音“deck”)的双头队列接口,以及对应的并发接口BlockingDeque ,实现类包括ArrayDeque 和LinkedBlockingDeque 。
- 名叫NavigableSet 和NavigableMap的用于排序set和map的新改进接口,以及一些像TreeSet和TreeMap那样的实现类。
- 用于并发和排序的新组合的接口:ConcurrentNavigableSet 和ConcurrentNavigableMap 。加上两个新的并发排序实现类名为ConcurrentSkipListSet和ConcurrentSkipListMap。
其中尤其引发他兴趣的是SkipList,它不像许多普通的CS数据接口,相对来说是个新的重新:
skip列表是个概率性的的数据结构,由William Pugh在1990年发明,列表基于平行的链接列表,效率相对二叉搜索树(对于大多数操作平均需要O(log n)时间)有显著改善。Google也一直致力于collections领域的工作,并发布了一套建立于标准的Java Collections Framework 的实现类。虽然还是alpha版本 ,但Google已经把它们使用在自己的许多服务中,比如GMail,Reader和Blogger。除了专注于为既有的Java Collections Framework增加复杂性和灵活性以外,Google也添加了许多的collections和工具类来使得编码变得更简单并提高代码可读性。
其中最值得注意的collection是:
译者 张凯峰 InfoQ中文站编辑,有多年软件开发和测试经验,热衷参与技术社区与技术传播。
云计算平台的可用性,相比传统互联网服务而言,更加复杂和困难,也更具有挑战性。本文借助新浪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分布式远程服务技术受到越来越多的关注,本文将对各种相关实现以示例的形式逐一介绍,并总结其中的优缺点,使读者能够在技术选型时有所准备。这是文章的下篇。
2 条回复
关注此讨论 回复