剖析短迭代
敏捷教练Dave Nicolette提出:我们应该如何设定迭代长度?是要根据发布周期的时间么?使用短迭代又有哪些好处?
作者 R.J. Lorimer译者 张凯峰 发布于 2008年8月1日 上午5时16分
由Sun的Brian Goetz和Robert Eckstein合作撰写的有关Java和实时系统的文章最近登载在Sun开发者网络上,该系列文章由两部分组成。在一个真正的实时环境中,线程优先级是极其重要的,没有一个系统可以保证,所有的任务都能够准时完成。然而,一个实时系统能够确保的是,当有些任务即将超过最终时限时,可以先牺牲低优先级的任务来保障它的执行。Goetz和Eckstein接着提到Java实时系统规范的核心概念——实时线程:
RTSJ定义了至少28种优先权级别,并要求严格执行此规定。然而,正如本篇文章前面所说,RTSJ的实现依赖于支持多种优先权的实时操作系统,和高优先级线程抢占低优先级线程的能力。
此外,RTSJ可允许非实时和实时活动同时存在于一个Java应用中,对一个活动的时序保证程度依赖于活动所属线程类型:第一部分讲到的最后一个概念是,支持内存管理所做的各种扩展。由于与垃圾回收及对象分配相关的延迟的存在,三个内存区域被划分出来:java.lang.Thread或javax.realtime.RealtimeThread线程类型。
- 标准java.lang.Thread(JLT)线程用来支持非实时的活动。JLT线程可以应用Thread类定义的10种优先权级别,但是它们不适用于实时活动,因为不能够提供时序执行保证。
- RTSJ还定义了
javax.realtime.RealtimeThread(RTT)线程类型。RTTs可以利用RTSJ提供的强大的线程优先权支持,它的调度遵循运行直至阻塞(run-to-block)原则,而非按时间片运行原则。这就意味着,当有另外具有较高优先权的RTT出现时,调度程序会抢占该RTT。
引入RealtimeThread的扩展类——NoHeapRealtimeThread,以实时友好的方式辅助管理这些独特的内存区域:
RTSJ提供一个RTT的子类,称为然而,即使软件正在使用特定的内存区域,它的资源使用依然很容易受到内存其它非关键部分的GC的影响。由于这个原因,该系列文章的第二部分集中于和垃圾回收相关的问题,阐述了可用于实时Java系统的不同GC方法,然后介绍了Sun的商业实时Java系统:Java RTS。在第二部分中描述了四种垃圾回收算法:NoHeapRealtimeThread(NHRT)。该子类得实例可以避免由垃圾回收引起的不稳定情况。这个NHRT类是为硬实时(hard-real-time)活动所准备的。
为最大化可预测性,NHRTs不能访问垃圾回收堆,也不能操纵堆变量。否则,线程会遭遇GC暂停,这将导致任务错过运行时限。与此相反的是,NHRT可以更具预测性的方式使用作用域内存和永久内存特性分配内存。
本文主要讲述了如何用JBoss Portlet Container 和JBoss Portlet Bridge创建新项目,怎样配置一个JSF应用去使用JBoss Portlet Bridge,以及JBoss Portlet Bridge所具备的功能。
在这篇文章里,Bryon Jacob和Chris Berry将和我们继续探讨AtomServer,它是基于Apache Abdera的完整Atom存储实现。作者还创建了几个Atompub规范扩展,其中包括自动标记、批处理和Feeds聚合。
InfoQ中文站的电子杂志《架构师》试刊第二期出版了!相比于上期,我们在内容的选择安排和版式上都根据读者的意见重新做了修正。“细节决定成败”,我们希望基于InfoQ中文站的专业内容,《架构师》能逐渐成为大家喜欢的电子刊物!
在本文中,Steven Haines探讨了Web应用性能调优问题。该领域过去更像是一门艺术而不是一门科学。他提出了一种称为基于等待调优的方法,使整个调优过程更加可度量,也因此更具科学性。
通常来说,改变技术路线时最艰难的部分是辨别语言语法之间的不同。这篇文章就为Java开发者提供了一份如何转向Flex基础语言ActionScript的指南。
本视频主要以财帮子为例,介绍了如何创建一个PV为百万级的Rails应用。其中包括:Rails应用的服务器架构、Rails Cache的优化、负载均衡的处理、Web服务器的调试、分布式解决方案、Open API的设计等等。
InfoQ首席架构师Alexandru Popescu在采访中谈论了InfoQ架构、Webwork与DWR、Hibernate与JCR、Hibernate可扩展性、最新的InfoQ视频流系统和InfoQ的未来规划。
没有回复
回复