天天看點

Gavin King所期望的Java EE 6新特性

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的業務方法……