专访开源项目Amoeba架构师陈思儒
DBA notes站长冯大辉(Fenng)代表InfoQ中文站采访了分布式数据库Proxy开源项目Amoeba的架构师和主要开发者陈思儒,内容包括Amoeba项目的起因、功能及其愿景等。
作者 Scott Delap译者 Jason Lai 发布于 2007年4月2日 下午11时39分
Hibernate创始人和Seam项目领导人Gavin King最近发表了一个文章系列的第一篇,该系列阐述了他在Java EE 6中所希望看见的新特性。Gavin列表中的第一条提议是为无状态和有状态Session Bean提供更多的并发模式(Concurrecy Modes)。对此他提出了三个方案:
- 无并发模式(No concurrency),缺省模式,也是当前支持的方式:Bean不支持并发客户。如果两个请求同时到达,允许容器抛出ConcurrentAccessException异常。
- Bean管理的并发模式(Bean-managed concurrency):Bean支持由多个线程引发的并发访问,负责管理对可变数据结构的访问。
- 容器管理的并发模式(Container-managed concurrency):Bean支持并发客户端,容器负责保证线程在进入Bean实现之前按次序排队。
Gavin提出的第二条提议是轻量级异步性(Lightweight Asynchronicity)。他主张,目前JMS和EJB定时器的可选方案不足。此外,他提倡每个Bean拥有多个@Timeout方法,以及增强的调度选项。第三条提议则是有状态Web服务端点(Stateful Web Service Endpoint):
……目前只有无状态Session Bean才能做为Web服务端点。通过WS-Contexts或WS-Addressing(或者任意合适的WS-*),我们就能支持担当Web服务端点角色的有状态Session Bean。我还不清楚到底这会是什么样子,但我们在Seam/WS中进行的一些尝试可能会和它有所关联……
Gavin的愿望表还包括可选EJB业务接口(Optional Business Interfaces for EJBs)、简化的JMS/JavaMail、增强Logging注射(Enhanced Loggin Injection)和EJB Meta-Annotatons。对于可选业务接口,他认为:
目前EJB强制要求所有Session Bean都必须有@Local或者@Remote接口。当Session Bean存在于业务层内,并且业务逻辑和客户代码之间存在一个良好定义的API时,这并不是一个不合理的规定。……尤其在类似Seam的环境中,Bean的唯一客户可能只是一个带有EL表达式的JSF页面,此时接口则是完全多此一举的!……接口应当是可选的,当它不存在时,Bean类的public方法应当作为Session Bean的业务方法……
DBA notes站长冯大辉(Fenng)代表InfoQ中文站采访了分布式数据库Proxy开源项目Amoeba的架构师和主要开发者陈思儒,内容包括Amoeba项目的起因、功能及其愿景等。
作为三期系列文章的第二部分,本文延续了上一期内容,介绍了RichFaces,包括如何把RichFaces集成到之前提到的示例应用中、如何部署RichFaces porlet和RichFaces的多种特性和功能。
Amazon Web Services(AWS)的传道者Jeff Barr讨论了SimpleDB、S3、EC2、SQS、云计算、Amazon的不同服务如何与应用交互、AWS的起源、SimpleDB和微软SQL Server Data Services、AWS cloud的全球化、三月份的AWS停机。
Erlang的并发模型很有名,它的健壮性也很有名。但其他方面呢?在这篇文章里,Dennis Byrne演示了如何用Erlang建立内部DSL。
本视频主要以FreeWheel为例,对一个基于Rails的企业级应用进行了剖析。其中包括:FreeWheel的架构、部署、数据库的问题、REST API、敏捷开发过程、如何去写测试以及持续集成等等。
JavaFX显示了Sun的Java系列产品市场方向的一个重大转变。随着1.0版的即将发布,InfoQ以JavaFX预览版为参考,与Sun高级工程师Joshua Marinacci探讨了即将发布的1.0正式版。
本文主要讲述了如何用JBoss Portlet Container 和JBoss Portlet Bridge创建新项目,怎样配置一个JSF应用去使用JBoss Portlet Bridge,以及JBoss Portlet Bridge所具备的功能。
没有回复
回复