JP2000250768A - サーバ・オブジェクトのメソッドを呼び出すプロセス方法及びデータ処理システム - Google Patents

サーバ・オブジェクトのメソッドを呼び出すプロセス方法及びデータ処理システム

Info

Publication number
JP2000250768A
JP2000250768A JP2000045445A JP2000045445A JP2000250768A JP 2000250768 A JP2000250768 A JP 2000250768A JP 2000045445 A JP2000045445 A JP 2000045445A JP 2000045445 A JP2000045445 A JP 2000045445A JP 2000250768 A JP2000250768 A JP 2000250768A
Authority
JP
Japan
Prior art keywords
adapter
server
data processing
processing system
client
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Granted
Application number
JP2000045445A
Other languages
English (en)
Other versions
JP4146983B2 (ja
Inventor
A Aputo Aja
アジャ・エイ・アプト
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
International Business Machines Corp
Original Assignee
International Business Machines Corp
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by International Business Machines Corp filed Critical International Business Machines Corp
Publication of JP2000250768A publication Critical patent/JP2000250768A/ja
Application granted granted Critical
Publication of JP4146983B2 publication Critical patent/JP4146983B2/ja
Anticipated expiration legal-status Critical
Expired - Fee Related legal-status Critical Current

Links

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/46Multiprogramming arrangements
    • G06F9/54Interprogram communication
    • G06F9/547Remote procedure calls [RPC]; Web services
    • G06F9/548Object oriented; Remote method invocation [RMI]
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L69/00Network arrangements, protocols or services independent of the application payload and not provided for in the other groups of this subclass
    • H04L69/30Definitions, standards or architectural aspects of layered protocol stacks
    • H04L69/32Architecture of open systems interconnection [OSI] 7-layer type protocol stacks, e.g. the interfaces between the data link level and the physical level
    • H04L69/322Intralayer communication protocols among peer entities or protocol data unit [PDU] definitions
    • H04L69/329Intralayer communication protocols among peer entities or protocol data unit [PDU] definitions in the application layer [OSI layer 7]
    • YGENERAL TAGGING OF NEW TECHNOLOGICAL DEVELOPMENTS; GENERAL TAGGING OF CROSS-SECTIONAL TECHNOLOGIES SPANNING OVER SEVERAL SECTIONS OF THE IPC; TECHNICAL SUBJECTS COVERED BY FORMER USPC CROSS-REFERENCE ART COLLECTIONS [XRACs] AND DIGESTS
    • Y10TECHNICAL SUBJECTS COVERED BY FORMER USPC
    • Y10STECHNICAL SUBJECTS COVERED BY FORMER USPC CROSS-REFERENCE ART COLLECTIONS [XRACs] AND DIGESTS
    • Y10S707/00Data processing: database and file management or data structures
    • Y10S707/99941Database schema or data structure
    • Y10S707/99944Object-oriented database structure
    • Y10S707/99945Object-oriented database structure processing
    • YGENERAL TAGGING OF NEW TECHNOLOGICAL DEVELOPMENTS; GENERAL TAGGING OF CROSS-SECTIONAL TECHNOLOGIES SPANNING OVER SEVERAL SECTIONS OF THE IPC; TECHNICAL SUBJECTS COVERED BY FORMER USPC CROSS-REFERENCE ART COLLECTIONS [XRACs] AND DIGESTS
    • Y10TECHNICAL SUBJECTS COVERED BY FORMER USPC
    • Y10STECHNICAL SUBJECTS COVERED BY FORMER USPC CROSS-REFERENCE ART COLLECTIONS [XRACs] AND DIGESTS
    • Y10S707/00Data processing: database and file management or data structures
    • Y10S707/99941Database schema or data structure
    • Y10S707/99948Application of database or data structure, e.g. distributed, multimedia, or image

Landscapes

  • Engineering & Computer Science (AREA)
  • Software Systems (AREA)
  • Theoretical Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • General Engineering & Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Stored Programmes (AREA)
  • Computer And Data Communications (AREA)
  • Multi Processors (AREA)

Abstract

(57)【要約】 【課題】 Javaクライアントが、別のJavaアプ
リケーションと通信することを可能にする機構を提供す
ること。 【解決手段】 CORBAサーバ上で実行されるEJB
のインタフェース上で内観することによりアダプタが生
成される。アダプタはJavaクライアント側に存在
し、クライアントからの全てのビジネス・メソッド呼び
出しをサーバ上のCORBAプロキシに委託し、Jav
aクライアントからCORBAプロキシへの、及びその
逆のデータ整備を実行する。クライアントによりアダプ
タに発行されるビジネス・メソッド呼び出しは適切なデ
ータ変換の後、アダプタによりCORBAプロキシに委
託される。サーバ・オブジェクト内のメソッドを呼び出
そうとする間、クライアント・オブジェクトはアダプタ
内のメソッドを呼び出し、アダプタが透過的にオブジェ
クト参照を用いてサーバ上のオブジェクト参照のスケル
トンを呼び出し、これが次にサーバ・オブジェクト内の
メソッドを呼び出す。

Description

【発明の詳細な説明】
【0001】
【発明の属する技術分野】本発明は一般に、改善された
分散データ処理システムに関し、特に、分散データ処理
システム内のクライアント及びサーバ上にオブジェクト
を含む、分散アプリケーションのための方法及び装置に
関する。
【0002】
【関連技術】本発明は、本願と同時に出願された米国特
許出願"Method and System for Persisting Beans as C
ontainer-Managed Fields"(出願人整理番号:AT99
8907)に関連する。
【0003】
【従来の技術】ソフトウェア開発者は、企業全体に及ぶ
アプリケーションの作成が困難であり、分散アプリケー
ションの作成が更に困難である根本的な問題に直面して
いる。更に、企業は1つのプラットフォームに閉ざされ
ること無く、できる限り速くアプリケーションを作成す
ることを願望する。理想的には、企業開発者は一旦アプ
リケーションを作成したら、それを彼らの全てのプラッ
トフォーム上で実行することを希望する。Enterprise J
avaBeans(商標)技術は、この能力を提供しようとす
る。
【0004】Enterprise JavaBeans(EJB)コンポー
ネント・アーキテクチャは、企業がスケーラブルで安全
なマルチプラットフォーム業務用アプリケーションを、
再利用可能なサーバ側コンポーネントとして作成するこ
とを可能にするように設計される。その目的は、企業開
発者が業務論理(またはビジネス論理)の作成だけに注
力できるようにすることにより企業問題を解決すること
である。
【0005】サーバ側環境、及びそれをサービスするた
めに必要とされるツールは、EJB技術のための設計目
標に多大に影響する。1つの主要な設計目的は、分散ア
プリケーションを作成するプロセスをできる限り低減す
ることである。この目的は、Enterprise JavaBeansの単
純な宣言属性に、通常、手作業でコーディングされる必
要のあるフィーチャを転換することにより達成された。
これらの宣言属性は、開発効率の多大な向上をもたら
す。なぜなら、セキュリティ及びトランザクションなど
の特定の振舞いがコード内にセットされるのではなく、
ビーン自身上の"フラグ"であるからである。
【0006】EJB仕様は、トランザクション、セキュ
リティ、スレッディング、名前付け、オブジェクト・ラ
イフサイクル、資源プーリング、リモート・アクセス、
及び持続性などのシステム・レベルのプログラミングを
世話するインフラストラクチャを作成する。EJB仕様
はまた、既存のアプリケーションへのアクセスを単純化
し、ツール作成使用のために均等なアプリケーション開
発モデルを提供する。
【0007】Javaは、Javaクライアントがリモ
ート・メソッド呼び出し(RMI)と呼ばれる方法によ
り、別のプロセスで動作しているJavaサーバ上のメ
ソッドを呼び出す機構を提供する。しかしながら、例え
ば共通オブジェクト・リクエスト・ブローカ・アーキテ
クチャ(CORBA:Common Object Request BrokerAr
chitecture)準拠のサーバなど、サーバがJava環境
で動作していない場合、JavaクライアントはCOR
BAサーバ上のメソッドに対してメソッド呼び出しを発
行できない。なぜなら、JavaはCORBAオブジェ
クトと通信するための固有の機構を提供しないからであ
る。
【0008】要するにCORBAは、アプリケーション
がどこに配置されようと、或いは誰がそれらを設計した
かに関わらず、アプリケーションが互いに通信すること
を可能にするオブジェクト・リクエスト・ブローカ(O
RB)である。オブジェクト・リクエスト・ブローカ
は、オブジェクト間のクライアント−サーバ関係を確立
するミドルウェアである。企業は、様々なソフトウェア
・アプリケーション間の相互運用性を提供するための解
決策としてCORBAに注目した。
【0009】
【発明が解決しようとする課題】データ整備、すなわ
ち、JavaクライアントとCORBAサーバ間での異
なるタイプのデータのためのデータ変換を実行するため
の標準的な機構は存在しない。Javaクライアントが
CORBAサーバなどの非Java環境で実行されるE
JBなどの、別のJavaアプリケーションと通信する
ことを可能にする機構を有することが有利である。
【0010】
【課題を解決するための手段】本発明は、CORBAサ
ーバ上で実行されるEJBのインタフェース上で内観
(introspect)することにより生成されるアダプタを提
供する。アダプタはJavaクライアント側に存在し、
EJBを実行するCORBAサーバのリモート・プロキ
シを含む。アダプタはEJBのビジネス・メソッドを呼
び出すために、EJBにより指定されるインタフェース
を実装するJavaクラスである。アダプタは、クライ
アントからの全てのビジネス・メソッド呼び出しをサー
バ上のCORBAプロキシに委託し、Javaクライア
ントからCORBAプロキシへの、及びその逆のデータ
整備を実行する。クライアントによりアダプタに発行さ
れるビジネス・メソッド呼び出しは適切なデータ変換の
後、アダプタによりCORBAプロキシに委託される。
従って、アダプタはJavaクライアントとCORBA
サーバ上のEJBとの間の透過的な接着剤として作用す
る。
【0011】
【発明の実施の形態】図1を参照すると、本発明が実装
され得る分散データ処理システムの図を示す。分散デー
タ処理システム100は、本発明が実現され得るコンピ
ュータのネットワークである。分散データ処理システム
100はネットワーク102を含み、これは分散データ
処理システム100内で一緒に接続される様々な装置及
びコンピュータ間で、通信リンクを提供するために使用
される媒体である。ネットワーク102は電線または光
ファイバ・ケーブルなどの永久接続、または電話接続を
通じて形成される一時接続を含み得る。
【0012】図示の例では、サーバ104が記憶ユニッ
ト106と共にネットワーク102に接続される。更
に、クライアント108、110及び112がネットワ
ーク102に接続される。これらのクライアント10
8、110及び112は、例えばパーソナル・コンピュ
ータまたはネットワーク・コンピュータである。本願の
目的上、ネットワーク・コンピュータはネットワークに
接続される任意のコンピュータであり、ネットワークに
接続される別のコンピュータからプログラムまたは他の
アプリケーションを受信する。図示の例では、サーバ1
04はブート・ファイル、オペレーティング・システム
・イメージ、及びアプリケーションなどのデータをクラ
イアント108乃至112に提供する。クライアント1
08、110及び112は、サーバ104のクライアン
トである。分散データ処理システム100は図示されな
い追加のサーバ、クライアント及び他の装置を含み得
る。図示の例では、分散データ処理システムは100は
インターネットであり、ネットワーク102が、TCP
/IPプロトコル一式を使用し互いに通信するネットワ
ーク及びゲートウェイの世界的な集合を表す。主要ノー
ドまたはホスト・コンピュータ間の高速データ通信回線
の中枢がインターネットの中心部にあり、データ及びメ
ッセージを経路指定する数千の商業用、政府用、教育
用、及び他のコンピュータ・システムを含む。勿論、分
散データ処理システム100は、例えばイントラネッ
ト、ローカル・エリア・ネットワーク(LAN)、また
は広域ネットワーク(WAN)などの、多数の異なるタ
イプのネットワークとしても実現され得る。図1は例と
して示されただけであり、本発明のプロセスの体系的な
制限を意図するものではない。
【0013】図2を参照すると、このブロック図は、図
1のサーバ104など、本発明に従いサーバとして実現
されるデータ処理システムを示す。データ処理システム
(サーバ)200は、システム・バス206に接続され
る複数のプロセッサ202及び204を含む対称マルチ
プロセッサ(SMP)・システムであり得る。或いは、
単一プロセッサ・システムが使用され得る。システム・
バス206には更に、メモリ制御装置/キャッシュ20
8が接続され、これはローカル・メモリ209とのイン
タフェースを提供する。I/Oバス・ブリッジ210は
システム・バス206に接続され、I/Oバス212と
のインタフェースを提供する。メモリ制御装置/キャッ
シュ208及びI/Oバス・ブリッジ210は、図示の
ように統合され得る。
【0014】I/Oバス212に接続される周辺コンポ
ーネント相互接続(PCI)バス・ブリッジ214は、
PCIローカル・バス216とのインタフェースを提供
する。多数のモデム218乃至220がPCIバス21
6に接続される。一般的なPCIバス・インプリメンテ
ーションは、4つの拡張スロットまたは増設コネクタを
サポートする。図1のネットワーク・コンピュータ10
8乃至112への通信リンクは、増設ボードを介してP
CIローカル・バス216に接続されるモデム218及
びネットワーク・アダプタ220を介して提供され得
る。
【0015】追加のPCIバス・ブリッジ222及び2
24は、PCIバス226及び228のためのインタフ
ェースを提供し、これらのバスから追加のモデムまたは
ネットワーク・アダプタがサポートされ得る。このよう
に、サーバ200は複数のネットワーク・コンピュータ
への接続を可能にする。また図示のように、メモリマッ
プド・グラフィックス・アダプタ230及びハード・デ
ィスク232も、直接的にまたは間接的にI/Oバス2
12に接続され得る。
【0016】当業者には明らかなように、図2に示され
るハードウェアは変化し得る。例えば、光ディスク・ド
ライブなどの他の周辺装置も、追加で、または図示のハ
ードウェアの代わりに使用され得る。図示の例は、本発
明に関する体系的な制限を意味するものではない。
【0017】図2に示されるデータ処理システムは、例
えばIBMの製品であるIBM RISC/System6000システム
であり、AIX(Advanced Interactive Executive)オ
ペレーティング・システムを実行する。
【0018】次に図3を参照すると、本発明が実現され
得るデータ処理システムのブロック図が示される。デー
タ処理システム300は、クライアント・コンピュータ
の例である。データ処理システム300は、周辺コンポ
ーネント相互接続(PCI)ローカル・バス・アーキテ
クチャを使用する。図示の例はPCIバスを使用する
が、マイクロチャネル及びISAなどの他のバス・アー
キテクチャも使用され得る。プロセッサ302及び主メ
モリ304がPCIブリッジ308を介してPCIロー
カル・バス306に接続される。PCIブリッジ308
は、プロセッサ302のための統合型メモリ制御装置及
びキャッシュ・メモリを含み得る。PCIローカル・バ
ス306への追加の接続は、直接コンポーネント相互接
続を介してまたは増設ボードを介して形成され得る。図
示の例では、ローカル・エリア・ネットワーク(LA
N)・アダプタ310、SCSIホスト・バス・アダプ
タ312、及び拡張バス・インタフェース314が直接
コンポーネント接続によりPCIローカル・バス306
に接続される。それに対して、音声アダプタ316、グ
ラフィックス・アダプタ318、及びスマートカード・
アダプタ319は、拡張スロットに挿入される増設ボー
ドにより、PCIローカル・バス306に接続される。
拡張バス・インタフェース314は、キーボード及びマ
ウス・アダプタ320、モデム322、及び追加のメモ
リ324のための接続を提供する。SCSIホスト・バ
ス・アダプタ312は、ハード・ディスク・ドライブ3
26、テープ・ドライブ328、及びCD−ROMドラ
イブ330のための接続を提供する。一般的なPCIロ
ーカル・バス・インプリメンテーションは、3つまたは
4つのPCI拡張スロットまたは増設コネクタをサポー
トする。
【0019】オペレーティング・システムはプロセッサ
302上で実行され、図3のデータ処理システム300
内の様々なコンポーネントの制御を調整及び提供するた
めに使用される。オペレーティング・システムはIBM
から提供されるOS/2などの、市販のオペレーティン
グ・システムであってよい。"OS/2"はIBMの商標
である。Javaなどのオブジェクト指向のプログラミ
ング・システムが、オペレーティング・システムと共に
実行され、データ処理システム300上で実行されるJ
avaプログラムまたはアプリケーションからオペレー
ティング・システムに呼び出しを提供する。"Java"
はサン・マイクロシステムズ社の商標である。オペレー
ティング・システムの命令、オブジェクト指向オペレー
ティング・システム、及びアプリケーションまたはプロ
グラムは、ハード・ディスク・ドライブ326などの記
憶装置上に配置され、主メモリ304にロードされ、プ
ロセッサ302により実行される。
【0020】当業者には明らかなように、図3のハード
ウェアはインプリメンテーションに応じて変化し得る。
フラッシュROM(または等価な不揮発性メモリ)また
は光ディスク・ドライブなどの、他の内部ハードウェア
または周辺装置が更に追加で、または図3に示されるハ
ードウェアの代わりに使用され得る。また、本発明のプ
ロセスはマルチプロセッサ・データ処理システムに適用
され得る。
【0021】例えば、データ処理システム300は、ネ
ットワーク・コンピュータとして任意的に構成される場
合、図3に点線332で示されるボックス内のSCSI
ホスト・バス・アダプタ312、ハード・ディスク・ド
ライブ326、テープ・ドライブ328、及びCD−R
OM330を含まなくてよい。すなわち、点線ボックス
内のコンポーネントは任意に含まれ得ることを示す。そ
の場合、正確にはクライアント・コンピュータと呼ばれ
るコンピュータは、LANアダプタ310やモデム32
2などの、特定タイプのネットワーク通信インタフェー
スを含まねばならない。別の例として、データ処理シス
テム300は自身が特定タイプのネットワーク通信イン
タフェースを含むか否かに関わらず、特定タイプのネッ
トワーク通信インタフェースに頼ることなく、ブート可
能に構成される独立型のシステムである。更に別の例と
して、データ処理システム300はパーソナル・デジタ
ル・アシスタント(PDA)装置であり、これはオペレ
ーティング・システム・ファイルまたはユーザ生成デー
タを記憶する不揮発性メモリを提供するために、ROM
またはフラッシュROMにより構成される。
【0022】図3の図示の例、及び前述の例は、本発明
に関する体系的な制限を意味するものではない。
【0023】本発明は、JavaクライアントがCOR
BAサーバ上のEJBと通信可能な分散アプリケーショ
ンを提供する方法、データ処理システム、及び命令を提
供する。分散アプリケーション内における本発明につい
て述べる都合上、従来の総称的な分散アプリケーション
について詳述することにする。
【0024】本発明のプロセスは、オブジェクト指向プ
ログラミング・システムであるJavaプログラミング
・システムを用いて実現され得る。オブジェクト指向プ
ログラミング技術は、"オブジェクト"の定義、作成、使
用及び命令を含み得る。これらのオブジェクトは、デー
タ要素または属性、及びデータ要素を操作するメソッド
を含むソフトウェア・エンティティである。オブジェク
トはまた、オブジェクト内のメソッドをトリガまたは制
御するオブジェクト外の事象に関連するデータを含み得
る。
【0025】オブジェクトは、"クラス"を定義すること
により定義される。クラスはオブジェクトではなくテン
プレートであり、コンパイラに実際のオブジェクトの作
成方法を指示する。例えば、クラスはデータ変数の数及
びタイプや、データを操作する機能に関わるステップを
指定し得る。オブジェクトは実際、コンストラクタと呼
ばれる特殊機能によりプログラム内で作成される。コン
ストラクタは、対応するクラス定義、及びオブジェクト
作成の間に提供される引き数などの追加の情報を使用
し、オブジェクトを構成する。オブジェクトはデストラ
クタと呼ばれる特殊機能により破壊される。Javaは
また、インタフェースとして知られる完全な抽象クラス
の作成を許容し、これは他のクラスが如何にメソッドを
処理しているかに関わり無く、複数のクラスと共用され
得るメソッドの定義を可能にする。
【0026】図4を参照すると、従来の分散アプリケー
ションを示す図が示される。図示のように、クライアン
ト・オブジェクト400は、分散アプリケーションのク
ライアント側に存在し、一方、サーバ・オブジェクト4
02は分散アプリケーションのサーバ側を形成する。ク
ライアント・オブジェクト400は、例えば図1の分散
データ処理システム100内のクライアント108など
の、クライアント・コンピュータ上に配置される。サー
バ・オブジェクト402は、図1のサーバ104などの
サーバ上に配置される。クライアント・オブジェクト4
00は、サーバ・オブジェクト402内に実装される様
々なビジネス規則またはビジネス論理にもとづき、デー
タベース404をアクセスするために、サーバ・オブジ
ェクト402への呼び出しを開始する。データベース4
04はサーバ内に配置されるか、リモート・データベー
スである。サーバ・オブジェクト402は現企業アプリ
ケーション410へのアクセス、及びレガシ・アプリケ
ーション408へのアクセスも提供し得る。分散アプリ
ケーションを作成するユーザが、サーバ・オブジェクト
402を実装する第2階級(tier)のコンピュータの、
ホスト名またはインターネット・プロトコル(IP)・
アドレスを構成することを可能にするためにカストマイ
ザが提供され得る。この例では、Javaリモート・メ
ソッド呼び出し(RMI)プロトコル406が、クライ
アント・オブジェクト400及びサーバ・オブジェクト
402などのオブジェクト間の分散通信のために使用さ
れる。
【0027】サーバ・オブジェクト402は、アプリケ
ーション・プログラミング・インタフェース(API)
を用いて実装される実際のビジネス論理を含む。API
はJava定義Javaデータベース接続性(JDB
C)構造化照会言語(SQL)データベース・アクセス
・インタフェースを使用し、これは広範囲のリレーショ
ナル・データベースへの均等なアクセスを提供する。図
示の例では、これらのデータベースはデータベース40
4内で見いだされ得る。サーバ・オブジェクト402
は、クライアント・オブジェクト400から呼び出され
る必要な機能を提供するために使用されるメソッドを含
む。前述のメソッドは、他の後置システム(すなわちC
ICS、IMS、MQ、SAPなど)をアクセスするた
めに作成され、JDBCまたはデータベース・アクセス
だけに制限されるべきではない。
【0028】分散アプリケーション内におけるデータベ
ース・アクセスの例について、引き続き述べると、デー
タベース・アクセス機能は2つのオブジェクト、すなわ
ちクライアント・オブジェクト及びサーバ・オブジェク
トに分けられる。サーバ・オブジェクトは、クライアン
ト・オブジェクトから呼び出され、JDBCを使用する
メソッドを含むインタフェースを実装する。
【0029】クライアント・オブジェクトは、様々な事
象の事象ソースまたは事象シンクとして作用する。生成
時、クライアント・オブジェクトはクライアント側ビル
ダ環境で使用され、他のクライアント側ソフトウェア・
コンポーネントに接続される。例えば、クライアント側
生成時にアプリケーション・アセンブラがクライアント
側ビルダ環境を使用し、GUIオブジェクトをクライア
ント・オブジェクトに接続する。従って、ボタンが押下
されるとき、特定のデータを検索するための事象がオブ
ジェクトに送信される。サーバ側生成時には、アプリケ
ーション・アセンブラがビルダ環境を使用し、サーバ・
オブジェクトを接続する。
【0030】実行時、ユーザはクライアント上のボタン
を押下し、これは特定のデータが表示のために要求され
ることを示す。GUIオブジェクトは事象を生成し、こ
れがクライアント・オブジェクトに送信される。クライ
アント・オブジェクトは、必要なデータを要求するサー
バ・オブジェクト上のメソッドを呼び出す。クライアン
ト・オブジェクトは、リモート・メソッド呼び出し(R
MI)またはIIOP(Internet InterOrb Protocol)
を使用するオブジェクト・リクエスト・ブローカ(OR
B)などのプロトコルを使用することにより、その対応
するサーバ・オブジェクトと通信する。サーバ側オブジ
ェクトはデータを検索し、データをクライアント側オブ
ジェクトに返送する。データが次にクライアント側オブ
ジェクトによりGUIオブジェクトに返送され、エンド
ユーザに表示される。
【0031】図示の例では、クライアント・オブジェク
ト400及びサーバ・オブジェクト402を実装するJ
avaビーンズが使用され得る。ビーンを純粋なオブジ
ェクトと区別するのは、それが属性インタフェースと呼
ばれる外部インタフェースを有することであり、これは
ツールがコンポーネントが実行しようとしていることを
読出し、それを他のビーンにフック留めし(hook u
p)、それを別の環境にプラグ・インすることを可能に
する。2つの異なるタイプのビーン、すなわちJavaBean
s及びEnterprise JavaBeans(EJB)が使用され得
る。JavaBeansは単一のプロセスに対して局所的である
ようにもくろまれ、しばしば実行時に見ることができ
る。このビジュアル・コンポーネントは、ボタン、リス
ト・ボックス、グラフィックまたはチャートなどであ
る。
【0032】EJBは、サーバ上で実行され、クライア
ントにより呼び出されるように設計される、見ることが
できないリモート・オブジェクトである。EJBは複数
の見ることができないJavaBeansから構成される。EJ
Bはあるマシン上に常駐し、別のマシンから遠隔的に呼
び出されるようにもくろまれる。EJBは、ツールによ
り読出され得るビーンに関する記述としてもくろまれる
展開記述子(deployment descriptor)を有する。EJ
Bはまたプラットフォーム独立であり、Javaをサポ
ートする任意のプラットフォーム上で使用され得る。
【0033】サーバ・ビーンズすなわちEJBは、サー
バ上に展開される遠隔的に実行可能なコンポーネントま
たはビジネス・オブジェクトである。EJBはそれらが
遠隔的にアクセスされることを可能にするプロトコルを
有し、このプロトコルは、EJBが特定のサーバ上に導
入または展開されることを可能にする。EJBはサービ
スの主要な品質、セキュリティ、トランザクション振舞
い、同時性(2つ以上のクライアントにより一度にアク
セスされる能力)、及び持続性(どのようにそれらの状
態が保管され得るか)をEJBサーバ上においてそれら
が配置されるコンテナに委託する一連の機構を有する。
EJBはそれらの振舞いを異なるサービス品質を提供す
るコンテナ内に導入される。展開ツールの使用を通じ
て、プラットフォーム独立のJavaBeanがプラットフォー
ム特定のEJBに取り入れられる。後者は、既存のビジ
ネス・システム及びアプリケーションの特定の要求に合
致するために使用可能な適正なサービス品質を有する。
【0034】クライアント・ビーン400とサーバ・ビ
ーン402間のこの分離により、サーバ・ビーン402
内の様々なビジネス論理の変更がクライアント・ビーン
400の変更無しに実行され得る。これは単一のサーバ
をアクセスする数千のクライアントが存在し得ることを
考慮すると望ましい。更にこれらのプロセスは、例えば
COBOLなどの今日的でないプログラミング言語によ
り作成されたプログラムにも適用され得る。こうしたプ
ログラムの動的変更は、そのプログラムをJavaなど
のオブジェクト指向プログラミング・システムと互換に
するインタフェースを作成することにより実行され得
る。
【0035】分散アプリケーション内及び間の通信サー
ビスは、例えばOMG(Object Management Group)コ
ンソーシアムにより設計されたCORBA規格など、J
avaリモート・メソッド呼び出し(RMI)以外の他
のタイプの分散プロトコルによっても同様に実現され得
る。CORBAは、今日使用可能な急増しつつあるハー
ドウェア及びソフトウェア製品の間の相互運用性のニー
ズに対するOMGの回答である。要するに、CORBA
はアプリケーションがどこに配置されようと、また誰が
それらを設計したかに関わらず、アプリケーションが互
いに通信することを可能にするオブジェクト・リクエス
ト・ブローカ(ORB)である。
【0036】オブジェクト・リクエスト・ブローカは、
オブジェクト間のクライアント−サーバ関係を確立する
ミドルウェアである。オブジェクト・リクエスト・ブロ
ーカを使用することにより、クライアントは同一マシン
上に存在する、またはネットワークを介して存在するサ
ーバ・オブジェクト上のメソッドを透過的に呼び出すこ
とができる。オブジェクト・リクエスト・ブローカは呼
び出しを横取りし、要求を実現するオブジェクトを見い
だす責任があり、それにパラメータを受け渡し、そのメ
ソッドを呼び出し、結果を返却する。クライアントは、
オブジェクトが配置されている場所、そのプログラミン
グ言語、そのオペレーティング・システム、またはオブ
ジェクトのインタフェースの一部でない他のシステム態
様を知る必要はない。そうすることにより、オブジェク
ト・リクエスト・ブローカは、異種の分散環境内の異な
るマシン上のアプリケーション間の相互運用性を提供
し、複数のオブジェクト・システムを継ぎ目無く相互接
続する。
【0037】典型的なクライアント/サーバ・アプリケ
ーションを扱うために、開発者は彼ら自身の設計または
認識された規格を使用し、装置間で使用されるプロトコ
ルを定義する。プロトコル定義はインプリメンテーショ
ン言語、ネットワーク・トランスポート、及び幾つかの
他のファクタに依存する。オブジェクト・リクエスト・
ブローカはこのプロセスを単純化し、柔軟性を提供す
る。オブジェクト・リクエスト・ブローカは、構成中の
システムの各コンポーネントのために、プログラマが大
抵の適切なオペレーティング・システム、実行環境、及
びプログラミング言語さえも選択し、使用することを可
能にする。更に重要な点は、オブジェクト・リクエスト
・ブローカは既存のコンポーネントの統合を可能にす
る。ORBベースの解決策では、開発者は新たなオブジ
ェクトを作成するために使用するのと同一のインタフェ
ースを用いて、レガシ・コンポーネントをモデル化し、
次に標準化バスとレガシ・インタフェース間を変換す
る"ラッパ(wrapper)"・コードを作成する。
【0038】CORBAは、オブジェクト指向標準化及
び相互運用性に向けての重要な進歩を表すオブジェクト
・リクエスト・ブローカである。CORBAにより、ユ
ーザは、情報がどのソフトウェアまたはハードウェア・
プラットフォーム上に存在するか、或いは情報がネット
ワーク内のどこに配置されるかを知る必要無しに、情報
へのアクセスを透過的に獲得できる。CORBAオブジ
ェクト開発の目的は、オブジェクト・サーバまたは単に
サーバの生成及び登録である。サーバはプログラムであ
り、1つ以上のオブジェクト・タイプのインプリメンテ
ーションを含み、オブジェクト・リクエスト・ブローカ
に登録される。
【0039】CORBAは、オブジェクトが企業及び大
陸さえも横断して通信することを可能にするオブジェク
ト・バスを詳述する。CORBAは、高機能コンポーネ
ントが互いに発見し合い、オブジェクト・バスを介して
相互運用することを可能にするように設計された。しか
しながら、CORBAは単なる相互運用性を超越する。
CORBAはバス関連サービスの拡張セットを指定する
ことにより、オブジェクトを作成及び消去し、それらを
名前によりアクセスし、それらを永久記憶装置に記憶
し、それらの状態を外部化し、それらの間の臨時の関係
を定義する。
【0040】JDKバージョン1.1の発表により、J
avaはリモート・メソッド呼び出し(RMI)と呼ば
れる、それ自身の組み込み型の固有のオブジェクト・リ
クエスト・ブローカを有する。リモート・メソッド呼び
出しは、リモート・オブジェクト上のメソッド呼び出し
を行うといった総称的な意味では、オブジェクト・リク
エスト・ブローカであるが、それはCORBA準拠のオ
ブジェクト・リクエスト・ブローカではない。リモート
・メソッド呼び出しはJavaに固有である。リモート
・メソッド呼び出しは、本来、中核を成すJava言語
の拡張である。リモート・メソッド呼び出し(RMI)
は、Javaオブジェクト直列化、移植性のあるダウン
ロード可能なオブジェクト・インプリメンテーション、
及びJavaインタフェース定義などの、他の多くのフ
ィーチャに依存する。他方、リモート・メソッド呼び出
しは幾つかの制限を有し、その最も偉大な強み、すなわ
ちJavaとのその堅い統合の結果である原理上の制限
が、他の言語により作成されたオブジェクトまたはアプ
リケーションとの使用を非現実的なものにする。
【0041】Javaは、拡張によるリモート・メソッ
ド呼び出しと共に具体的なプログラミング技術である。
Javaは基本的に、実行可能コードを作成及び編成す
る問題を解決するために設計された。Javaはそれな
りにプログラミング技術の間に、特定のポイントを築き
上げる。Javaと他のプログラミング言語との間に存
在する隔たりは、時に行き交うことが困難である。例え
ば、JavaコードからAdaコードに呼び出しを行う
ために使用される技術は、JavaコードからC++コ
ードに呼び出しを行うために使用されるものと幾分異な
る。このことは多言語環境において、システムの生成を
複雑化させ、複雑化は使用される言語の数と共に著し
く、時に非線形的に増加する。
【0042】JavaはJavaネイティブ・インタフ
ェース(JNI:Java Native Interface)と呼ばれる
APIを提供し、これはJavaコードが他の言語によ
るルーチンを呼び出す、または呼び出されることを可能
にする。JNIは主にC及びC++言語との相互運用の
ために適合化され、習得するのにかなり難しいインタフ
ェースである。リモート・メソッド呼び出しはJava
間の技術である。Javaクライアントがリモート・メ
ソッド呼び出しを使用し、別の言語のリモート・オブジ
ェクトと通信したい場合、"異質の(foreign)"リモー
ト・オブジェクトと一緒に配置されるJava媒介を介
する必要がある。この場合の根本的な問題は、Java
が定義上、言語自身の境界内で作用するプログラミング
技術であることである。
【0043】それに対してCORBAは統合技術であ
り、プログラミング技術ではない。CORBAは特に、
異種のプログラミング技術を一緒に結合する接着剤とし
て設計される。CORBAはプログラミング空間内のポ
イントとして存在するのではなく、個々の言語を表すポ
イント間の空間を占有する。例えば、Javaクライア
ントがCORBA技術を使用し、C++オブジェクトと
通信するとき、C++プログラマ及びJavaプログラ
マの両者は、完全にそれぞれの言語環境内で作業する。
CORBAのオブジェクト・リクエスト・ブローカは、
JavaクライアントにJavaスタブ・インタフェー
スを提供し、C++プログラマにC++スケルトン・イ
ンタフェースを提供する。CORBAは言語間問題を自
動的に解決する。
【0044】CORBAは統合指向の見地を提供し、そ
こでは設計努力がシステムの要素間の境界に絞られる。
基礎となるインタフェース技術(例えばIIOP)は、
それらの境界をできる限り柔軟で、適応的で、プログラ
ミング技術独立にするように設計される。CORBAな
どのインタフェース技術は、プログラミング技術よりも
長い半減期を有するだけでなく、廃れたプログラミング
言語への依存による、アプリケーションの追加及び死去
に対する最善の防御である。
【0045】図5を参照すると、CORBA規格を使用
する従来の分散アプリケーションが示される。クライア
ント・オブジェクト500は、通信リンク510として
示されるIIOP規格を使用し、CORBAサーバ52
0と通信する。CORBAサーバ520は、異種のタイ
プのソフトウェア・オブジェクトのための統合及び相互
運用性を提供する。JavaBean521、C++オブジェク
ト522、EnterpriseJavaBean(EJB)523、及び
COBOLオブジェクト524は、サーバ520により
提供されるCORBAサービスを用いて通信し、サービ
ス機能を登録する。クライアント・オブジェクト500
は、CORBAサービスを通じて、オブジェクト521
乃至524により提供される機能及びメソッドを呼び出
す。
【0046】図6を参照すると、CORBAを用いて相
互運用性機能を提供する従来の分散アプリケーション内
のコンポーネントが示される。図6は、クライアント6
02から、サーバ内のCORBAオブジェクト・インプ
リメンテーションに送信されるメソッド要求618を示
す。クライアントは、CORBAサーバ上のメソッドを
呼び出す任意のコードであり、ことによるとそれ自身が
CORBAオブジェクトである。サーバント620は、
オブジェクト・インプリメンテーションのインスタン
ス、すなわちCORBAオブジェクトを実現する実際の
コード及びデータである。
【0047】CORBAサーバ・オブジェクトのクライ
アント602は、サーバ・オブジェクトに対するオブジ
ェクト参照616を有し、クライアントはこのオブジェ
クト参照を使用し、メソッド要求618を発行する。
【0048】オブジェクト参照は、オブジェクト・リク
エスト・ブローカ内のをオブジェクトを指定するために
必要とされる情報である。クライアントは通常、幾つか
の異なる方法によりオブジェクト参照を獲得する。第1
に、クライアントはオブジェクトを作成するためにオブ
ジェクト上の"作成"メソッドを呼び出す。作成メソッド
は、新たなオブジェクトに対するオブジェクト参照をク
ライアントに返却する。第2に、クライアントは、命名
サービスに要求を発行することにより、オブジェクト参
照を獲得する。命名サービスはオブジェクト参照を名前
によりデータ構造内に記憶し、クライアントは特定タイ
プのハードコード化ネットワーク・アドレスではなし
に、オブジェクトの関連付けられる名前によりオブジェ
クト参照を探索または解析する。すなわち、オブジェク
トを同一の物理マシン内で、またはネットワーク上のど
こかで突き止める。最後に、クライアントは、オブジェ
クト参照をストリング化することにより特定的に作成さ
れたストリングからオブジェクト参照を獲得する。
【0049】一旦オブジェクト参照が獲得されると、ク
ライアントはCORBAオブジェクトを自身上に呼び出
せるように、適切なタイプに制限する。
【0050】サーバ・オブジェクトが遠隔的である場
合、オブジェクト参照はスタブ機能604を指し示し、
これがオブジェクト・リクエスト・ブローカ・マシンを
使用して、呼び出しをサーバ・オブジェクトに転送す
る。CORBAクライアントは、その全てのデータ整備
及びIIOP作業を実行するために、ローカル・オブジ
ェクト・リクエスト・ブローカ・オブジェクトを必要と
する。スタブ・コードはオブジェクト・リクエスト・ブ
ローカ606により、サーバ・オブジェクトを実行する
マシンを識別し、そのマシンのオブジェクト・リクエス
ト・ブローカ610に、オブジェクトのサーバ614へ
の接続を依頼する。スタブ・コードが接続を有すると
き、それはオブジェクト参照及びパラメータを宛先オブ
ジェクトのインプリメンテーションにリンクされるスケ
ルトン・コード612に送信する。スケルトン・コード
は呼び出し及びパラメータを要求されたインプリメンテ
ーション特定の形式に変換し、オブジェクトを呼び出
す。あらゆる結果または例外が、同一の経路に沿って返
却される。
【0051】クライアントは、CORBAオブジェクト
の位置、インプリメンテーション詳細、及びオブジェク
トをアクセスするために使用されるオブジェクト・リク
エスト・ブローカを知らない。異なるオブジェクト・リ
クエスト・ブローカが、IIOP608を介して通信し
得る。
【0052】クライアントは、CORBAオブジェクト
のインタフェース内で指定されるメソッドだけを呼び出
し得る。インタフェースはオブジェクト・タイプを定義
し、命名メソッド及びパラメータのセットの他に、これ
らのメソッドが返却し得る例外タイプを指定する。サー
バ・オブジェクトのクライアントは、サーバ・オブジェ
クトに対応するオブジェクト参照へのアクセスを有し、
そのオブジェクトに対するオペレーションを呼び出す。
クライアント・オブジェクトは、そのインタフェースに
従い、サーバ・オブジェクトの論理構造だけを知り、メ
ソッド呼び出しを通じてサーバ・オブジェクトの振舞い
に遭遇する。重要な点は、クライアント−サーバ関係が
2つの特定のオブジェクトに関連することである。すな
わち、一方のサーバ・オブジェクトのインプリメンテー
ションは、他のサーバ・オブジェクトのクライアントで
有り得る。
【0053】スタブ及びスケルトン・ファイルは、様々
な方法により生成される。スタブ・ファイルは、クライ
アント・プログラミング言語により、クライアントにサ
ーバ・メソッドへのアクセスを提供する。サーバ・スケ
ルトン・ファイルは、オブジェクト・インプリメンテー
ションをオブジェクト・リクエスト・ブローカ(OR
B)実行時に結び付ける。オブジェクト・リクエスト・
ブローカはスケルトンを使用し、メソッドをオブジェク
ト・インプリメンテーション・インスタンス(サーバン
ト)にディスパッチする。
【0054】従来技術の説明から本発明の説明に目を向
けると、図7及び図8は、Java及びCORBAの利
点を結合する本発明の詳細を示す。前述のように、リモ
ート・メソッド呼び出しは、Javaクライアントがリ
モート・メソッド呼び出しによりリモート・オブジェク
トと通信することを強要する、Java間の技術であ
る。Javaは定義上、言語自身の境界内で作用するプ
ログラミング技術である。それに対して、CORBAは
統合技術であり、プログラミング技術ではない。本発明
は、JavaクライアントがCORBAクライアント上
に存在するEJBのビジネス・メソッドを呼び出すこと
を可能にする。
【0055】図7を参照すると、このブロック図は、C
ORBAサーバ内で実行されるEnterprise JavaBean
(EJB)のリモート・ビジネス・メソッドを呼び出す
方法を実現するために使用されるコンポーネントを示
す。図7のシステムは、図4及び図6に示されるシステ
ムに類似する。図7は、クライアント700及びサーバ
726が、Java仮想マシンJVM702及びJVM
724を含むJava実行時環境によりイネーブルされ
る以外は、図4に示される分散アプリケーションと類似
する。図7は図6と類似する。なぜなら、クライアント
602及びサーバ614と同様に、Javaクライアン
ト・オブジェクト704がリモートEJB728内のメ
ソッドを呼び出そうとしているからである。
【0056】更に、図7の分散アプリケーションは、オ
ブジェクト・リクエスト・ブローカORB714及びO
RB718を含み、オブジェクト要求及び応答をIIO
P716を介して伝達する。図6の総称的なアーキテク
チャは、クライアント、サーバ、スタブ、及びスケルト
ンを含み、オブジェクト・リクエスト・ブローカが図7
のソフトウェア・アーキテクチャ内に反映され、これは
本発明の方法に従い、JavaオブジェクトがCORB
Aを用いて通信することを可能にする。
【0057】JVM702は、EJB728内に存在す
るビジネス・メソッドを呼び出そうとしているJava
クライアント・オブジェクト704を含む。Java仮
想マシン(JVM)は、メモリ内に存在する仮想コンピ
ュータ・コンポーネントである。特定のケースでは、J
VMはプロセッサ内で実現され得る。JVMはJava
プログラムが、コードがコンパイルされたあるプラット
フォームだけではなしに、異なるプラットフォーム上で
実行されることを可能にする。JavaプログラムはJ
VMのためにコンパイルされる。このように、Java
は、様々な中央処理ユニット及びオペレーティング・シ
ステム・アーキテクチャを含み得る多くのタイプのデー
タ処理システムのためにアプリケーションをサポートで
きる。
【0058】Javaアプリケーションが異なるタイプ
のデータ処理システム上で実行されるようにするため
に、コンパイラは一般に、アーキテクチャ中立ファイル
形式を生成する。すなわち、Java実行時システムが
存在する場合、コンパイルされたコードが多くのプロセ
ッサ上で実行可能である。Javaコンパイラは、特定
のコンピュータ・アーキテクチャには特定的でないバイ
トコード命令を生成する。バイトコードは、Javaコ
ンパイラにより生成されるマシン独立なコードであり、
Javaインタプリタにより実行される。Javaイン
タプリタは、バイトコードを交互に解読及び実行するJ
VM内のモジュールである。これらのバイトコード命令
は、任意のコンピュータ上で容易に解釈され、また固有
マシン・コードに即座に容易に変換されるように設計さ
れる。
【0059】JVM702は、EJBインタフェース7
08をクライアント・オブジェクト704に提供するア
ダプタ706を含み、それにより、クライアント・オブ
ジェクト704はリモート・メソッド呼び出しの既知の
メソッドを使用し、EJBインタフェース708内のメ
ソッドを呼び出す。EJBインタフェース708はCO
RBAプロキシ710を呼び出し、サーバ726とのC
ORBA通信を開始する。CORBAプロキシ710
は、オブジェクト要求をオブジェクト・リクエスト・ブ
ローカORB714に受け渡す。この例では、ORB7
14はJavaにより実現される。ORBがC++によ
り実現される場合、オブジェクト要求はJavaネイテ
ィブ・インタフェース(JNI)を通じて受け渡され
る。ORB714及びORB718はIIOP716を
介して通信し、オブジェクト要求がクライアント及びサ
ーバ・オブジェクトにより、オブジェクト・リクエスト
・ブローカを用いて透過的にサポートされることを保証
する。一旦ORB718がオブジェクト要求を受信する
と、EJBスケルトン720内のコードが呼び出され、
EJB728から要求されたビジネス・メソッドの呼び
出しを開始する。EJBスケルトン720はJNI72
2を用いてEJB728を呼び出し、適切な引き数をJ
VM724内に含まれるEJB728に受け渡す。この
特定の例では、EJBスケルトン720はC++により
実現され得るが、JNI722の使用を要求するJav
a以外の別の言語によっても実現され得る。
【0060】図8を参照すると、このブロック図は、サ
ーバ・オブジェクトのリモート・メソッドを呼び出す方
法を実現するために使用されるコンポーネントを示す。
図8のシステムは、クライアント750がある言語によ
り実装されるクライアント・オブジェクト752を有
し、サーバ772が異なる言語により実装されるサーバ
・オブジェクト770を有するように、環境が一般化さ
れる以外は、図7に示されるシステムと類似する。
【0061】クライアント750はアダプタ754を含
む。アダプタはクライアント・オブジェクト752のた
めにオブジェクト参照により、サーバ・オブジェクト7
70上のリモート・メソッド呼び出しをシミュレートす
る。クライアント・オブジェクト752はアダプタ75
4内のメソッドを呼び出し、これがオブジェクト参照7
56を呼び出し、サーバ772とのオブジェクト通信を
開始する。オブジェクト参照756は、データ整備モジ
ュール758を通じてオブジェクト要求をオブジェクト
・ディスパッチャ760に受け渡す。オブジェクト・デ
ィスパッチャ760及びオブジェクト・ディスパッチャ
764は、オブジェクト通信リンク762を介して通信
し、オブジェクト要求がクライアント及びサーバ・オブ
ジェクトにより適切なオブジェクト要求プロトコルを用
いて、透過的にサポートされることを保証する。オブジ
ェクト・ディスパッチャ764はオブジェクト要求をデ
ータ整備モジュール766を介して、リモート呼び出し
スケルトン768に受け渡す。データ整備モジュール7
58及びデータ整備モジュール766は、異なる言語に
より実装されるオブジェクトを含む相互運用環境のため
に、適切なデータ変換及び呼び出し変換機構を提供す
る。リモート呼び出しスケルトン768は、サーバ・オ
ブジェクト770内のメソッドを呼び出し、適切な引き
数をサーバ・オブジェクト770に受け渡す。
【0062】図9を参照すると、CORBAサーバ内で
実行されるEnterprise JavaBean(EJB)上のリモー
ト・ビジネス・メソッドを呼び出す方法を示すフロー図
が示される。図7に関連して前述したように、Java
クライアント・オブジェクトからJavaアダプタ、O
RB及びEJBスケルトンを介して所望のEJBに至る
プロセス・フローは、図9に示されるプロセス・フロー
に類似する。図9は、本発明のJava及びCORBA
環境内の実際の呼び出し及びクラス操作を示す。
【0063】プロセスは、クライアント内のコードがリ
モート・オブジェクトの名前を探索するとき開始する
(ステップ802)。クライアントは、EJB内のビジ
ネス・メソッドなど、リモート・サーバ内のオブジェク
トのメソッドの実行を要求する。ルックアップ・メソッ
ド内のコードが所望のメソッドを含むリモート・オブジ
ェクトに対応するCORBAプロキシの名前を見いだす
(ステップ804)。適切なCORBAプロキシが見い
だされた後、その対応するCORBAプロキシのための
適切なアダプタ・クラスが突き止められる(ステップ8
06)。CORBAプロキシは適切なアダプタ・クラス
によりラップ(wrap)され(ステップ808)、アダプ
タ・クラスが呼び出し側クライアント・コードに総称オ
ブジェクトとして返却される(ステップ810)。クラ
イアント・コードは、返却された総称オブジェクトを必
要なクラス・タイプに固定する(ステップ812)。ク
ライアント・コードは次に、新たに獲得されたオブジェ
クトから所望のメソッドを呼び出し(ステップ81
4)、新たに獲得されたアダプタ・クラス内の所望のメ
ソッドが呼び出される(ステップ816)。呼び出され
たアダプタ・クラス・メソッド内のコードは、CORB
Aプロキシ内のその対応するメソッドを呼び出す(ステ
ップ818)。一旦メソッドがCORBAプロキシ内で
実行を開始すると、CORBAインフラストラクチャ
が、CORBAサーバ上のCORBAプロキシに対応す
るリモート・オブジェクトの呼び出しを処理する(ステ
ップ820)。
【0064】図9の方法は、図8に示されるオブジェク
ト指向環境のために一般化され得る。CORBAプロキ
シを通じてEJBのメソッドを呼び出すのではなく、ソ
ース・オブジェクト及びターゲット・オブジェクトがサ
ーバ・オブジェクトのメソッドに一般化され、そのオブ
ジェクト参照を通じて呼び出される。本発明の一般化さ
れた方法によれば、サーバ・オブジェクトに対するオブ
ジェクト参照がアダプタによりラップされ、クライアン
ト・オブジェクトによるサーバ・オブジェクト内のメソ
ッドの呼び出しがアダプタにより透過的に処理される。
クライアント・オブジェクトがサーバ・オブジェクトの
メソッドを呼び出そうとするとき、メソッドは実際、ア
ダプタ・オブジェクト内で呼び出される。アダプタ・ク
ラスは本質的に、オブジェクト参照がクライアント・コ
ードから分離されるように、オブジェクト参照をラップ
する。クライアントはオブジェクト参照について何も知
らない。クライアントはただ、アダプタ・コードに"話
しかける(talk to)"だけであり、他方、サーバ上のス
ケルトン・コードに"話しかける"オブジェクト参照は、
クライアント・ベースのアダプタに関して何も知らな
い。
【0065】図10乃至図13を参照すると、Java
クライアントがCORBAサーバ内で実行されるEnterp
rise JavaBeanから、リモート・ビジネス・メソッドを
呼び出す分散アプリケーションを記述するJavaプロ
グラミング言語ステートメントの例が示される。図10
では、Javaプログラム内の標準のリモート・メソッ
ド呼び出し(RMI)技術の例が示される。CustomerIm
plクラスのリモート・オブジェクトは、インタフェー
ス"CustomerInterface"により表されるビジネス・メソ
ッドのセットを有し得る。CustomerInterface内に含ま
れるメソッドは、Javaクライアントから遠隔的に呼
び出され得る。この場合、クライアント・コードはステ
ートメント902乃至906に類似すると思われる。ス
テートメント902は、リモート・オブジェクトのオブ
ジェクト参照を獲得するための命名サービスの使用を示
す。オブジェクト"obj"は、CustomerInterfaceを実装す
るリモートJavaオブジェクトのRMIプロキシであ
る。ステートメント902でオブジェクト参照を獲得
後、ステートメント904で、オブジェクトを適切なオ
ブジェクト・タイプに固定することによりオブジェクト
が制限される。ステートメント906では、Javaク
ライアント・コードがプロキシ・オブジェクト上のビジ
ネス・メソッドをあたかもローカル・オブジェクトのよ
うに呼び出す。クライアントは、呼び出しがオブジェク
ト・リクエスト・ブローカ(ORB)を用いて実施され
ることを知らない。プロキシ・オブジェクトはCORB
A規格により定義されるように、メソッド呼び出しをリ
モート・オブジェクトに転送する。
【0066】本発明の方法によれば、リモート・オブジ
ェクトを実行するために、Java内のRMI振舞い
が、CORBA機構を用いてシミュレートされる。特殊
なNamingContext及びアダプタ・クラスのセットが、図
11乃至図13に示されるように実装される。特殊なNa
mingContextクラス内のルックアップ・メソッドが、図
11に示されるように実装される。ステートメント91
2は、特殊なルックアップ・メソッドの定義を示す。ス
テートメント914は、CORBA命名サービス内のル
ックアップ・メソッドがステートメント914内の所望
のリモート・オブジェクトに対応するCORBAプロキ
シを見いだすために使用されることを示す。一旦COR
BAプロキシが見いだされると、ステートメント916
が新たなアダプタ・クラスを作成する。ステートメント
918は、CORBAプロキシが適切なアダプタ・クラ
スによりラップされることを示す。ステートメント92
0は、ルックアップ・メソッドからの戻り値として、オ
ブジェクト参照の返却を示す。
【0067】図12は、図10に示されるRMIに類似
のシミュレート化RMIのためのクライアント・コード
の例を示す。ステートメント922は、リモート・オブ
ジェクトの名前によるリモート・オブジェクトのルック
アップすなわち探索を示し、図11に示されるコードに
より実装された新たなNamingContextクラスを使用す
る。一旦オブジェクト参照が返却されると、ステートメ
ント924がオブジェクト参照がCostomerInterfaceク
ラスを用いて制限されるか、固定されなければならない
ことを示す。ステートメント926は、クライアント・
コード内で呼び出される所望のビジネス・メソッドを示
す。しかしながら、CustomerInterfaceクラスの"cust"
インスタンス上で呼び出されるビジネス・メソッドは、
実際には、新たに定義されたNamingCotextクラスにより
返却されたアダプタ・オブジェクト上で呼び出される。
【0068】図13は、ビジネス・メソッドのためのア
ダプタ・クラス内のコードを示す。ステートメント93
0はbusinessMethodメソッドの定義の開始を示す。ステ
ートメント932は、アダプタ・コードが所望のメソッ
ド呼び出しをCORBAプロキシに委託することを示
す。この場合、プロキシはCORBAサーバ上のEJB
のスケルトンのための、CORBAプロキシのJava
クラス・インプリメンテーションである。
【0069】アダプタ・クラスは、CORBAサーバ上
のEJBによりサポートされるビジネス・インタフェー
スを実装しなければならない。アダプタ・クラスは本
来、CORBAプロキシがJavaクライアント・コー
ドから分離されるように、CORBAプロキシをラップ
する。重要な点は、JavaクライアントがCORBA
プロキシに関して何も知らないことである。Javaク
ライアントはJavaベースのアダプタ・コードにだけ
話しかけ、他方、CORBAサーバ上のスケルトン・コ
ードに話しかけるCORBAプロキシは、Javaベー
スのアダプタに関して何も知らない。
【0070】図11乃至図13に示される例では、リモ
ート・オブジェクトのビジネス・メソッドのための引き
数が、単にアダプタからプロキシ・オブジェクトに受け
渡される。引き数に対するデータ変換は示されない。ビ
ジネス・メソッドがEJBを引き数として受け取った
り、返却する場合、必要に応じて好適なアダプタによ
り、プロキシ・オブジェクトの適切なラップまたはラッ
プ解除を実行することが、そのビジネス・メソッドのア
ダプタ・コードの義務である。図示の例では、戻り値を
期待すること無く、ビジネス・メソッドがCustomerInte
rfaceクラスのために呼び出される。
【0071】ビジネス・メソッドが引き数として整数及
びEJBを受け取り、戻り値としてEJBを返却する例
では、EJBはラップ及びラップ解除されなければなら
ない。
【0072】図14乃至図16を参照すると、Java
プログラミング言語ステートメントの例が、Javaメ
ソッドへの引き数として使用されるEJBをラップ及び
ラップ解除するプロセスを示す。図14は、Javaビ
ジネス・メソッドの宣言の例であり、これは整数及びタ
イプ"Employee"のEJBを引き数として受け取り、タイ
プ"Customer"のEJBを戻り値として返却する。
【0073】図15は、リモートEJB内のビジネス・
メソッドに対するシミュレート化RMIの例を示す。図
11乃至図13に示されるリモートEJBの場合同様、
図15は前述のように、ビジネス・メソッドの引き数を
ラップ及びラップ解除する追加のステップを示す以外
は、プロキシをアダプタによりラップ及びラップ解除す
る本発明の方法を使用する。ステートメント1010
は"EmployeeName"の探索、及びオブジェクト"obj1"への
その割当てを示し、ステートメント1012は、オブジ
ェクト"obj1"から、タイプ"Employee"のオブジェクト"e
e"への制限を示す。ステートメント1014は"Custome
rName"の探索を示し、ステートメント1016は、Cust
omerクラス内のビジネス・メソッドの呼び出しを示し、
EJB引き数"ee"及び新たな顧客"newCust"の戻り値を
有する。
【0074】EmployeeのEJBを引き数として受け渡す
ことにより、ビジネス・メソッドがJavaクライアン
トによりアダプタ上で呼び出されるとき、"Employee"イ
ンタフェースを実現するのはアダプタ・オブジェクトで
あり、アダプタ・コードがアダプタを"Employee ee"か
らラップ解除し、その内部のCORBAプロキシをOR
Bを介して受け渡す。同様に、ORBを介して返却され
る結果の戻り値が実際、CustomerのEJBのCORBA
プロキシを含む。この場合、アダプタ・コードは返却さ
れたプロキシをクライアントに返送する前に、それを適
切なアダプタによりラップする。
【0075】図16は、CutomerAdapterクラス内のアダ
プタ・コードの例を示し、これはEJB引き数を必要に
応じてラップ及びラップ解除するためのステップを示す
以外は、図13に示される例と類似である。ステートメ
ント1020は、アダプタ・クラス内のビジネス・メソ
ッドの宣言を示し、整数"I"及び"Employee ee"を引き
数として受け取り、Customerを戻り値として返却する。
ステートメント1022は、引き数"ee"がタイプ"eeAda
pter"として書き直されることを示す。ステートメント
1024は、EmployeeAdapterからCORBAプロキシ
を獲得するために、"eeAdapter"がラップ解除されるこ
とを示す。ステートメント1026は、ビジネス・メソ
ッドが"eeProxy"を引き数として、プロキシ・オブジェ
クト上で呼び出されることを示す。なぜなら、CORB
Aプロキシ・オブジェクトだけがORBを介して受け渡
されるべきであるからである。ステートメント1028
は、適切なアダプタにより、返却されたプロキシ"custP
roxy"をラップし、"custAdapter"を獲得することを示
す。ステートメント1030は、"custAdapter"がビジ
ネス・メソッドの呼び出しからの戻り値として、呼び出
し側クライアント・オブジェクトに返却されることを示
す。このように、アダプタ・コードは、メソッド呼び出
しをCORBAプロキシに委託することに加え、必要に
応じてデータ変換を実行する。この場合、アダプタ・コ
ードは、ビジネス・メソッド内で引き数として渡される
EJBをラップ及びラップ解除する。更に、アダプタ
は、ORBインプリメンテーションによりサポートされ
ないデータ・タイプも実行する。
【0076】図17を参照すると、本発明の好適な方法
に従い、適切なアダプタによりEJB引き数をラップ及
びラップ解除するプロセスのフロー図が示される。プロ
セスは、クライアント・オブジェクトがビジネス・メソ
ッドを呼び出し、様々な引き数をビジネス・メソッドに
受け渡すとき開始する(ステップ1102)。この場
合、クライアントは、CORBAサーバ上のリモートE
JBのビジネス・メソッドのためのインタフェースを実
現する、アダプタ・クラス内のメソッドを呼び出す。ア
ダプタはビジネス・メソッドのために引き数のリストを
解析し(ステップ1104)、必要に応じて引き数に対
してデータ変換を実行する(ステップ1106)。引き
数がEJBを表すか否か、この場合、アダプタによりラ
ップされたEJBのためのCORBAプロキシを表すか
否かが判断される(ステップ1108)。肯定の場合、
アダプタ・コードがアダプタをEJB引き数からラップ
解除し、CORBAプロキシを獲得する(ステップ11
10)。
【0077】引き数がEJBでない場合、プロセスはこ
のメソッド呼び出しにおいて、処理されるべき追加の引
き数が存在するか否かを判断する(ステップ111
2)。存在する場合、プロセスはステップ1104に戻
り、次の引き数を獲得する。もはや引き数が存在しない
場合、アダプタはメソッド呼び出しをEJBを表すCO
RBAプロキシにORBを介して委託する(ステップ1
114)。
【0078】呼び出されたCORBAプロキシに対し
て、戻り値が存在するか否かが判断される(ステップ1
116)。存在しない場合、アダプタは実行を完了し、
制御フローをクライアント・コードに返却する(ステッ
プ1124)。戻り値が存在する場合、戻り値がEJB
プロキシか否かが判断される(ステップ1118)。そ
うでない場合、戻り値がクライアントへの結果値として
返却される(ステップ1122)。戻り値がEJBプロ
キシの場合、アダプタは結果をクライアントに返却する
前に、返却されたプロキシを適切なアダプタによりラッ
プする(ステップ1120)。プロセスは次に完了し、
クライアント・コードがその実行を継続する(ステップ
1124)。
【0079】本発明の利点は、図面に関する前述の詳細
な説明から明かであろう。Javaは、Javaクライ
アントがリモート・メソッド呼び出し(RMI)と呼ば
れる方法を使用して、別のプロセスで実行されるJav
aサーバ上のメソッドを呼び出す機構を提供する。しか
しながら、CORBA準拠のサーバなど、サーバがJa
va環境で実行されていない場合、Javaクライアン
トは、サーバ上のメソッドに対するメソッド呼び出しを
発行できない。なぜなら、JavaはCORBAオブジ
ェクトと通信する固有の機構を提供しないからである。
JavaクライアントとCORBAサーバ間で、データ
整備、すなわち異なるタイプのデータのためのデータ変
換を実行する標準的な機構は存在しない。これらの方法
は、他のサーバ上で実行される他のEJBに参照を受け
渡すステップを含む。Javaクライアントが、COR
BAサーバなどの非Java環境で実行されるEJBな
どの別のJavaアプリケーションと通信するための標
準的な機構は存在しない。
【0080】本発明は、CORBAサーバ内で実行され
るEnterprise JavaBean(EJB)のインタフェースを
内観することにより生成されるアダプタを使用する。こ
れらのアダプタはJavaクライアント側に存在し、そ
れらの内部にEJBを実行するCORBAサーバのリモ
ート・プロキシを保持する。アダプタは、ビジネス・メ
ソッドを呼び出すためにEJBにより指定されるインタ
フェースを実現するJavaクラスである。アダプタは
クライアントからの全てのビジネス・メソッド呼び出し
をサーバ上のCORBAプロキシに委託し、Javaク
ライアントからCORBAプロキシへの、及びその逆の
データ整備を実行する。
【0081】クライアント・オブジェクトの見地から、
アダプタは実際にCORBAサーバ上に存在するEJB
のレプリカである。クライアント・オブジェクトは、自
身がオブジェクト・リクエスト・ブローカ(ORB)を
介してCORBAサーバ上のEJBと通信することを意
識しない。アダプタはそれ自身内にEJBを実行するサ
ーバのCORBAプロキシを記憶する。クライアントに
よりアダプタに発せられるあらゆるビジネス・メソッド
呼び出しが適切なデータ変換の後に、アダプタによりC
ORBAプロキシに委託される。従って、アダプタは、
JavaクライアントとCORBAサーバ上のEJBと
の間の透過的な接着剤として作用する。
【0082】重要な点は、本発明は完全機能型のデータ
処理システムの状況において述べられてきたが、当業者
であれば、本発明のプロセスが命令のコンピュータ読取
り可能媒体の形態、及び様々な形態で配布され得、本発
明が配布を実施するために実際に使用される特定のタイ
プの信号担持媒体に関係無しに、同様に当てはまること
が理解できよう。コンピュータ読取り可能媒体の例に
は、フロッピー・ディスク、ハード・ディスク・ドライ
ブ、RAM、及びCD−ROMなどの記録型媒体と、デ
ジタル及びアナログ通信リンクなどの伝送型媒体とが含
まれる。
【0083】まとめとして、本発明の構成に関して以下
の事項を開示する。
【0084】(1)分散データ処理システム内の分散ア
プリケーションにおいて、サーバ・オブジェクトのメソ
ッドを呼び出すプロセスであって、前記サーバ・オブジ
ェクトと異なるプログラミング・パラダイムで実装され
るクライアント・オブジェクトを実行するステップと、
リモート・サーバ・オブジェクトのためのオブジェクト
参照を獲得するステップと、前記オブジェクト参照をア
ダプタ内でラップするステップと、前記アダプタのメソ
ッドを呼び出すステップとを含む、プロセス。 (2)前記アダプタが前記オブジェクト参照を使用し
て、前記サーバ上のスケルトンのメソッドを呼び出す、
前記(1)記載のプロセス。 (3)前記スケルトンが前記サーバ・オブジェクトのメ
ソッドを呼び出す、前記(1)記載のプロセス。 (4)分散データ処理システムにおいて分散アプリケー
ションを実装する方法であって、サーバ・オブジェクト
のプロキシためのオブジェクト参照を獲得するステップ
と、前記プロキシをアダプタ内でラップするステップ
と、前記アダプタのメソッドを呼び出すステップとを含
む、方法。 (5)前記アダプタが、前記サーバ・オブジェクトによ
りサポートされるインタフェースを実装するJavaク
ラスである、前記(4)記載の方法。 (6)前記サーバ・オブジェクトがEnterprise JavaBea
nである、前記(4)記載の方法。 (7)前記オブジェクト参照が命名サービスから獲得さ
れる、前記(4)記載の方法。 (8)前記プロキシがCORBAプロキシである、前記
(4)記載の方法。 (9)前記アダプタが前記CORBAプロキシのメソッ
ドを呼び出す、前記(8)記載の方法。 (10)前記CORBAプロキシがクライアント・コン
ピュータ上に存在するJavaクラスである、前記
(8)記載の方法。 (11)前記CORBAプロキシがメソッド要求をオブ
ジェクト・リクエスト・ブローカに受け渡す、前記
(8)記載の方法。 (12)分散データ処理システム内の分散アプリケーシ
ョンにおいて、サーバ・オブジェクトのメソッドを呼び
出すデータ処理システムであって、前記サーバ・オブジ
ェクトと異なるプログラミング・パラダイムで実装され
るクライアント・オブジェクトを実行する実行手段と、
リモート・サーバ・オブジェクトのためのオブジェクト
参照を獲得する獲得手段と、前記オブジェクト参照をア
ダプタ内でラップするラッピング手段と、前記アダプタ
のメソッドを呼び出す呼び出し手段とを含む、データ処
理システム。 (13)前記アダプタが前記オブジェクト参照を使用し
て、前記サーバ上のスケルトンのメソッドを呼び出す、
前記(12)記載のデータ処理システム。 (14)前記スケルトンが前記サーバ・オブジェクトの
メソッドを呼び出す、前記(12)記載のデータ処理シ
ステム。 (15)分散データ処理システムにおいて分散アプリケ
ーションを実装するデータ処理システムであって、サー
バ・オブジェクトのプロキシためのオブジェクト参照を
獲得する獲得手段と、前記プロキシをアダプタ内でラッ
プするラッピング手段と、前記アダプタのメソッドを呼
び出す呼び出し手段とを含む、データ処理システム。 (16)前記アダプタが、前記サーバ・オブジェクトに
よりサポートされるインタフェースを実装するJava
クラスである、前記(15)記載のデータ処理システ
ム。 (17)前記サーバ・オブジェクトがEnterprise JavaB
eanである、前記(15)記載のデータ処理システム。 (18)前記オブジェクト参照が命名サービスから獲得
される、前記(15)記載のデータ処理システム。 (19)前記プロキシがCORBAプロキシである、前
記(15)記載のデータ処理システム。 (20)前記アダプタが前記CORBAプロキシのメソ
ッドを呼び出す、前記(19)記載のデータ処理システ
ム。 (21)前記CORBAプロキシがクライアント・コン
ピュータ上に存在するJavaクラスである、前記(1
9)記載のデータ処理システム。 (22)前記CORBAプロキシがメソッド要求をオブ
ジェクト・リクエスト・ブローカに受け渡す、前記(1
9)記載のデータ処理システム。 (23)分散データ処理システム内の分散アプリケーシ
ョンにおいて、サーバ・オブジェクトのメソッドを呼び
出すためにデータ処理システム内で使用されるコンピュ
ータ・プログラムを記憶したコンピュータ読取り可能記
憶媒体であって、前記コンピュータ・プログラムは、前
記サーバ・オブジェクトと異なるプログラミング・パラ
ダイムで実装されるクライアント・オブジェクトを実行
する第1の命令と、リモート・サーバ・オブジェクトの
ためのオブジェクト参照を獲得する第2の命令と、前記
オブジェクト参照をアダプタ内でラップする第3の命令
と、前記アダプタのメソッドを呼び出す第4の命令とを
含む、記憶媒体。 (24)分散データ処理システムにおいて分散アプリケ
ーションを実装するために、データ処理システム内で使
用されるコンピュータ・プログラムを記憶したコンピュ
ータ読取り可能記憶媒体であって、前記コンピュータ・
プログラムは、サーバ・オブジェクトのプロキシのため
のオブジェクト参照を獲得する第1の命令と、前記プロ
キシをアダプタ内でラップする第2の命令と、前記アダ
プタのメソッドを呼び出す第3の命令とを含む、記憶媒
体。
【図面の簡単な説明】
【図1】本発明が実装される分散データ処理システムを
示す図である。
【図2】サーバとして実装され得るデータ処理システム
を示すブロック図である。
【図3】本発明が実装され得るデータ処理システムを示
すブロック図である。
【図4】従来の分散アプリケーションを示す図である。
【図5】CORBA規格を使用する従来の分散アプリケ
ーションを示す図である。
【図6】CORBAを用いて相互運用性機能を提供する
従来の分散アプリケーション内のコンポーネントを示す
図である。
【図7】CORBAサーバ内で実行されるEJBのリモ
ート・ビジネス・メソッドを呼び出す方法を実装するた
めに使用されるコンポーネントを示すブロック図であ
る。
【図8】サーバ・オブジェクトのリモート・メソッドを
呼び出す方法を実装するために使用されるコンポーネン
トを示すブロック図である。
【図9】CORBAサーバ内で実行されるEJB上のリ
モート・ビジネス・メソッドを呼び出す方法を示すフロ
ー図である。
【図10】JavaクライアントがCORBAサーバ内
で実行されるEJBからリモート・ビジネス・メソッド
を呼び出すための分散アプリケーションを記述する、J
avaプログラミング言語文の例を示す図である。
【図11】JavaクライアントがCORBAサーバ内
で実行されるEJBからリモート・ビジネス・メソッド
を呼び出すための分散アプリケーションを記述する、J
avaプログラミング言語文の例を示す図である。
【図12】JavaクライアントがCORBAサーバ内
で実行されるEJBからリモート・ビジネス・メソッド
を呼び出すための分散アプリケーションを記述する、J
avaプログラミング言語文の例を示す図である。
【図13】JavaクライアントがCORBAサーバ内
で実行されるEJBからリモート・ビジネス・メソッド
を呼び出すための分散アプリケーションを記述する、J
avaプログラミング言語文の例を示す図である。
【図14】Javaメソッドへの引き数として使用され
るEJBをラップ及びラップ解除するプロセスを記述す
るJavaプログラミング言語文の例を示す図である。
【図15】Javaメソッドへの引き数として使用され
るEJBをラップ及びラップ解除するプロセスを記述す
るJavaプログラミング言語文の例を示す図である。
【図16】Javaメソッドへの引き数として使用され
るEJBをラップ及びラップ解除するプロセスを記述す
るJavaプログラミング言語文の例を示す図である。
【図17】本発明の方法に従う好適なアダプタによる、
EJB引き数のラップ及びラップ解除のフロー図であ
る。
【符号の説明】
100、200、300 分散データ処理システム 102 ネットワーク 104、200、614、726、772 サーバ 106 記憶ユニット 108、110、112、602、700、750 ク
ライアント 202、204、302 プロセッサ 206 システム・バス 208 メモリ制御装置/キャッシュ 209 ローカル・メモリ 210 I/Oバス・ブリッジ 212 I/Oバス 214 周辺コンポーネント相互接続(PCI)バス・
ブリッジ 216、306 PCIローカル・バス 218、322 モデム 220 ネットワーク・アダプタ 222、224 PCIバス・ブリッジ 226、228 PCIバス 230 メモリマップド・グラフィックス・アダプタ 232 ハード・ディスク 304 主メモリ 308 PCIブリッジ 310 ローカル・エリア・ネットワーク(LAN)・
アダプタ 312 SCSIホスト・バス・アダプタ 314 拡張バス・インタフェース 316 音声アダプタ 318 グラフィックス・アダプタ 319 スマートカード・アダプタ 320 キーボード及びマウス・アダプタ 324 メモリ 326 ハード・ディスク・ドライブ 328 テープ・ドライブ 330 CD−ROMドライブ 400、500、752 クライアント・オブジェクト 402、770 サーバ・オブジェクト 404 データベース 406 Javaリモート・メソッド呼び出し(RM
I)プロトコル 408 レガシ・アプリケーション 410 現企業アプリケーション 510 通信リンク 520 CORBAサーバ 521 JavaBean 522 C++オブジェクト 523 Enterprise JavaBean(EJB) 524 COBOLオブジェクト 606、610 オブジェクト・リクエスト・ブローカ 612 スケルトン・コード 616 オブジェクト参照 618 メソッド要求 620 サーバント 702 Java仮想マシンJVM 704 Javaクライアント・オブジェクト 706 アダプタ 708 EJBインタフェース 710 CORBAプロキシ 714、718 オブジェクト・リクエスト・ブローカ
ORB 716 IIOP 720 EJBスケルトン 722 JNI 724 JVM 728 リモートEJB 756 オブジェクト参照 758 データ整備モジュール 760、764 オブジェクト・ディスパッチャ 762 オブジェクト通信リンク 766 データ整備モジュール 768 リモート呼び出しスケルトン

Claims (24)

    【特許請求の範囲】
  1. 【請求項1】分散データ処理システム内の分散アプリケ
    ーションにおいて、サーバ・オブジェクトのメソッドを
    呼び出すプロセスであって、 前記サーバ・オブジェクトと異なるプログラミング・パ
    ラダイムで実装されるクライアント・オブジェクトを実
    行するステップと、 リモート・サーバ・オブジェクトのためのオブジェクト
    参照を獲得するステップと、 前記オブジェクト参照をアダプタ内でラップするステッ
    プと、 前記アダプタのメソッドを呼び出すステップとを含む、
    プロセス。
  2. 【請求項2】前記アダプタが前記オブジェクト参照を使
    用して、前記サーバ上のスケルトンのメソッドを呼び出
    す、請求項1記載のプロセス。
  3. 【請求項3】前記スケルトンが前記サーバ・オブジェク
    トのメソッドを呼び出す、請求項1記載のプロセス。
  4. 【請求項4】分散データ処理システムにおいて分散アプ
    リケーションを実装する方法であって、 サーバ・オブジェクトのプロキシためのオブジェクト参
    照を獲得するステップと、 前記プロキシをアダプタ内でラップするステップと、 前記アダプタのメソッドを呼び出すステップとを含む、
    方法。
  5. 【請求項5】前記アダプタが、前記サーバ・オブジェク
    トによりサポートされるインタフェースを実装するJa
    vaクラスである、請求項4記載の方法。
  6. 【請求項6】前記サーバ・オブジェクトがEnterprise J
    avaBeanである、請求項4記載の方法。
  7. 【請求項7】前記オブジェクト参照が命名サービスから
    獲得される、請求項4記載の方法。
  8. 【請求項8】前記プロキシがCORBAプロキシであ
    る、請求項4記載の方法。
  9. 【請求項9】前記アダプタが前記CORBAプロキシの
    メソッドを呼び出す、請求項8記載の方法。
  10. 【請求項10】前記CORBAプロキシがクライアント
    ・コンピュータ上に存在するJavaクラスである、請
    求項8記載の方法。
  11. 【請求項11】前記CORBAプロキシがメソッド要求
    をオブジェクト・リクエスト・ブローカに受け渡す、請
    求項8記載の方法。
  12. 【請求項12】分散データ処理システム内の分散アプリ
    ケーションにおいて、サーバ・オブジェクトのメソッド
    を呼び出すデータ処理システムであって、 前記サーバ・オブジェクトと異なるプログラミング・パ
    ラダイムで実装されるクライアント・オブジェクトを実
    行する実行手段と、 リモート・サーバ・オブジェクトのためのオブジェクト
    参照を獲得する獲得手段と、 前記オブジェクト参照をアダプタ内でラップするラッピ
    ング手段と、 前記アダプタのメソッドを呼び出す呼び出し手段とを含
    む、データ処理システム。
  13. 【請求項13】前記アダプタが前記オブジェクト参照を
    使用して、前記サーバ上のスケルトンのメソッドを呼び
    出す、請求項12記載のデータ処理システム。
  14. 【請求項14】前記スケルトンが前記サーバ・オブジェ
    クトのメソッドを呼び出す、請求項12記載のデータ処
    理システム。
  15. 【請求項15】分散データ処理システムにおいて分散ア
    プリケーションを実装するデータ処理システムであっ
    て、 サーバ・オブジェクトのプロキシためのオブジェクト参
    照を獲得する獲得手段と、 前記プロキシをアダプタ内でラップするラッピング手段
    と、 前記アダプタのメソッドを呼び出す呼び出し手段とを含
    む、データ処理システム。
  16. 【請求項16】前記アダプタが、前記サーバ・オブジェ
    クトによりサポートされるインタフェースを実装するJ
    avaクラスである、請求項15記載のデータ処理シス
    テム。
  17. 【請求項17】前記サーバ・オブジェクトがEnterprise
    JavaBeanである、請求項15記載のデータ処理システ
    ム。
  18. 【請求項18】前記オブジェクト参照が命名サービスか
    ら獲得される、請求項15記載のデータ処理システム。
  19. 【請求項19】前記プロキシがCORBAプロキシであ
    る、請求項15記載のデータ処理システム。
  20. 【請求項20】前記アダプタが前記CORBAプロキシ
    のメソッドを呼び出す、請求項19記載のデータ処理シ
    ステム。
  21. 【請求項21】前記CORBAプロキシがクライアント
    ・コンピュータ上に存在するJavaクラスである、請
    求項19記載のデータ処理システム。
  22. 【請求項22】前記CORBAプロキシがメソッド要求
    をオブジェクト・リクエスト・ブローカに受け渡す、請
    求項19記載のデータ処理システム。
  23. 【請求項23】分散データ処理システム内の分散アプリ
    ケーションにおいて、サーバ・オブジェクトのメソッド
    を呼び出すためにデータ処理システム内で使用されるコ
    ンピュータ・プログラムを記憶したコンピュータ読取り
    可能記憶媒体であって、前記コンピュータ・プログラム
    は、 前記サーバ・オブジェクトと異なるプログラミング・パ
    ラダイムで実装されるクライアント・オブジェクトを実
    行する第1の命令と、 リモート・サーバ・オブジェクトのためのオブジェクト
    参照を獲得する第2の命令と、 前記オブジェクト参照をアダプタ内でラップする第3の
    命令と、 前記アダプタのメソッドを呼び出す第4の命令とを含
    む、記憶媒体。
  24. 【請求項24】分散データ処理システムにおいて分散ア
    プリケーションを実装するために、データ処理システム
    内で使用されるコンピュータ・プログラムを記憶したコ
    ンピュータ読取り可能記憶媒体であって、前記コンピュ
    ータ・プログラムは、 サーバ・オブジェクトのプロキシのためのオブジェクト
    参照を獲得する第1の命令と、 前記プロキシをアダプタ内でラップする第2の命令と、 前記アダプタのメソッドを呼び出す第3の命令とを含
    む、記憶媒体。
JP2000045445A 1999-02-26 2000-02-23 サーバ・オブジェクトのメソッドを呼び出すプロセス方法及びデータ処理システム Expired - Fee Related JP4146983B2 (ja)

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
US25914199A 1999-02-26 1999-02-26
US09/259141 1999-02-26

Publications (2)

Publication Number Publication Date
JP2000250768A true JP2000250768A (ja) 2000-09-14
JP4146983B2 JP4146983B2 (ja) 2008-09-10

Family

ID=22983699

Family Applications (1)

Application Number Title Priority Date Filing Date
JP2000045445A Expired - Fee Related JP4146983B2 (ja) 1999-02-26 2000-02-23 サーバ・オブジェクトのメソッドを呼び出すプロセス方法及びデータ処理システム

Country Status (2)

Country Link
US (1) US6959307B2 (ja)
JP (1) JP4146983B2 (ja)

Cited By (9)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
WO2002054263A1 (fr) * 2000-12-28 2002-07-11 Future System Consulting Corp. Systeme de structure
KR100426311B1 (ko) * 2001-12-28 2004-04-08 한국전자통신연구원 Ejb 컴포넌트 조립 장치 및 방법
US6813669B1 (en) 2000-02-24 2004-11-02 International Business Machines Corporation Agent provided by USB device for executing USB device dependent program in USB host
KR100490750B1 (ko) * 2001-12-27 2005-05-24 한국전자통신연구원 Ejb 영속 상태 객체로 표현된 데이터베이스 엔터티들의자동화된 상호관계 관리 방법
JP2009037627A (ja) * 2008-09-05 2009-02-19 Canon Inc 画像形成装置、画像形成装置の制御方法、及び、制御プログラム
WO2009072809A2 (en) * 2007-12-05 2009-06-11 An-Mo Jeong A method for decoupling service components from application-specific business entities
US7617504B1 (en) * 2002-09-12 2009-11-10 Sprint Communications Company L.P. Computer method and system for integrating enterprise JavaBeans into non-Java environments
US8140679B2 (en) 2001-02-12 2012-03-20 International Business Machines Corporation Method and system for automated session resource clean-up in a distributed client-server environment
CN112035276A (zh) * 2020-08-06 2020-12-04 上海视云网络科技有限公司 一种基于java的跨平台可扩展的RPC框架设计方法

Families Citing this family (101)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US7283991B1 (en) * 1999-03-11 2007-10-16 Microsoft Corporation Caching system for path search optimization
US7051071B2 (en) 2000-02-16 2006-05-23 Bea Systems, Inc. Workflow integration system for enterprise wide electronic collaboration
US7181745B1 (en) * 2000-03-03 2007-02-20 The Mathworks, Inc. Method and system for accessing objects defined within an external object-oriented environment
US7478403B1 (en) * 2000-04-21 2009-01-13 Sun Microsystems, Inc. Secure access to managed network objects using a configurable platform-independent gateway providing individual object-level access control
FI20001617A (fi) * 2000-07-06 2002-01-07 Nokia Mobile Phones Ltd Tiedonsiirtomenetelmõ ja -jõrjestely
US7111077B1 (en) * 2000-12-22 2006-09-19 Unisys Corporation Method and apparatus for passing service requests and data from web based workstations directly to online transaction processing (OLTP) server systems
US7080092B2 (en) 2001-10-18 2006-07-18 Bea Systems, Inc. Application view component for system integration
US7562339B2 (en) * 2002-01-15 2009-07-14 Bea Systems, Inc. System architecture for business process development and execution with introspection and generic components
US20030158919A1 (en) * 2002-02-20 2003-08-21 Sun Microsystems, Inc., A Delaware Corporation Method for deploying version control system server software having remote access capability
US7516447B2 (en) 2002-02-22 2009-04-07 Bea Systems, Inc. Methods and apparatus for building, customizing and using software abstractions of external entities
US7421153B1 (en) * 2002-04-05 2008-09-02 Bank Of America Corporation Image and data processing system
US7424717B2 (en) * 2002-05-01 2008-09-09 Bea Systems, Inc. Systems and methods for business process plug-in development
US7257645B2 (en) 2002-05-01 2007-08-14 Bea Systems, Inc. System and method for storing large messages
US8135772B2 (en) 2002-05-01 2012-03-13 Oracle International Corporation Single servlets for B2B message routing
US7350184B2 (en) 2002-05-02 2008-03-25 Bea Systems, Inc. System and method for enterprise application interactions
US7165249B2 (en) * 2002-05-02 2007-01-16 Bea Systems, Inc. Systems and methods for modular component deployment
US7484224B2 (en) * 2002-05-02 2009-01-27 Bae Systems, Inc. Adapter deployment without recycle
US7676538B2 (en) * 2002-05-02 2010-03-09 Bea Systems, Inc. Systems and methods for application view transactions
US7627631B2 (en) 2002-05-02 2009-12-01 Bea Systems, Inc. Systems and methods for collaborative business plug-ins
US6988099B2 (en) 2002-06-27 2006-01-17 Bea Systems, Inc. Systems and methods for maintaining transactional persistence
US7574714B2 (en) * 2002-08-23 2009-08-11 At&T Intellectual Property I, L.P. System and method for providing interoperability between different programming protocols
US7114148B2 (en) * 2002-09-30 2006-09-26 Microsoft Corporation Runtime services for network software platform
US20040128644A1 (en) * 2002-10-25 2004-07-01 Walter Hurst Software architecture for distributed enterprise business applications
EP1420340A1 (en) * 2002-11-15 2004-05-19 Hewlett-Packard Company Remote object invocation system and method
US7752599B2 (en) * 2003-02-25 2010-07-06 Bea Systems Inc. Systems and methods extending an existing programming language with constructs
US7774697B2 (en) * 2003-02-25 2010-08-10 Bea Systems, Inc. System and method for structuring distributed applications
US7293038B2 (en) 2003-02-25 2007-11-06 Bea Systems, Inc. Systems and methods for client-side filtering of subscribed messages
US8032860B2 (en) 2003-02-26 2011-10-04 Oracle International Corporation Methods for type-independent source code editing
US7707564B2 (en) * 2003-02-26 2010-04-27 Bea Systems, Inc. Systems and methods for creating network-based software services using source code annotations
US7076772B2 (en) 2003-02-26 2006-07-11 Bea Systems, Inc. System and method for multi-language extensible compiler framework
US7539985B2 (en) 2003-02-26 2009-05-26 Bea Systems, Inc. Systems and methods for dynamic component versioning
US7299454B2 (en) 2003-02-26 2007-11-20 Bea Systems, Inc. Method for multi-language debugging
US7650276B2 (en) 2003-02-26 2010-01-19 Bea Systems, Inc. System and method for dynamic data binding in distributed applications
US20040226030A1 (en) * 2003-02-28 2004-11-11 Kyle Marvin Systems and methods for an extensible software proxy
US7636722B2 (en) 2003-02-28 2009-12-22 Bea Systems, Inc. System and method for describing application extensions in XML
US7650592B2 (en) * 2003-03-01 2010-01-19 Bea Systems, Inc. Systems and methods for multi-view debugging environment
US7281252B1 (en) * 2003-03-12 2007-10-09 Microsoft Corporation Method, system, and apparatus for implementing object interfaces at runtime
US7480921B1 (en) 2003-03-12 2009-01-20 Microsoft Corporation Method, system, and apparatus for customizing web parts
US7562353B2 (en) * 2003-05-16 2009-07-14 Hewlett-Packard Development Company, L.P. Methods and systems for transforming Java applications of behalf of another device
US7424721B2 (en) * 2003-05-19 2008-09-09 Sun Microsystems, Inc. Inter-object communication interface bridge
US8495202B2 (en) * 2003-10-24 2013-07-23 Brother Kogyo Kabushiki Kaisha Imaging device information management system
GB0406162D0 (en) * 2004-03-19 2004-04-21 Ibm Method and system for providing real world contexts to computer applications
US7386865B2 (en) * 2004-06-24 2008-06-10 Sap Ag System and method for processing remote function calls
GB0416259D0 (en) * 2004-07-21 2004-08-25 Ibm A method and system for enabling a server application to be executed in the same virtual machine as a client application using direct object oriented
US7512953B1 (en) * 2004-08-31 2009-03-31 Sap Ag System and method for smart proxy creation and management within a distributed object-oriented architecture
US7823169B1 (en) * 2004-10-28 2010-10-26 Wheeler Thomas T Performing operations by a first functionality within a second functionality in a same or in a different programming language
US7774789B1 (en) 2004-10-28 2010-08-10 Wheeler Thomas T Creating a proxy object and providing information related to a proxy object
US8266631B1 (en) 2004-10-28 2012-09-11 Curen Software Enterprises, L.L.C. Calling a second functionality by a first functionality
US20060106864A1 (en) * 2004-11-12 2006-05-18 International Business Machines Corporation System, computer program product and method of narrowing an enterprise Java bean (EJB) object reference to a home implementation class name
WO2010049742A1 (en) * 2004-12-01 2010-05-06 Computer Associates Think, Inc. Managing elements residing on legacy systems
US7861212B1 (en) 2005-03-22 2010-12-28 Dubagunta Saikumar V System, method, and computer readable medium for integrating an original application with a remote application
US7797688B1 (en) 2005-03-22 2010-09-14 Dubagunta Saikumar V Integrating applications in multiple languages
US8578349B1 (en) 2005-03-23 2013-11-05 Curen Software Enterprises, L.L.C. System, method, and computer readable medium for integrating an original language application with a target language application
DE602006012472D1 (de) * 2005-04-15 2010-04-08 Esprida Corp Vorrichtung und methode zur verwaltung von einem aus intelligenten geräten bestehenden netzwerk
US7673285B1 (en) * 2005-06-24 2010-03-02 Emc Corporation System and methods for generating a software component interface
US20070078927A1 (en) * 2005-09-12 2007-04-05 Microsoft Corporation Server-side service framework
US7882489B2 (en) * 2005-11-22 2011-02-01 International Business Machines Corporation Integrated code generation for adapter-specific property template
US20070130133A1 (en) * 2005-12-02 2007-06-07 Oracle International Corporation Incorporating network constraints into a network data model for a relational database management system
US8438186B2 (en) * 2005-12-02 2013-05-07 Oracle International Corporation Method and apparatus for creating topological features inside a database system
US8161501B2 (en) * 2006-01-09 2012-04-17 Red Hat, Inc. Apparatus, method and computer program product for facilitating the interoperability of virtual machines
US7921409B2 (en) * 2006-02-28 2011-04-05 Microsoft Corporation Managed add-in framework proxy generation
US10289728B2 (en) 2006-05-15 2019-05-14 Avaya Inc. Garbage collection of persistent objects with dynamic multikeys
US10185579B2 (en) 2006-05-15 2019-01-22 Avaya Inc. Dynamic multikeys for persistent objects
US10324735B2 (en) * 2006-05-15 2019-06-18 Avaya Inc. Method invocation for persistent objects with dynamic multikeys
US7810140B1 (en) 2006-05-23 2010-10-05 Lipari Paul A System, method, and computer readable medium for processing a message in a transport
US7844759B1 (en) 2006-07-28 2010-11-30 Cowin Gregory L System, method, and computer readable medium for processing a message queue
US8250178B2 (en) * 2006-09-15 2012-08-21 Emc Corporation Protecting client-side code
US20080072069A1 (en) * 2006-09-15 2008-03-20 Emc Corporation Protecting client-side code
GB0624168D0 (en) * 2006-12-04 2007-01-10 Axiom Systems Ltd Service assembly and delivery
US8423496B1 (en) 2006-12-22 2013-04-16 Curen Software Enterprises, L.L.C. Dynamic determination of needed agent rules
US7660780B1 (en) 2006-12-22 2010-02-09 Patoskie John P Moving an agent from a first execution environment to a second execution environment
US9311141B2 (en) 2006-12-22 2016-04-12 Callahan Cellular L.L.C. Survival rule usage by software agents
US7698243B1 (en) 2006-12-22 2010-04-13 Hauser Robert R Constructing an agent in a first execution environment using canonical rules
US8200603B1 (en) 2006-12-22 2012-06-12 Curen Software Enterprises, L.L.C. Construction of an agent that utilizes as-needed canonical rules
US7702602B1 (en) 2006-12-22 2010-04-20 Hauser Robert R Moving and agent with a canonical rule from one device to a second device
US7949626B1 (en) 2006-12-22 2011-05-24 Curen Software Enterprises, L.L.C. Movement of an agent that utilizes a compiled set of canonical rules
US7664721B1 (en) 2006-12-22 2010-02-16 Hauser Robert R Moving an agent from a first execution environment to a second execution environment using supplied and resident rules
US7702604B1 (en) 2006-12-22 2010-04-20 Hauser Robert R Constructing an agent that utilizes supplied rules and rules resident in an execution environment
US7860517B1 (en) 2006-12-22 2010-12-28 Patoskie John P Mobile device tracking using mobile agent location breadcrumbs
US8132179B1 (en) 2006-12-22 2012-03-06 Curen Software Enterprises, L.L.C. Web service interface for mobile agents
US7702603B1 (en) 2006-12-22 2010-04-20 Hauser Robert R Constructing an agent that utilizes a compiled set of canonical rules
US7660777B1 (en) 2006-12-22 2010-02-09 Hauser Robert R Using data narrowing rule for data packaging requirement of an agent
US7970724B1 (en) 2006-12-22 2011-06-28 Curen Software Enterprises, L.L.C. Execution of a canonical rules based agent
US20080201481A1 (en) * 2007-02-20 2008-08-21 Microsoft Corporation Remote interface marshalling
US8996394B2 (en) * 2007-05-18 2015-03-31 Oracle International Corporation System and method for enabling decision activities in a process management and design environment
US8185916B2 (en) * 2007-06-28 2012-05-22 Oracle International Corporation System and method for integrating a business process management system with an enterprise service bus
US8949423B2 (en) * 2007-09-28 2015-02-03 International Business Machines Corporation Autonomically co-locating first and second components on a select server
US8904002B2 (en) * 2007-09-28 2014-12-02 International Business Machines Corporation Reducing overhead in component interactions
US8849897B2 (en) * 2007-11-15 2014-09-30 Microsoft Corporation Delegating application invocation back to client
SE533007C2 (sv) 2008-10-24 2010-06-08 Ilt Productions Ab Distribuerad datalagring
EP2387200B1 (en) 2010-04-23 2014-02-12 Compuverde AB Distributed data storage
US8997124B2 (en) 2011-09-02 2015-03-31 Compuverde Ab Method for updating data in a distributed data storage system
US8769138B2 (en) 2011-09-02 2014-07-01 Compuverde Ab Method for data retrieval from a distributed data storage system
US9021053B2 (en) 2011-09-02 2015-04-28 Compuverde Ab Method and device for writing data to a data storage system comprising a plurality of data storage nodes
US8645978B2 (en) 2011-09-02 2014-02-04 Compuverde Ab Method for data maintenance
US9626378B2 (en) 2011-09-02 2017-04-18 Compuverde Ab Method for handling requests in a storage system and a storage node for a storage system
US8650365B2 (en) 2011-09-02 2014-02-11 Compuverde Ab Method and device for maintaining data in a data storage system comprising a plurality of data storage nodes
US8863129B2 (en) 2011-12-06 2014-10-14 International Business Machines Corporation Automated caching and mirroring of immutable data in distributed virtual machines via native interface components
US20150040102A1 (en) * 2013-07-31 2015-02-05 Fp Complete System and method for software interoperability
US20170228269A1 (en) * 2014-10-31 2017-08-10 Hewlett-Packard Development Company, L.P. Proxies for native code access
CN112311567B (zh) * 2019-07-26 2022-04-05 华为技术有限公司 一种通信方法及装置

Family Cites Families (8)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
DE69327448T2 (de) 1992-12-21 2004-03-04 Sun Microsystems, Inc., Mountain View Verfahren und Vorrichtung für Teilaufgaben in verteiltem Verarbeitungssystem
US5778228A (en) 1994-08-16 1998-07-07 International Business Machines Corporation Method and system for transferring remote procedure calls and responses over a network
US6374308B1 (en) 1996-04-23 2002-04-16 Sun Microsystems, Inc. Method and apparatus for interactively connecting distributed objects to a graphic user interface
US5991823A (en) 1996-06-26 1999-11-23 Sun Microsystems, Inc. Low overhead object adaptor
US6282580B1 (en) * 1996-07-02 2001-08-28 Sun Microsystems, Inc. Bridge providing communication between different implementations of object request brokers
US6125383A (en) 1997-06-11 2000-09-26 Netgenics Corp. Research system using multi-platform object oriented program language for providing objects at runtime for creating and manipulating biological or chemical data
US6637020B1 (en) * 1998-12-03 2003-10-21 International Business Machines Corporation Creating applications within data processing systems by combining program components dynamically
US6269373B1 (en) * 1999-02-26 2001-07-31 International Business Machines Corporation Method and system for persisting beans as container-managed fields

Cited By (12)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6813669B1 (en) 2000-02-24 2004-11-02 International Business Machines Corporation Agent provided by USB device for executing USB device dependent program in USB host
WO2002054263A1 (fr) * 2000-12-28 2002-07-11 Future System Consulting Corp. Systeme de structure
US7177899B2 (en) 2000-12-28 2007-02-13 Future System Consulting Corp. Framework system
US7366751B2 (en) 2000-12-28 2008-04-29 Future Architect, Inc. Framework system
US8140679B2 (en) 2001-02-12 2012-03-20 International Business Machines Corporation Method and system for automated session resource clean-up in a distributed client-server environment
KR100490750B1 (ko) * 2001-12-27 2005-05-24 한국전자통신연구원 Ejb 영속 상태 객체로 표현된 데이터베이스 엔터티들의자동화된 상호관계 관리 방법
KR100426311B1 (ko) * 2001-12-28 2004-04-08 한국전자통신연구원 Ejb 컴포넌트 조립 장치 및 방법
US7617504B1 (en) * 2002-09-12 2009-11-10 Sprint Communications Company L.P. Computer method and system for integrating enterprise JavaBeans into non-Java environments
WO2009072809A2 (en) * 2007-12-05 2009-06-11 An-Mo Jeong A method for decoupling service components from application-specific business entities
WO2009072809A3 (en) * 2007-12-05 2009-09-17 An-Mo Jeong A method for decoupling service components from application-specific business entities
JP2009037627A (ja) * 2008-09-05 2009-02-19 Canon Inc 画像形成装置、画像形成装置の制御方法、及び、制御プログラム
CN112035276A (zh) * 2020-08-06 2020-12-04 上海视云网络科技有限公司 一种基于java的跨平台可扩展的RPC框架设计方法

Also Published As

Publication number Publication date
US20040111730A1 (en) 2004-06-10
US6959307B2 (en) 2005-10-25
JP4146983B2 (ja) 2008-09-10

Similar Documents

Publication Publication Date Title
JP4146983B2 (ja) サーバ・オブジェクトのメソッドを呼び出すプロセス方法及びデータ処理システム
US6269373B1 (en) Method and system for persisting beans as container-managed fields
US6263498B1 (en) Method and apparatus for enabling server side distributed object modification
JP2978807B2 (ja) 遠隔プロシージャ・コール・システムおよび方法
AU691031B2 (en) System and method for providing interoperability among heterogeneous object systems
US7533388B1 (en) Method and apparatus for dynamic Stubs and Ties in RMI-IIOP
US20030182457A1 (en) Method and apparatus for generating a code bridge
Troelsen C# and the. NET Platform
US20080178151A1 (en) Method and Apparatus to Implement Adaptive Scripting Tool
Oberleitner et al. The Vienna Component Framework enabling composition across component models
Aleksy et al. Implementing distributed systems with Java and CORBA
Albahari et al. C# Essentials: Programming the. NET Framework
Troelsen Pro C# 2005 and the. NET 2.0 Platform
Chiang Wrapping legacy systems for use in heterogeneous computing environments
Vogel C++ Programming with CORBA
US7596572B1 (en) Methods and apparatus for providing a categorical approach to valuetype bridge support
US7788677B1 (en) Methods and apparatus providing a categorical approach to strongly typed component management
Van Heiningen et al. Exploiting dynamic proxies in middleware for distributed, parallel, and mobile Java applications
Mykkänen et al. Component and Service Technology Families
Fraser Pro Visual C++/CLI and the. NET 3.5 platform
Zhang A comparative study of DCOM/CORBA and. NET/J2EE
Cerqueira et al. Binding an interpreted language to CORBA
Sells et al. ATL internals: working with ATL 8
Akbay et al. Design and implementation of an enterprise information system utilizing a component based three-tier client/server database system
Toulemonde et al. Connecting Domino to the Enterprise Using Java

Legal Events

Date Code Title Description
A131 Notification of reasons for refusal

Free format text: JAPANESE INTERMEDIATE CODE: A131

Effective date: 20040106

A601 Written request for extension of time

Free format text: JAPANESE INTERMEDIATE CODE: A601

Effective date: 20040405

A602 Written permission of extension of time

Free format text: JAPANESE INTERMEDIATE CODE: A602

Effective date: 20040408

A521 Request for written amendment filed

Free format text: JAPANESE INTERMEDIATE CODE: A523

Effective date: 20040701

Free format text: JAPANESE INTERMEDIATE CODE: A821

Effective date: 20040701

RD12 Notification of acceptance of power of sub attorney

Free format text: JAPANESE INTERMEDIATE CODE: A7432

Effective date: 20040701

A521 Request for written amendment filed

Free format text: JAPANESE INTERMEDIATE CODE: A821

Effective date: 20040702

A02 Decision of refusal

Free format text: JAPANESE INTERMEDIATE CODE: A02

Effective date: 20050418

A521 Request for written amendment filed

Free format text: JAPANESE INTERMEDIATE CODE: A523

Effective date: 20050711

Free format text: JAPANESE INTERMEDIATE CODE: A821

Effective date: 20050711

A911 Transfer to examiner for re-examination before appeal (zenchi)

Free format text: JAPANESE INTERMEDIATE CODE: A911

Effective date: 20050905

A912 Re-examination (zenchi) completed and case transferred to appeal board

Free format text: JAPANESE INTERMEDIATE CODE: A912

Effective date: 20060407

A521 Request for written amendment filed

Free format text: JAPANESE INTERMEDIATE CODE: A821

Effective date: 20071121

RD12 Notification of acceptance of power of sub attorney

Free format text: JAPANESE INTERMEDIATE CODE: A7432

Effective date: 20080422

A521 Request for written amendment filed

Free format text: JAPANESE INTERMEDIATE CODE: A821

Effective date: 20080425

Free format text: JAPANESE INTERMEDIATE CODE: A523

Effective date: 20080425

A521 Request for written amendment filed

Free format text: JAPANESE INTERMEDIATE CODE: A821

Effective date: 20080423

A521 Request for written amendment filed

Free format text: JAPANESE INTERMEDIATE CODE: A821

Effective date: 20080616

RD14 Notification of resignation of power of sub attorney

Free format text: JAPANESE INTERMEDIATE CODE: A7434

Effective date: 20080616

A01 Written decision to grant a patent or to grant a registration (utility model)

Free format text: JAPANESE INTERMEDIATE CODE: A01

A61 First payment of annual fees (during grant procedure)

Free format text: JAPANESE INTERMEDIATE CODE: A61

Effective date: 20080623

R150 Certificate of patent or registration of utility model

Free format text: JAPANESE INTERMEDIATE CODE: R150

FPAY Renewal fee payment (event date is renewal date of database)

Free format text: PAYMENT UNTIL: 20110627

Year of fee payment: 3

LAPS Cancellation because of no payment of annual fees