第1回:EJBのすべてを知る (2/3)

EJB 3を再考する
EJB 3を再考する

第1回:EJBのすべてを知る

著者:レッドハット  田澤 孝之   2007/9/12
前のページ  1  2  3  次のページ
EJB 2.0の登場

   これらの反省からEJB 2.0では大きな変更が加えられました。実際にEJBを分散オブジェクト、特に粒度の細かなエンティティまでもをネットワークに分散配置することは稀というよりアンチパターンであり、ほとんどがWeb層からのローカル呼び出し、またはセッションファサードパターンによる1つのセッションBeanで粒度の細かいEJBはラップされました。

   これによってローカルインターフェースの追加が行われることになります。またオブジェクト指向の観点より嫌われたCMP(コンテナ管理永続化)エンティティBeanも、オブジェクト関連の表現が可能になり、かつエンティティBeanはローカルインターフェースのみに変更されています。

   そして第3のEJBであり、非同期通信を実現する「メッセージ駆動型Bean」が追加されました。その後、EJB 2.1でタイマーサービスやWebサービス対応が追加されていきました。
EJB 2でのEJBの種類
図3:EJB 2でのEJBの種類
(画像をクリックすると別ウィンドウに拡大図を表示します)

   しかしEJB 2では、相変わらず多くのファイルを記述する必要があり、開発という点での改善は見送られています。そこで開発現場ではEJB開発の敷居を下げようという動きが活発になりました。ここではEJB 2でもJavadocを応用したXDocletなどを利用してBeanの実装クラスのみを記述し、その他のソースコードやデプロイメント記述子の自動生成が行われるようになっていきます。

EJBでのXDocletの例
package ejb2;

⁄**
* @ejb.bean
*     name="Bank"
*     type="Stateless"
*     view-type="remote"
*/
public abstract class BankBean implements javax.ejb.SessionBean {

    private BankManager bank;

    ⁄**
     * @ejb.interface-method
     */
    public void withdraw(double amount) {
      double totalAmount = bank.getAmount() - amount;
      setAmount(totalAmount);
    }

    ⁄**
     * @ejb.interface-method
     */
    public void deposit(double amount) {
      double totalAmount = bank.getAmount() + amount;
      setAmount(totalAmount);
    }

    ⁄**
     * @ejb.create-method
     */
    public void ejbCreate() {
    }
}


EJB離れ

   このようにEJBが進化する中、開発者の間ではEJBを利用せずに「軽量にPOJOベースでの開発を」という動きが、EJB 2.0の仕様が登場してきた頃から活発化してきました。EJBコンテナを重量であると比喩し、「軽量コンテナ」で同等以上のことを実現しようというコンセプトを基にSpring Frameworkが登場します。

   あわせてJSPとサーブレットの実行エンジンであるApache Tomcatの品質と性能向上も相乗効果となりEJB不要論が顕著化していきます。ここでベンダー各社はEJBコンテナを除いた廉価版製品のリリースをはじめたのです。これも、EJB離れの加速を招いた要因の1つだったといえるでしょう。

   しかし、これは本当に正しい選択だったのでしょうか。確かにCMPはO/Rマッピングツールとしては不自然だったかもしれません。しかしセッションBeanとメッセージ駆動型Beanはよくできており、コンポーネントベース開発(CBD)の促進にもなります。トランザクション、セキュリティもよく動作しました。

   これらは元来からあるEJBのコンセプトです。そしてEJB離れが進む中でも、勘定系システムをJavaで構築している企業ではEJBコンテナを利用し、企業向けサービスのメリットを享受して、変化に強いシステムを実現しているのです。

前のページ  1  2  3  次のページ


レッドハット株式会社 田澤 孝之
著者プロフィール
レッドハット株式会社  田澤 孝之
JBossグループ SE部 マネージャー
1989年より日立製作所にてIT業界に身をおく。1998年より日本BEAシステムズにてTPモニタ、サーバサイドJavaにフォーカス。特にJ2EEに特化しプリセールス、インストラクタ、SOAコンサルタント業務に従事。2006年よりファストサーチ&トランスファで企業向けサーチソリューションコンサルタントを経て、2007年よりレッドハットにてJBossの販売提案と導入技術支援を行う。「EJB 2.0 徹底攻略」(技術評論社)など著書、共著多数。


INDEX
第1回:EJBのすべてを知る
 Java EEとEJB
EJB 2.0の登場
 EJB 3.0の登場
EJB 3を再考する
第1回EJBのすべてを知る
第2回ステートレスセッションBeanでの実装
第3回ステートフルセッションBeanでの実装
関連記事
JBoss Enterprise Application Platformの全貌
DIxAOPコンテナ「Seasar2とSpring」

人気記事トップ10

人気記事ランキングをもっと見る

企画広告も役立つ情報バッチリ! Sponsored