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

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

Info

Publication number
JP4146983B2
JP4146983B2 JP2000045445A JP2000045445A JP4146983B2 JP 4146983 B2 JP4146983 B2 JP 4146983B2 JP 2000045445 A JP2000045445 A JP 2000045445A JP 2000045445 A JP2000045445 A JP 2000045445A JP 4146983 B2 JP4146983 B2 JP 4146983B2
Authority
JP
Japan
Prior art keywords
client
adapter
server
proxy
argument
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.)
Expired - Fee Related
Application number
JP2000045445A
Other languages
English (en)
Other versions
JP2000250768A (ja
Inventor
アジャ・エイ・アプト
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

Images

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

Description

【0001】
【発明の属する技術分野】
本発明は一般に、改善された分散データ処理システムに関し、特に、分散データ処理システム内のクライアント及びサーバ上にオブジェクトを含む、分散アプリケーションのための方法及び装置に関する。
【0002】
【関連技術】
本発明は、本願と同時に出願された米国特許出願"Method and System for Persisting Beans as Container-Managed Fields"(出願人整理番号:AT998907)に関連する。
【0003】
【従来の技術】
ソフトウェア開発者は、企業全体に及ぶアプリケーションの作成が困難であり、分散アプリケーションの作成が更に困難である根本的な問題に直面している。更に、企業は1つのプラットフォームに閉ざされること無く、できる限り速くアプリケーションを作成することを願望する。理想的には、企業開発者は一旦アプリケーションを作成したら、それを彼らの全てのプラットフォーム上で実行することを希望する。Enterprise JavaBeans(商標)技術は、この能力を提供しようとする。
【0004】
Enterprise JavaBeans(EJB)コンポーネント・アーキテクチャは、企業がスケーラブルで安全なマルチプラットフォーム業務用アプリケーションを、再利用可能なサーバ側コンポーネントとして作成することを可能にするように設計される。その目的は、企業開発者が業務論理(またはビジネス論理)の作成だけに注力できるようにすることにより企業問題を解決することである。
【0005】
サーバ側環境、及びそれをサービスするために必要とされるツールは、EJB技術のための設計目標に多大に影響する。1つの主要な設計目的は、分散アプリケーションを作成するプロセスをできる限り低減することである。この目的は、Enterprise JavaBeansの単純な宣言属性に、通常、手作業でコーディングされる必要のあるフィーチャを転換することにより達成された。これらの宣言属性は、開発効率の多大な向上をもたらす。なぜなら、セキュリティ及びトランザクションなどの特定の振舞いがコード内にセットされるのではなく、ビーン自身上の"フラグ"であるからである。
【0006】
EJB仕様は、トランザクション、セキュリティ、スレッディング、名前付け、オブジェクト・ライフサイクル、資源プーリング、リモート・アクセス、及び持続性などのシステム・レベルのプログラミングを世話するインフラストラクチャを作成する。EJB仕様はまた、既存のアプリケーションへのアクセスを単純化し、ツール作成使用のために均等なアプリケーション開発モデルを提供する。
【0007】
Javaは、Javaクライアントがリモート・メソッド呼び出し(RMI)と呼ばれる方法により、別のプロセスで動作しているJavaサーバ上のメソッドを呼び出す機構を提供する。しかしながら、例えば共通オブジェクト・リクエスト・ブローカ・アーキテクチャ(CORBA:Common Object Request Broker Architecture)準拠のサーバなど、サーバがJava環境で動作していない場合、JavaクライアントはCORBAサーバ上のメソッドに対してメソッド呼び出しを発行できない。なぜなら、JavaはCORBAオブジェクトと通信するための固有の機構を提供しないからである。
【0008】
要するにCORBAは、アプリケーションがどこに配置されようと、或いは誰がそれらを設計したかに関わらず、アプリケーションが互いに通信することを可能にするオブジェクト・リクエスト・ブローカ(ORB)である。オブジェクト・リクエスト・ブローカは、オブジェクト間のクライアント−サーバ関係を確立するミドルウェアである。企業は、様々なソフトウェア・アプリケーション間の相互運用性を提供するための解決策としてCORBAに注目した。
【0009】
【発明が解決しようとする課題】
データ整備、すなわち、JavaクライアントとCORBAサーバ間での異なるタイプのデータのためのデータ変換を実行するための標準的な機構は存在しない。JavaクライアントがCORBAサーバなどの非Java環境で実行されるEJBなどの、別の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に接続される。これらのクライアント108、110及び112は、例えばパーソナル・コンピュータまたはネットワーク・コンピュータである。本願の目的上、ネットワーク・コンピュータはネットワークに接続される任意のコンピュータであり、ネットワークに接続される別のコンピュータからプログラムまたは他のアプリケーションを受信する。図示の例では、サーバ104はブート・ファイル、オペレーティング・システム・イメージ、及びアプリケーションなどのデータをクライアント108乃至112に提供する。クライアント108、110及び112は、サーバ104のクライアントである。分散データ処理システム100は図示されない追加のサーバ、クライアント及び他の装置を含み得る。図示の例では、分散データ処理システムは100はインターネットであり、ネットワーク102が、TCP/IPプロトコル一式を使用し互いに通信するネットワーク及びゲートウェイの世界的な集合を表す。主要ノードまたはホスト・コンピュータ間の高速データ通信回線の中枢がインターネットの中心部にあり、データ及びメッセージを経路指定する数千の商業用、政府用、教育用、及び他のコンピュータ・システムを含む。勿論、分散データ処理システム100は、例えばイントラネット、ローカル・エリア・ネットワーク(LAN)、または広域ネットワーク(WAN)などの、多数の異なるタイプのネットワークとしても実現され得る。図1は例として示されただけであり、本発明のプロセスの体系的な制限を意図するものではない。
【0013】
図2を参照すると、このブロック図は、図1のサーバ104など、本発明に従いサーバとして実現されるデータ処理システムを示す。データ処理システム(サーバ)200は、システム・バス206に接続される複数のプロセッサ202及び204を含む対称マルチプロセッサ(SMP)・システムであり得る。或いは、単一プロセッサ・システムが使用され得る。システム・バス206には更に、メモリ制御装置/キャッシュ208が接続され、これはローカル・メモリ209とのインタフェースを提供する。I/Oバス・ブリッジ210はシステム・バス206に接続され、I/Oバス212とのインタフェースを提供する。メモリ制御装置/キャッシュ208及びI/Oバス・ブリッジ210は、図示のように統合され得る。
【0014】
I/Oバス212に接続される周辺コンポーネント相互接続(PCI)バス・ブリッジ214は、PCIローカル・バス216とのインタフェースを提供する。多数のモデム218乃至220がPCIバス216に接続される。一般的なPCIバス・インプリメンテーションは、4つの拡張スロットまたは増設コネクタをサポートする。図1のネットワーク・コンピュータ108乃至112への通信リンクは、増設ボードを介してPCIローカル・バス216に接続されるモデム218及びネットワーク・アダプタ220を介して提供され得る。
【0015】
追加のPCIバス・ブリッジ222及び224は、PCIバス226及び228のためのインタフェースを提供し、これらのバスから追加のモデムまたはネットワーク・アダプタがサポートされ得る。このように、サーバ200は複数のネットワーク・コンピュータへの接続を可能にする。また図示のように、メモリマップド・グラフィックス・アダプタ230及びハード・ディスク232も、直接的にまたは間接的にI/Oバス212に接続され得る。
【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への追加の接続は、直接コンポーネント相互接続を介してまたは増設ボードを介して形成され得る。図示の例では、ローカル・エリア・ネットワーク(LAN)・アダプタ310、SCSIホスト・バス・アダプタ312、及び拡張バス・インタフェース314が直接コンポーネント接続によりPCIローカル・バス306に接続される。それに対して、音声アダプタ316、グラフィックス・アダプタ318、及びスマートカード・アダプタ319は、拡張スロットに挿入される増設ボードにより、PCIローカル・バス306に接続される。拡張バス・インタフェース314は、キーボード及びマウス・アダプタ320、モデム322、及び追加のメモリ324のための接続を提供する。SCSIホスト・バス・アダプタ312は、ハード・ディスク・ドライブ326、テープ・ドライブ328、及びCD−ROMドライブ330のための接続を提供する。一般的なPCIローカル・バス・インプリメンテーションは、3つまたは4つのPCI拡張スロットまたは増設コネクタをサポートする。
【0019】
オペレーティング・システムはプロセッサ302上で実行され、図3のデータ処理システム300内の様々なコンポーネントの制御を調整及び提供するために使用される。オペレーティング・システムはIBMから提供されるOS/2などの、市販のオペレーティング・システムであってよい。"OS/2"はIBMの商標である。Javaなどのオブジェクト指向のプログラミング・システムが、オペレーティング・システムと共に実行され、データ処理システム300上で実行されるJavaプログラムまたはアプリケーションからオペレーティング・システムに呼び出しを提供する。"Java"はサン・マイクロシステムズ社の商標である。オペレーティング・システムの命令、オブジェクト指向オペレーティング・システム、及びアプリケーションまたはプログラムは、ハード・ディスク・ドライブ326などの記憶装置上に配置され、主メモリ304にロードされ、プロセッサ302により実行される。
【0020】
当業者には明らかなように、図3のハードウェアはインプリメンテーションに応じて変化し得る。フラッシュROM(または等価な不揮発性メモリ)または光ディスク・ドライブなどの、他の内部ハードウェアまたは周辺装置が更に追加で、または図3に示されるハードウェアの代わりに使用され得る。また、本発明のプロセスはマルチプロセッサ・データ処理システムに適用され得る。
【0021】
例えば、データ処理システム300は、ネットワーク・コンピュータとして任意的に構成される場合、図3に点線332で示されるボックス内のSCSIホスト・バス・アダプタ312、ハード・ディスク・ドライブ326、テープ・ドライブ328、及びCD−ROM330を含まなくてよい。すなわち、点線ボックス内のコンポーネントは任意に含まれ得ることを示す。その場合、正確にはクライアント・コンピュータと呼ばれるコンピュータは、LANアダプタ310やモデム322などの、特定タイプのネットワーク通信インタフェースを含まねばならない。別の例として、データ処理システム300は自身が特定タイプのネットワーク通信インタフェースを含むか否かに関わらず、特定タイプのネットワーク通信インタフェースに頼ることなく、ブート可能に構成される独立型のシステムである。更に別の例として、データ処理システム300はパーソナル・デジタル・アシスタント(PDA)装置であり、これはオペレーティング・システム・ファイルまたはユーザ生成データを記憶する不揮発性メモリを提供するために、ROMまたはフラッシュROMにより構成される。
【0022】
図3の図示の例、及び前述の例は、本発明に関する体系的な制限を意味するものではない。
【0023】
本発明は、JavaクライアントがCORBAサーバ上のEJBと通信可能な分散アプリケーションを提供する方法、データ処理システム、及び命令を提供する。分散アプリケーション内における本発明について述べる都合上、従来の総称的な分散アプリケーションについて詳述することにする。
【0024】
本発明のプロセスは、オブジェクト指向プログラミング・システムであるJavaプログラミング・システムを用いて実現され得る。オブジェクト指向プログラミング技術は、"オブジェクト"の定義、作成、使用及び命令を含み得る。これらのオブジェクトは、データ要素または属性、及びデータ要素を操作するメソッドを含むソフトウェア・エンティティである。オブジェクトはまた、オブジェクト内のメソッドをトリガまたは制御するオブジェクト外の事象に関連するデータを含み得る。
【0025】
オブジェクトは、"クラス"を定義することにより定義される。クラスはオブジェクトではなくテンプレートであり、コンパイラに実際のオブジェクトの作成方法を指示する。例えば、クラスはデータ変数の数及びタイプや、データを操作する機能に関わるステップを指定し得る。オブジェクトは実際、コンストラクタと呼ばれる特殊機能によりプログラム内で作成される。コンストラクタは、対応するクラス定義、及びオブジェクト作成の間に提供される引き数などの追加の情報を使用し、オブジェクトを構成する。オブジェクトはデストラクタと呼ばれる特殊機能により破壊される。Javaはまた、インタフェースとして知られる完全な抽象クラスの作成を許容し、これは他のクラスが如何にメソッドを処理しているかに関わり無く、複数のクラスと共用され得るメソッドの定義を可能にする。
【0026】
図4を参照すると、従来の分散アプリケーションを示す図が示される。図示のように、クライアント・オブジェクト400は、分散アプリケーションのクライアント側に存在し、一方、サーバ・オブジェクト402は分散アプリケーションのサーバ側を形成する。クライアント・オブジェクト400は、例えば図1の分散データ処理システム100内のクライアント108などの、クライアント・コンピュータ上に配置される。サーバ・オブジェクト402は、図1のサーバ104などのサーバ上に配置される。クライアント・オブジェクト400は、サーバ・オブジェクト402内に実装される様々なビジネス規則またはビジネス論理にもとづき、データベース404をアクセスするために、サーバ・オブジェクト402への呼び出しを開始する。データベース404はサーバ内に配置されるか、リモート・データベースである。サーバ・オブジェクト402は現企業アプリケーション410へのアクセス、及びレガシ・アプリケーション408へのアクセスも提供し得る。分散アプリケーションを作成するユーザが、サーバ・オブジェクト402を実装する第2階級(tier)のコンピュータの、ホスト名またはインターネット・プロトコル(IP)・アドレスを構成することを可能にするためにカストマイザが提供され得る。この例では、Javaリモート・メソッド呼び出し(RMI)プロトコル406が、クライアント・オブジェクト400及びサーバ・オブジェクト402などのオブジェクト間の分散通信のために使用される。
【0027】
サーバ・オブジェクト402は、アプリケーション・プログラミング・インタフェース(API)を用いて実装される実際のビジネス論理を含む。APIはJava定義Javaデータベース接続性(JDBC)構造化照会言語(SQL)データベース・アクセス・インタフェースを使用し、これは広範囲のリレーショナル・データベースへの均等なアクセスを提供する。図示の例では、これらのデータベースはデータベース404内で見いだされ得る。サーバ・オブジェクト402は、クライアント・オブジェクト400から呼び出される必要な機能を提供するために使用されるメソッドを含む。前述のメソッドは、他の後置システム(すなわちCICS、IMS、MQ、SAPなど)をアクセスするために作成され、JDBCまたはデータベース・アクセスだけに制限されるべきではない。
【0028】
分散アプリケーション内におけるデータベース・アクセスの例について、引き続き述べると、データベース・アクセス機能は2つのオブジェクト、すなわちクライアント・オブジェクト及びサーバ・オブジェクトに分けられる。サーバ・オブジェクトは、クライアント・オブジェクトから呼び出され、JDBCを使用するメソッドを含むインタフェースを実装する。
【0029】
クライアント・オブジェクトは、様々な事象の事象ソースまたは事象シンクとして作用する。生成時、クライアント・オブジェクトはクライアント側ビルダ環境で使用され、他のクライアント側ソフトウェア・コンポーネントに接続される。例えば、クライアント側生成時にアプリケーション・アセンブラがクライアント側ビルダ環境を使用し、GUIオブジェクトをクライアント・オブジェクトに接続する。従って、ボタンが押下されるとき、特定のデータを検索するための事象がオブジェクトに送信される。サーバ側生成時には、アプリケーション・アセンブラがビルダ環境を使用し、サーバ・オブジェクトを接続する。
【0030】
実行時、ユーザはクライアント上のボタンを押下し、これは特定のデータが表示のために要求されることを示す。GUIオブジェクトは事象を生成し、これがクライアント・オブジェクトに送信される。クライアント・オブジェクトは、必要なデータを要求するサーバ・オブジェクト上のメソッドを呼び出す。クライアント・オブジェクトは、リモート・メソッド呼び出し(RMI)またはIIOP(Internet InterOrb Protocol)を使用するオブジェクト・リクエスト・ブローカ(ORB)などのプロトコルを使用することにより、その対応するサーバ・オブジェクトと通信する。サーバ側オブジェクトはデータを検索し、データをクライアント側オブジェクトに返送する。データが次にクライアント側オブジェクトによりGUIオブジェクトに返送され、エンドユーザに表示される。
【0031】
図示の例では、クライアント・オブジェクト400及びサーバ・オブジェクト402を実装するJavaビーンズが使用され得る。ビーンを純粋なオブジェクトと区別するのは、それが属性インタフェースと呼ばれる外部インタフェースを有することであり、これはツールがコンポーネントが実行しようとしていることを読出し、それを他のビーンにフック留めし(hook up)、それを別の環境にプラグ・インすることを可能にする。2つの異なるタイプのビーン、すなわちJavaBeans及びEnterprise JavaBeans(EJB)が使用され得る。JavaBeansは単一のプロセスに対して局所的であるようにもくろまれ、しばしば実行時に見ることができる。このビジュアル・コンポーネントは、ボタン、リスト・ボックス、グラフィックまたはチャートなどである。
【0032】
EJBは、サーバ上で実行され、クライアントにより呼び出されるように設計される、見ることができないリモート・オブジェクトである。EJBは複数の見ることができないJavaBeansから構成される。EJBはあるマシン上に常駐し、別のマシンから遠隔的に呼び出されるようにもくろまれる。EJBは、ツールにより読出され得るビーンに関する記述としてもくろまれる展開記述子(deployment descriptor)を有する。EJBはまたプラットフォーム独立であり、Javaをサポートする任意のプラットフォーム上で使用され得る。
【0033】
サーバ・ビーンズすなわちEJBは、サーバ上に展開される遠隔的に実行可能なコンポーネントまたはビジネス・オブジェクトである。EJBはそれらが遠隔的にアクセスされることを可能にするプロトコルを有し、このプロトコルは、EJBが特定のサーバ上に導入または展開されることを可能にする。EJBはサービスの主要な品質、セキュリティ、トランザクション振舞い、同時性(2つ以上のクライアントにより一度にアクセスされる能力)、及び持続性(どのようにそれらの状態が保管され得るか)をEJBサーバ上においてそれらが配置されるコンテナに委託する一連の機構を有する。EJBはそれらの振舞いを異なるサービス品質を提供するコンテナ内に導入される。展開ツールの使用を通じて、プラットフォーム独立のJavaBeanがプラットフォーム特定のEJBに取り入れられる。後者は、既存のビジネス・システム及びアプリケーションの特定の要求に合致するために使用可能な適正なサービス品質を有する。
【0034】
クライアント・ビーン400とサーバ・ビーン402間のこの分離により、サーバ・ビーン402内の様々なビジネス論理の変更がクライアント・ビーン400の変更無しに実行され得る。これは単一のサーバをアクセスする数千のクライアントが存在し得ることを考慮すると望ましい。更にこれらのプロセスは、例えばCOBOLなどの今日的でないプログラミング言語により作成されたプログラムにも適用され得る。こうしたプログラムの動的変更は、そのプログラムをJavaなどのオブジェクト指向プログラミング・システムと互換にするインタフェースを作成することにより実行され得る。
【0035】
分散アプリケーション内及び間の通信サービスは、例えばOMG(Object Management Group)コンソーシアムにより設計されたCORBA規格など、Javaリモート・メソッド呼び出し(RMI)以外の他のタイプの分散プロトコルによっても同様に実現され得る。CORBAは、今日使用可能な急増しつつあるハードウェア及びソフトウェア製品の間の相互運用性のニーズに対するOMGの回答である。要するに、CORBAはアプリケーションがどこに配置されようと、また誰がそれらを設計したかに関わらず、アプリケーションが互いに通信することを可能にするオブジェクト・リクエスト・ブローカ(ORB)である。
【0036】
オブジェクト・リクエスト・ブローカは、オブジェクト間のクライアント−サーバ関係を確立するミドルウェアである。オブジェクト・リクエスト・ブローカを使用することにより、クライアントは同一マシン上に存在する、またはネットワークを介して存在するサーバ・オブジェクト上のメソッドを透過的に呼び出すことができる。オブジェクト・リクエスト・ブローカは呼び出しを横取りし、要求を実現するオブジェクトを見いだす責任があり、それにパラメータを受け渡し、そのメソッドを呼び出し、結果を返却する。クライアントは、オブジェクトが配置されている場所、そのプログラミング言語、そのオペレーティング・システム、またはオブジェクトのインタフェースの一部でない他のシステム態様を知る必要はない。そうすることにより、オブジェクト・リクエスト・ブローカは、異種の分散環境内の異なるマシン上のアプリケーション間の相互運用性を提供し、複数のオブジェクト・システムを継ぎ目無く相互接続する。
【0037】
典型的なクライアント/サーバ・アプリケーションを扱うために、開発者は彼ら自身の設計または認識された規格を使用し、装置間で使用されるプロトコルを定義する。プロトコル定義はインプリメンテーション言語、ネットワーク・トランスポート、及び幾つかの他のファクタに依存する。オブジェクト・リクエスト・ブローカはこのプロセスを単純化し、柔軟性を提供する。オブジェクト・リクエスト・ブローカは、構成中のシステムの各コンポーネントのために、プログラマが大抵の適切なオペレーティング・システム、実行環境、及びプログラミング言語さえも選択し、使用することを可能にする。更に重要な点は、オブジェクト・リクエスト・ブローカは既存のコンポーネントの統合を可能にする。ORBベースの解決策では、開発者は新たなオブジェクトを作成するために使用するのと同一のインタフェースを用いて、レガシ・コンポーネントをモデル化し、次に標準化バスとレガシ・インタフェース間を変換する"ラッパ(wrapper)"・コードを作成する。
【0038】
CORBAは、オブジェクト指向標準化及び相互運用性に向けての重要な進歩を表すオブジェクト・リクエスト・ブローカである。CORBAにより、ユーザは、情報がどのソフトウェアまたはハードウェア・プラットフォーム上に存在するか、或いは情報がネットワーク内のどこに配置されるかを知る必要無しに、情報へのアクセスを透過的に獲得できる。CORBAオブジェクト開発の目的は、オブジェクト・サーバまたは単にサーバの生成及び登録である。サーバはプログラムであり、1つ以上のオブジェクト・タイプのインプリメンテーションを含み、オブジェクト・リクエスト・ブローカに登録される。
【0039】
CORBAは、オブジェクトが企業及び大陸さえも横断して通信することを可能にするオブジェクト・バスを詳述する。CORBAは、高機能コンポーネントが互いに発見し合い、オブジェクト・バスを介して相互運用することを可能にするように設計された。しかしながら、CORBAは単なる相互運用性を超越する。CORBAはバス関連サービスの拡張セットを指定することにより、オブジェクトを作成及び消去し、それらを名前によりアクセスし、それらを永久記憶装置に記憶し、それらの状態を外部化し、それらの間の臨時の関係を定義する。
【0040】
JDKバージョン1.1の発表により、Javaはリモート・メソッド呼び出し(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サーバ520と通信する。CORBAサーバ520は、異種のタイプのソフトウェア・オブジェクトのための統合及び相互運用性を提供する。JavaBean521、C++オブジェクト522、Enterprise JavaBean(EJB)523、及びCOBOLオブジェクト524は、サーバ520により提供されるCORBAサービスを用いて通信し、サービス機能を登録する。クライアント・オブジェクト500は、CORBAサービスを通じて、オブジェクト521乃至524により提供される機能及びメソッドを呼び出す。
【0046】
図6を参照すると、CORBAを用いて相互運用性機能を提供する従来の分散アプリケーション内のコンポーネントが示される。図6は、クライアント602から、サーバ内の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】
スタブ及びスケルトン・ファイルは、様々な方法により生成される。スタブ・ファイルは、クライアント・プログラミング言語により、クライアントにサーバ・メソッドへのアクセスを提供する。サーバ・スケルトン・ファイルは、オブジェクト・インプリメンテーションをオブジェクト・リクエスト・ブローカ(ORB)実行時に結び付ける。オブジェクト・リクエスト・ブローカはスケルトンを使用し、メソッドをオブジェクト・インプリメンテーション・インスタンス(サーバント)にディスパッチする。
【0054】
従来技術の説明から本発明の説明に目を向けると、図7及び図8は、Java及びCORBAの利点を結合する本発明の詳細を示す。前述のように、リモート・メソッド呼び出しは、Javaクライアントがリモート・メソッド呼び出しによりリモート・オブジェクトと通信することを強要する、Java間の技術である。Javaは定義上、言語自身の境界内で作用するプログラミング技術である。それに対して、CORBAは統合技術であり、プログラミング技術ではない。本発明は、JavaクライアントがCORBAクライアント上に存在するEJBのビジネス・メソッドを呼び出すことを可能にする。
【0055】
図7を参照すると、このブロック図は、CORBAサーバ内で実行されるEnterprise JavaBean(EJB)のリモート・ビジネス・メソッドを呼び出す方法を実現するために使用されるコンポーネントを示す。図7のシステムは、図4及び図6に示されるシステムに類似する。図7は、クライアント700及びサーバ726が、Java仮想マシンJVM702及びJVM724を含むJava実行時環境によりイネーブルされる以外は、図4に示される分散アプリケーションと類似する。図7は図6と類似する。なぜなら、クライアント602及びサーバ614と同様に、Javaクライアント・オブジェクト704がリモートEJB728内のメソッドを呼び出そうとしているからである。
【0056】
更に、図7の分散アプリケーションは、オブジェクト・リクエスト・ブローカORB714及びORB718を含み、オブジェクト要求及び応答をIIOP716を介して伝達する。図6の総称的なアーキテクチャは、クライアント、サーバ、スタブ、及びスケルトンを含み、オブジェクト・リクエスト・ブローカが図7のソフトウェア・アーキテクチャ内に反映され、これは本発明の方法に従い、JavaオブジェクトがCORBAを用いて通信することを可能にする。
【0057】
JVM702は、EJB728内に存在するビジネス・メソッドを呼び出そうとしているJavaクライアント・オブジェクト704を含む。Java仮想マシン(JVM)は、メモリ内に存在する仮想コンピュータ・コンポーネントである。特定のケースでは、JVMはプロセッサ内で実現され得る。JVMはJavaプログラムが、コードがコンパイルされたあるプラットフォームだけではなしに、異なるプラットフォーム上で実行されることを可能にする。JavaプログラムはJVMのためにコンパイルされる。このように、Javaは、様々な中央処理ユニット及びオペレーティング・システム・アーキテクチャを含み得る多くのタイプのデータ処理システムのためにアプリケーションをサポートできる。
【0058】
Javaアプリケーションが異なるタイプのデータ処理システム上で実行されるようにするために、コンパイラは一般に、アーキテクチャ中立ファイル形式を生成する。すなわち、Java実行時システムが存在する場合、コンパイルされたコードが多くのプロセッサ上で実行可能である。Javaコンパイラは、特定のコンピュータ・アーキテクチャには特定的でないバイトコード命令を生成する。バイトコードは、Javaコンパイラにより生成されるマシン独立なコードであり、Javaインタプリタにより実行される。Javaインタプリタは、バイトコードを交互に解読及び実行するJVM内のモジュールである。これらのバイトコード命令は、任意のコンピュータ上で容易に解釈され、また固有マシン・コードに即座に容易に変換されるように設計される。
【0059】
JVM702は、EJBインタフェース708をクライアント・オブジェクト704に提供するアダプタ706を含み、それにより、クライアント・オブジェクト704はリモート・メソッド呼び出しの既知のメソッドを使用し、EJBインタフェース708内のメソッドを呼び出す。EJBインタフェース708はCORBAプロキシ710を呼び出し、サーバ726とのCORBA通信を開始する。CORBAプロキシ710は、オブジェクト要求をオブジェクト・リクエスト・ブローカORB714に受け渡す。この例では、ORB714はJavaにより実現される。ORBがC++により実現される場合、オブジェクト要求はJavaネイティブ・インタフェース(JNI)を通じて受け渡される。ORB714及びORB718はIIOP716を介して通信し、オブジェクト要求がクライアント及びサーバ・オブジェクトにより、オブジェクト・リクエスト・ブローカを用いて透過的にサポートされることを保証する。一旦ORB718がオブジェクト要求を受信すると、EJBスケルトン720内のコードが呼び出され、EJB728から要求されたビジネス・メソッドの呼び出しを開始する。EJBスケルトン720はJNI722を用いてEJB728を呼び出し、適切な引き数をJVM724内に含まれるEJB728に受け渡す。この特定の例では、EJBスケルトン720はC++により実現され得るが、JNI722の使用を要求するJava以外の別の言語によっても実現され得る。
【0060】
図8を参照すると、このブロック図は、サーバ・オブジェクトのリモート・メソッドを呼び出す方法を実現するために使用されるコンポーネントを示す。図8のシステムは、クライアント750がある言語により実装されるクライアント・オブジェクト752を有し、サーバ772が異なる言語により実装されるサーバ・オブジェクト770を有するように、環境が一般化される以外は、図7に示されるシステムと類似する。
【0061】
クライアント750はアダプタ754を含む。アダプタはクライアント・オブジェクト752のためにオブジェクト参照により、サーバ・オブジェクト770上のリモート・メソッド呼び出しをシミュレートする。クライアント・オブジェクト752はアダプタ754内のメソッドを呼び出し、これがオブジェクト参照756を呼び出し、サーバ772とのオブジェクト通信を開始する。オブジェクト参照756は、データ整備モジュール758を通じてオブジェクト要求をオブジェクト・ディスパッチャ760に受け渡す。オブジェクト・ディスパッチャ760及びオブジェクト・ディスパッチャ764は、オブジェクト通信リンク762を介して通信し、オブジェクト要求がクライアント及びサーバ・オブジェクトにより適切なオブジェクト要求プロトコルを用いて、透過的にサポートされることを保証する。オブジェクト・ディスパッチャ764はオブジェクト要求をデータ整備モジュール766を介して、リモート呼び出しスケルトン768に受け渡す。データ整備モジュール758及びデータ整備モジュール766は、異なる言語により実装されるオブジェクトを含む相互運用環境のために、適切なデータ変換及び呼び出し変換機構を提供する。リモート呼び出しスケルトン768は、サーバ・オブジェクト770内のメソッドを呼び出し、適切な引き数をサーバ・オブジェクト770に受け渡す。
【0062】
図9を参照すると、CORBAサーバ内で実行されるEnterprise JavaBean(EJB)上のリモート・ビジネス・メソッドを呼び出す方法を示すフロー図が示される。図7に関連して前述したように、Javaクライアント・オブジェクトからJavaアダプタ、ORB及びEJBスケルトンを介して所望のEJBに至るプロセス・フローは、図9に示されるプロセス・フローに類似する。図9は、本発明のJava及びCORBA環境内の実際の呼び出し及びクラス操作を示す。
【0063】
プロセスは、クライアント内のコードがリモート・オブジェクトの名前を探索するとき開始する(ステップ802)。クライアントは、EJB内のビジネス・メソッドなど、リモート・サーバ内のオブジェクトのメソッドの実行を要求する。ルックアップ・メソッド内のコードが所望のメソッドを含むリモート・オブジェクトに対応するCORBAプロキシの名前を見いだす(ステップ804)。適切なCORBAプロキシが見いだされた後、その対応するCORBAプロキシのための適切なアダプタ・クラスが突き止められる(ステップ806)。CORBAプロキシは適切なアダプタ・クラスによりラップ(wrap)され(ステップ808)、アダプタ・クラスが呼び出し側クライアント・コードに総称オブジェクトとして返却される(ステップ810)。クライアント・コードは、返却された総称オブジェクトを必要なクラス・タイプに固定する(ステップ812)。クライアント・コードは次に、新たに獲得されたオブジェクトから所望のメソッドを呼び出し(ステップ814)、新たに獲得されたアダプタ・クラス内の所望のメソッドが呼び出される(ステップ816)。呼び出されたアダプタ・クラス・メソッド内のコードは、CORBAプロキシ内のその対応するメソッドを呼び出す(ステップ818)。一旦メソッドがCORBAプロキシ内で実行を開始すると、CORBAインフラストラクチャが、CORBAサーバ上のCORBAプロキシに対応するリモート・オブジェクトの呼び出しを処理する(ステップ820)。
【0064】
図9の方法は、図8に示されるオブジェクト指向環境のために一般化され得る。CORBAプロキシを通じてEJBのメソッドを呼び出すのではなく、ソース・オブジェクト及びターゲット・オブジェクトがサーバ・オブジェクトのメソッドに一般化され、そのオブジェクト参照を通じて呼び出される。本発明の一般化された方法によれば、サーバ・オブジェクトに対するオブジェクト参照がアダプタによりラップされ、クライアント・オブジェクトによるサーバ・オブジェクト内のメソッドの呼び出しがアダプタにより透過的に処理される。クライアント・オブジェクトがサーバ・オブジェクトのメソッドを呼び出そうとするとき、メソッドは実際、アダプタ・オブジェクト内で呼び出される。アダプタ・クラスは本質的に、オブジェクト参照がクライアント・コードから分離されるように、オブジェクト参照をラップする。クライアントはオブジェクト参照について何も知らない。クライアントはただ、アダプタ・コードに"話しかける(talk to)"だけであり、他方、サーバ上のスケルトン・コードに"話しかける"オブジェクト参照は、クライアント・ベースのアダプタに関して何も知らない。
【0065】
図10乃至図13を参照すると、JavaクライアントがCORBAサーバ内で実行されるEnterprise JavaBeanから、リモート・ビジネス・メソッドを呼び出す分散アプリケーションを記述するJavaプログラミング言語ステートメントの例が示される。図10では、Javaプログラム内の標準のリモート・メソッド呼び出し(RMI)技術の例が示される。CustomerImplクラスのリモート・オブジェクトは、インタフェース"CustomerInterface"により表されるビジネス・メソッドのセットを有し得る。CustomerInterface内に含まれるメソッドは、Javaクライアントから遠隔的に呼び出され得る。この場合、クライアント・コードはステートメント902乃至906に類似すると思われる。ステートメント902は、リモート・オブジェクトのオブジェクト参照を獲得するための命名サービスの使用を示す。オブジェクト"obj"は、CustomerInterfaceを実装するリモートJavaオブジェクトのRMIプロキシである。ステートメント902でオブジェクト参照を獲得後、ステートメント904で、オブジェクトを適切なオブジェクト・タイプに固定することによりオブジェクトが制限される。ステートメント906では、Javaクライアント・コードがプロキシ・オブジェクト上のビジネス・メソッドをあたかもローカル・オブジェクトのように呼び出す。クライアントは、呼び出しがオブジェクト・リクエスト・ブローカ(ORB)を用いて実施されることを知らない。プロキシ・オブジェクトはCORBA規格により定義されるように、メソッド呼び出しをリモート・オブジェクトに転送する。
【0066】
本発明の方法によれば、リモート・オブジェクトを実行するために、Java内のRMI振舞いが、CORBA機構を用いてシミュレートされる。特殊なNamingContext及びアダプタ・クラスのセットが、図11乃至図13に示されるように実装される。特殊なNamingContextクラス内のルックアップ・メソッドが、図11に示されるように実装される。ステートメント912は、特殊なルックアップ・メソッドの定義を示す。ステートメント914は、CORBA命名サービス内のルックアップ・メソッドがステートメント914内の所望のリモート・オブジェクトに対応するCORBAプロキシを見いだすために使用されることを示す。一旦CORBAプロキシが見いだされると、ステートメント916が新たなアダプタ・クラスを作成する。ステートメント918は、CORBAプロキシが適切なアダプタ・クラスによりラップされることを示す。ステートメント920は、ルックアップ・メソッドからの戻り値として、オブジェクト参照の返却を示す。
【0067】
図12は、図10に示されるRMIに類似のシミュレート化RMIのためのクライアント・コードの例を示す。ステートメント922は、リモート・オブジェクトの名前によるリモート・オブジェクトのルックアップすなわち探索を示し、図11に示されるコードにより実装された新たなNamingContextクラスを使用する。一旦オブジェクト参照が返却されると、ステートメント924がオブジェクト参照がCostomerInterfaceクラスを用いて制限されるか、固定されなければならないことを示す。ステートメント926は、クライアント・コード内で呼び出される所望のビジネス・メソッドを示す。しかしながら、CustomerInterfaceクラスの"cust"インスタンス上で呼び出されるビジネス・メソッドは、実際には、新たに定義されたNamingCotextクラスにより返却されたアダプタ・オブジェクト上で呼び出される。
【0068】
図13は、ビジネス・メソッドのためのアダプタ・クラス内のコードを示す。ステートメント930はbusinessMethodメソッドの定義の開始を示す。ステートメント932は、アダプタ・コードが所望のメソッド呼び出しをCORBAプロキシに委託することを示す。この場合、プロキシはCORBAサーバ上のEJBのスケルトンのための、CORBAプロキシのJavaクラス・インプリメンテーションである。
【0069】
アダプタ・クラスは、CORBAサーバ上のEJBによりサポートされるビジネス・インタフェースを実装しなければならない。アダプタ・クラスは本来、CORBAプロキシがJavaクライアント・コードから分離されるように、CORBAプロキシをラップする。重要な点は、JavaクライアントがCORBAプロキシに関して何も知らないことである。JavaクライアントはJavaベースのアダプタ・コードにだけ話しかけ、他方、CORBAサーバ上のスケルトン・コードに話しかけるCORBAプロキシは、Javaベースのアダプタに関して何も知らない。
【0070】
図11乃至図13に示される例では、リモート・オブジェクトのビジネス・メソッドのための引き数が、単にアダプタからプロキシ・オブジェクトに受け渡される。引き数に対するデータ変換は示されない。ビジネス・メソッドがEJBを引き数として受け取ったり、返却する場合、必要に応じて好適なアダプタにより、プロキシ・オブジェクトの適切なラップまたはラップ解除を実行することが、そのビジネス・メソッドのアダプタ・コードの義務である。図示の例では、戻り値を期待すること無く、ビジネス・メソッドがCustomerInterfaceクラスのために呼び出される。
【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"のオブジェクト"ee"への制限を示す。ステートメント1014は"CustomerName"の探索を示し、ステートメント1016は、Customerクラス内のビジネス・メソッドの呼び出しを示し、EJB引き数"ee"及び新たな顧客"newCust"の戻り値を有する。
【0074】
EmployeeのEJBを引き数として受け渡すことにより、ビジネス・メソッドがJavaクライアントによりアダプタ上で呼び出されるとき、"Employee"インタフェースを実現するのはアダプタ・オブジェクトであり、アダプタ・コードがアダプタを"Employee ee"からラップ解除し、その内部のCORBAプロキシをORBを介して受け渡す。同様に、ORBを介して返却される結果の戻り値が実際、CustomerのEJBのCORBAプロキシを含む。この場合、アダプタ・コードは返却されたプロキシをクライアントに返送する前に、それを適切なアダプタによりラップする。
【0075】
図16は、CutomerAdapterクラス内のアダプタ・コードの例を示し、これはEJB引き数を必要に応じてラップ及びラップ解除するためのステップを示す以外は、図13に示される例と類似である。ステートメント1020は、アダプタ・クラス内のビジネス・メソッドの宣言を示し、整数"I"及び"Employee ee"を引き数として受け取り、Customerを戻り値として返却する。ステートメント1022は、引き数"ee"がタイプ"eeAdapter"として書き直されることを示す。ステートメント1024は、EmployeeAdapterからCORBAプロキシを獲得するために、"eeAdapter"がラップ解除されることを示す。ステートメント1026は、ビジネス・メソッドが"eeProxy"を引き数として、プロキシ・オブジェクト上で呼び出されることを示す。なぜなら、CORBAプロキシ・オブジェクトだけがORBを介して受け渡されるべきであるからである。ステートメント1028は、適切なアダプタにより、返却されたプロキシ"custProxy"をラップし、"custAdapter"を獲得することを示す。ステートメント1030は、"custAdapter"がビジネス・メソッドの呼び出しからの戻り値として、呼び出し側クライアント・オブジェクトに返却されることを示す。このように、アダプタ・コードは、メソッド呼び出しをCORBAプロキシに委託することに加え、必要に応じてデータ変換を実行する。この場合、アダプタ・コードは、ビジネス・メソッド内で引き数として渡されるEJBをラップ及びラップ解除する。更に、アダプタは、ORBインプリメンテーションによりサポートされないデータ・タイプも実行する。
【0076】
図17を参照すると、本発明の好適な方法に従い、適切なアダプタによりEJB引き数をラップ及びラップ解除するプロセスのフロー図が示される。プロセスは、クライアント・オブジェクトがビジネス・メソッドを呼び出し、様々な引き数をビジネス・メソッドに受け渡すとき開始する(ステップ1102)。この場合、クライアントは、CORBAサーバ上のリモートEJBのビジネス・メソッドのためのインタフェースを実現する、アダプタ・クラス内のメソッドを呼び出す。アダプタはビジネス・メソッドのために引き数のリストを解析し(ステップ1104)、必要に応じて引き数に対してデータ変換を実行する(ステップ1106)。引き数がEJBを表すか否か、この場合、アダプタによりラップされたEJBのためのCORBAプロキシを表すか否かが判断される(ステップ1108)。肯定の場合、アダプタ・コードがアダプタをEJB引き数からラップ解除し、CORBAプロキシを獲得する(ステップ1110)。
【0077】
引き数がEJBでない場合、プロセスはこのメソッド呼び出しにおいて、処理されるべき追加の引き数が存在するか否かを判断する(ステップ1112)。存在する場合、プロセスはステップ1104に戻り、次の引き数を獲得する。もはや引き数が存在しない場合、アダプタはメソッド呼び出しをEJBを表すCORBAプロキシにORBを介して委託する(ステップ1114)。
【0078】
呼び出されたCORBAプロキシに対して、戻り値が存在するか否かが判断される(ステップ1116)。存在しない場合、アダプタは実行を完了し、制御フローをクライアント・コードに返却する(ステップ1124)。戻り値が存在する場合、戻り値がEJBプロキシか否かが判断される(ステップ1118)。そうでない場合、戻り値がクライアントへの結果値として返却される(ステップ1122)。戻り値がEJBプロキシの場合、アダプタは結果をクライアントに返却する前に、返却されたプロキシを適切なアダプタによりラップする(ステップ1120)。プロセスは次に完了し、クライアント・コードがその実行を継続する(ステップ1124)。
【0079】
本発明の利点は、図面に関する前述の詳細な説明から明かであろう。Javaは、Javaクライアントがリモート・メソッド呼び出し(RMI)と呼ばれる方法を使用して、別のプロセスで実行されるJavaサーバ上のメソッドを呼び出す機構を提供する。しかしながら、CORBA準拠のサーバなど、サーバがJava環境で実行されていない場合、Javaクライアントは、サーバ上のメソッドに対するメソッド呼び出しを発行できない。なぜなら、JavaはCORBAオブジェクトと通信する固有の機構を提供しないからである。JavaクライアントとCORBAサーバ間で、データ整備、すなわち異なるタイプのデータのためのデータ変換を実行する標準的な機構は存在しない。これらの方法は、他のサーバ上で実行される他のEJBに参照を受け渡すステップを含む。Javaクライアントが、CORBAサーバなどの非Java環境で実行されるEJBなどの別のJavaアプリケーションと通信するための標準的な機構は存在しない。
【0080】
本発明は、CORBAサーバ内で実行されるEnterprise JavaBean(EJB)のインタフェースを内観することにより生成されるアダプタを使用する。これらのアダプタはJavaクライアント側に存在し、それらの内部にEJBを実行するCORBAサーバのリモート・プロキシを保持する。アダプタは、ビジネス・メソッドを呼び出すためにEJBにより指定されるインタフェースを実現するJavaクラスである。アダプタはクライアントからの全てのビジネス・メソッド呼び出しをサーバ上のCORBAプロキシに委託し、JavaクライアントからCORBAプロキシへの、及びその逆のデータ整備を実行する。
【0081】
クライアント・オブジェクトの見地から、アダプタは実際にCORBAサーバ上に存在するEJBのレプリカである。クライアント・オブジェクトは、自身がオブジェクト・リクエスト・ブローカ(ORB)を介してCORBAサーバ上のEJBと通信することを意識しない。アダプタはそれ自身内にEJBを実行するサーバのCORBAプロキシを記憶する。クライアントによりアダプタに発せられるあらゆるビジネス・メソッド呼び出しが適切なデータ変換の後に、アダプタによりCORBAプロキシに委託される。従って、アダプタは、JavaクライアントとCORBAサーバ上のEJBとの間の透過的な接着剤として作用する。
【0082】
重要な点は、本発明は完全機能型のデータ処理システムの状況において述べられてきたが、当業者であれば、本発明のプロセスが命令のコンピュータ読取り可能媒体の形態、及び様々な形態で配布され得、本発明が配布を実施するために実際に使用される特定のタイプの信号担持媒体に関係無しに、同様に当てはまることが理解できよう。コンピュータ読取り可能媒体の例には、フロッピー・ディスク、ハード・ディスク・ドライブ、RAM、及びCD−ROMなどの記録型媒体と、デジタル及びアナログ通信リンクなどの伝送型媒体とが含まれる。
【0083】
まとめとして、本発明の構成に関して以下の事項を開示する。
【0084】
(1)分散データ処理システム内の分散アプリケーションにおいて、サーバ・オブジェクトのメソッドを呼び出すプロセスであって、
前記サーバ・オブジェクトと異なるプログラミング・パラダイムで実装されるクライアント・オブジェクトを実行するステップと、
リモート・サーバ・オブジェクトのためのオブジェクト参照を獲得するステップと、
前記オブジェクト参照をアダプタ内でラップするステップと、
前記アダプタのメソッドを呼び出すステップと
を含む、プロセス。
(2)前記アダプタが前記オブジェクト参照を使用して、前記サーバ上のスケルトンのメソッドを呼び出す、前記(1)記載のプロセス。
(3)前記スケルトンが前記サーバ・オブジェクトのメソッドを呼び出す、前記(1)記載のプロセス。
(4)分散データ処理システムにおいて分散アプリケーションを実装する方法であって、
サーバ・オブジェクトのプロキシためのオブジェクト参照を獲得するステップと、
前記プロキシをアダプタ内でラップするステップと、
前記アダプタのメソッドを呼び出すステップと
を含む、方法。
(5)前記アダプタが、前記サーバ・オブジェクトによりサポートされるインタフェースを実装するJavaクラスである、前記(4)記載の方法。
(6)前記サーバ・オブジェクトがEnterprise JavaBeanである、前記(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 JavaBeanである、前記(15)記載のデータ処理システム。
(18)前記オブジェクト参照が命名サービスから獲得される、前記(15)記載のデータ処理システム。
(19)前記プロキシがCORBAプロキシである、前記(15)記載のデータ処理システム。
(20)前記アダプタが前記CORBAプロキシのメソッドを呼び出す、前記(19)記載のデータ処理システム。
(21)前記CORBAプロキシがクライアント・コンピュータ上に存在するJavaクラスである、前記(19)記載のデータ処理システム。
(22)前記CORBAプロキシがメソッド要求をオブジェクト・リクエスト・ブローカに受け渡す、前記(19)記載のデータ処理システム。
(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からリモート・ビジネス・メソッドを呼び出すための分散アプリケーションを記述する、Javaプログラミング言語文の例を示す図である。
【図11】JavaクライアントがCORBAサーバ内で実行されるEJBからリモート・ビジネス・メソッドを呼び出すための分散アプリケーションを記述する、Javaプログラミング言語文の例を示す図である。
【図12】JavaクライアントがCORBAサーバ内で実行されるEJBからリモート・ビジネス・メソッドを呼び出すための分散アプリケーションを記述する、Javaプログラミング言語文の例を示す図である。
【図13】JavaクライアントがCORBAサーバ内で実行されるEJBからリモート・ビジネス・メソッドを呼び出すための分散アプリケーションを記述する、Javaプログラミング言語文の例を示す図である。
【図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リモート・メソッド呼び出し(RMI)プロトコル
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 (11)

  1. 分散データ処理システム内の分散アプリケーションにおいて、サーバ・オブジェクトのメソッドを呼び出すデータ処理システムであって、
    第1のプログラミング環境を実装するクライアントにおいて、前記第1のプログラミング環境のために記述されたクライアント・オブジェクトを実行する実行手段と、
    前記第1のプログラミング環境と異なる第2のプログラミング環境を実装するサーバにおいて、前記第1のプログラミング環境のために記述されたサーバ・オブジェクトを実行する実行手段と、
    前記サーバ・オブジェクト内のメソッドを呼び出しするための試みを開始する前記クライアント・オブジェクトを実行する実行手段と、
    前記サーバ・オブジェクト内のメソッドを呼び出しするための試みを開始する前記クライアント・オブジェクトに応答して、前記サーバ・オブジェクトのためのオブジェクト参照を前記クライアント上で獲得する獲得手段と、
    前記獲得したオブジェクト参照を前記クライアントのアダプタ内でラップするラッピング手段であって、前記アダプタは前記オブジェクト参照クライアント・オブジェクトから分離し、かつ、前記オブジェクト参照と前記クライアント・オブジェクトとの間の異なるタイプのデータのためのデータ変換を実行する、前記ラッピング手段と、
    前記サーバ・オブジェクト内の前記メソッドを前記クライアント・オブジェクトによって呼び出す呼び出し手段であって、前記呼び出しは前記アダプタのメソッドを呼び出し、前記アダプタ内で呼び出された前記アダプタの前記メソッドは、前記サーバ・オブジェクト内の前記メソッドに対応する、前記呼び出し手段と、
    前記オブジェクト参照内のメソッドを、前記アダプタ内で呼び出された前記メソッドによって呼び出す呼び出し手段であって、前記オブジェクト参照内の前記メソッドは前記アダプタ内で呼び出された前記メソッドに対応する、前記呼び出し手段と、
    前記サーバ・オブジェクト内の前記メソッドを、前記オブジェクト参照によって呼び出す呼び出し手段であって、前記アダプタは、前記クライアント・オブジェクトが前記オブジェクト参照の操作に気づかないように、前記オブジェクト参照を用いて前記クライアント・オブジェクトに透過的に前記サーバ・オブジェクト内の前記メソッドを呼び出す、前記呼び出し手段と、
    を含み、前記アダプタが前記第2のプログラミング環境から前記クライアント・オブジェクトを分離し、且つ前記第1のプログラミング環境から前記オブジェクト参照を分離し、
    前記オブジェクト参照と前記クライアント・オブジェクトとの間の前記異なるタイプのデータのためのデータ変換を実行するために、更に
    前記クライアント・オブジェクトによって呼び出されたメソッドを受信することに応答して、引き数について前記呼び出されたメソッドを解析する手段と、
    必要に応じて前記引き数に対してデータ変換を実行する手段と、
    前記引き数がアダプタによってラップされているかどうかを決定する手段と、
    前記引き数がアダプタによってラップされている場合、前記引き数から前記アダプタをラップ解除して、前記引き数のオブジェクト参照を獲得する手段であって、前記引き数の前記オブジェクト参照が、前記引き数を表す前記第2のプログラミング環境におけるサーバ・オブジェクトへの参照を提供する手段と、
    前記クライアント・オブジェクトによって呼び出された前記メソッドを、前記引き数の前記オブジェクト参照を引き数として前記サーバ・オブジェクトのための前記オブジェクト参照に委託する手段と、
    戻り値を検出することに応答して、前記戻り値が前記第2のプログラミング環境のためのオブジェクト参照であるかどうかを決定する手段と、
    前記戻り値が前記第2のプログラミング環境のためのオブジェクト参照である場合、前記オブジェクト参照を前記オブジェクト参照のタイプに基づき適切なアダプタでラップする手段と、
    前記ラップされたオブジェクト参照を前記クライアント・オブジェクトに返す手段と
    を含む、データ処理システム。
  2. 前記アダプタが前記オブジェクト参照を使用して、前記サーバ上のスケルトンのメソッドを呼び出す、請求項1記載のデータ処理システム。
  3. 前記スケルトンが前記サーバ・オブジェクトのメソッドを呼び出す、請求項2記載のデータ処理システム。
  4. 分散データ処理システムにおいて分散アプリケーションを実装するデータ処理システムであって、
    第1のプログラミング環境を実装するクライアントにおいて、前記第1のプログラミング環境のために記述されたクライアント・オブジェクトを実行する実行手段と、
    前記第1のプログラミング環境と異なる第2のプログラミング環境を実装するサーバにおいて、前記第1のプログラミング環境のために記述されたサーバ・オブジェクトを実行する実行手段と、
    前記サーバ・オブジェクト内のメソッドを呼び出しするための試みを開始する前記クライアント・オブジェクトを実行する実行手段と、
    前記サーバ・オブジェクト内のメソッドを呼び出しするための試みを開始する前記クライアント・オブジェクトに応答して、前記サーバ・オブジェクトのプロキシを前記クライアント上で獲得する獲得手段と、
    前記プロキシを前記クライアントのアダプタ内でラップするラッピング手段であって、前記アダプタは、前記プロキシクライアント・オブジェクトから分離し、かつ、前記プロキシと前記クライアント・オブジェクトとの間の異なるタイプのデータのためのデータ変換を実行する、前記ラッピング手段と、
    前記アダプタのメソッドを呼び出す呼び出し手段であって、前記アダプタは前記プロキシ内のメソッドに対応するメソッドを呼び出す、前記呼び出し手段と
    を含み、
    前記プロキシと前記クライアント・オブジェクトとの間の前記異なるタイプのデータのためのデータ変換を実行するために、更に
    前記クライアント・オブジェクトによって呼び出されたメソッドを受信することに応答して、引き数について前記呼び出されたメソッドを解析する手段と、
    必要に応じて前記引き数に対してデータ変換を実行する手段と、
    前記引き数がアダプタによってラップされているかどうかを決定する手段と、
    前記引き数がアダプタによってラップされている場合、前記引き数から前記アダプタをラップ解除して、前記引き数のプロキシを獲得する手段であって、前記引き数の前記プロキシが、前記引き数を表す前記第2のプログラミング環境におけるサーバ・オブジェクトへの参照を提供する手段と、
    前記クライアント・オブジェクトによって呼び出された前記メソッドを、前記引き数の前記プロキシを引き数として前記サーバ・オブジェクトの前記プロキシに委託する手段と、
    戻り値を検出することに応答して、前記戻り値が前記第2のプログラミング環境のためのプロキシであるかどうかを決定する手段と、
    前記戻り値が前記第2のプログラミング環境のためのプロキシである場合、前記プロキシを前記プロキシのタイプに基づき適切なアダプタでラップする手段と、
    前記ラップされたプロキシを前記クライアント・オブジェクトに返す手段と
    を含む、データ処理システム。
  5. 前記アダプタが、前記サーバ・オブジェクトによりサポートされるインタフェースを実装するJavaクラスである、請求項4記載のデータ処理システム。
  6. 前記サーバ・オブジェクトがEnterprise Java Beanである、請求項4記載のデータ処理システム。
  7. 前記オブジェクト参照が命名サービスから獲得される、請求項4記載のデータ処理システム。
  8. 前記プロキシがCORBAプロキシである、請求項4記載のデータ処理システム。
  9. 前記アダプタが前記CORBAプロキシのメソッドを呼び出す、請求項8記載のデータ処理システム。
  10. 前記CORBAプロキシがクライアント・コンピュータ上に存在するJavaクラスである、請求項8記載のデータ処理システム。
  11. 前記CORBAプロキシがメソッド要求をオブジェクト・リクエスト・ブローカに受け渡す、請求項8記載のデータ処理システム。
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 JP2000250768A (ja) 2000-09-14
JP4146983B2 true 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)

Families Citing this family (110)

* 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
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
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
WO2002054263A1 (fr) 2000-12-28 2002-07-11 Future System Consulting Corp. Systeme de structure
US7493391B2 (en) 2001-02-12 2009-02-17 International Business Machines Corporation System for automated session resource clean-up by determining whether server resources have been held by client longer than preset thresholds
US20030097345A1 (en) 2001-10-18 2003-05-22 Mitch Upton System and method for invoking business functionality for a workflow
KR100490750B1 (ko) * 2001-12-27 2005-05-24 한국전자통신연구원 Ejb 영속 상태 객체로 표현된 데이터베이스 엔터티들의자동화된 상호관계 관리 방법
KR100426311B1 (ko) * 2001-12-28 2004-04-08 한국전자통신연구원 Ejb 컴포넌트 조립 장치 및 방법
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
US7519976B2 (en) 2002-05-01 2009-04-14 Bea Systems, Inc. Collaborative business plug-in framework
US8135772B2 (en) 2002-05-01 2012-03-13 Oracle International Corporation Single servlets for B2B message routing
US7257645B2 (en) * 2002-05-01 2007-08-14 Bea Systems, Inc. System and method for storing large messages
US7350184B2 (en) 2002-05-02 2008-03-25 Bea Systems, Inc. System and method for enterprise application interactions
US7627631B2 (en) 2002-05-02 2009-12-01 Bea Systems, Inc. Systems and methods for collaborative business plug-ins
US7484224B2 (en) * 2002-05-02 2009-01-27 Bae Systems, Inc. Adapter deployment without recycle
US7165249B2 (en) * 2002-05-02 2007-01-16 Bea Systems, Inc. Systems and methods for modular component deployment
US7676538B2 (en) * 2002-05-02 2010-03-09 Bea Systems, Inc. Systems and methods for application view transactions
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
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
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
US7076772B2 (en) 2003-02-26 2006-07-11 Bea Systems, Inc. System and method for multi-language extensible compiler framework
US7299454B2 (en) 2003-02-26 2007-11-20 Bea Systems, Inc. Method for multi-language debugging
US7539985B2 (en) 2003-02-26 2009-05-26 Bea Systems, Inc. Systems and methods for dynamic component versioning
US7707564B2 (en) * 2003-02-26 2010-04-27 Bea Systems, Inc. Systems and methods for creating network-based software services using source code annotations
US7650276B2 (en) 2003-02-26 2010-01-19 Bea Systems, Inc. System and method for dynamic data binding in distributed applications
US7636722B2 (en) 2003-02-28 2009-12-22 Bea Systems, Inc. System and method for describing application extensions in XML
US20040225995A1 (en) * 2003-02-28 2004-11-11 Kyle Marvin Reusable software controls
US7650592B2 (en) * 2003-03-01 2010-01-19 Bea Systems, Inc. Systems and methods for multi-view debugging environment
US7480921B1 (en) 2003-03-12 2009-01-20 Microsoft Corporation Method, system, and apparatus for customizing web parts
US7281252B1 (en) * 2003-03-12 2007-10-09 Microsoft Corporation Method, system, and apparatus for implementing object interfaces at runtime
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
US8266631B1 (en) 2004-10-28 2012-09-11 Curen Software Enterprises, L.L.C. Calling a second functionality by a first functionality
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
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
US8141106B2 (en) * 2004-12-01 2012-03-20 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
EP1875664B1 (en) * 2005-04-15 2010-02-24 Esprida Corporation Apparatus and method for managing a network of intelligent devices
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
US10324735B2 (en) * 2006-05-15 2019-06-18 Avaya Inc. Method invocation for persistent objects with dynamic multikeys
US10185579B2 (en) 2006-05-15 2019-01-22 Avaya Inc. Dynamic multikeys for persistent objects
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
US20080072069A1 (en) * 2006-09-15 2008-03-20 Emc Corporation Protecting client-side code
US8250178B2 (en) * 2006-09-15 2012-08-21 Emc Corporation Protecting client-side code
GB0624168D0 (en) * 2006-12-04 2007-01-10 Axiom Systems Ltd Service assembly and delivery
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
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
US7698243B1 (en) 2006-12-22 2010-04-13 Hauser Robert R Constructing an agent in a first execution environment using canonical rules
US9311141B2 (en) 2006-12-22 2016-04-12 Callahan Cellular L.L.C. Survival rule usage by software agents
US7970724B1 (en) 2006-12-22 2011-06-28 Curen Software Enterprises, L.L.C. Execution of a canonical rules based agent
US7660777B1 (en) 2006-12-22 2010-02-09 Hauser Robert R Using data narrowing rule for data packaging requirement of an agent
US8200603B1 (en) 2006-12-22 2012-06-12 Curen Software Enterprises, L.L.C. Construction of an agent that utilizes as-needed canonical 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
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
US8423496B1 (en) 2006-12-22 2013-04-16 Curen Software Enterprises, L.L.C. Dynamic determination of needed agent 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
US7860517B1 (en) 2006-12-22 2010-12-28 Patoskie John P Mobile device tracking using mobile agent location breadcrumbs
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
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
US8904002B2 (en) * 2007-09-28 2014-12-02 International Business Machines Corporation Reducing overhead in component interactions
US8949423B2 (en) * 2007-09-28 2015-02-03 International Business Machines Corporation Autonomically co-locating first and second components on a select server
US8849897B2 (en) * 2007-11-15 2014-09-30 Microsoft Corporation Delegating application invocation back to client
KR100884435B1 (ko) * 2007-12-05 2009-02-19 정안모 객체지향 기반 서비스 컴포넌트의 특정 애플리케이션비즈니스 엔티티에 대한 종속성 제거 방법
JP4862026B2 (ja) * 2008-09-05 2012-01-25 キヤノン株式会社 画像形成装置、画像形成装置の制御方法、及び、制御プログラム
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
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
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
US8997124B2 (en) 2011-09-02 2015-03-31 Compuverde Ab Method for updating data in a distributed data storage system
US8645978B2 (en) 2011-09-02 2014-02-04 Compuverde Ab Method for data maintenance
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
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
WO2016065621A1 (en) * 2014-10-31 2016-05-06 Hewlett-Packard Development Company,L.P. Proxies for native code access
CN112311567B (zh) * 2019-07-26 2022-04-05 华为技术有限公司 一种通信方法及装置
CN112035276A (zh) * 2020-08-06 2020-12-04 上海视云网络科技有限公司 一种基于java的跨平台可扩展的RPC框架设计方法

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

Also Published As

Publication number Publication date
US20040111730A1 (en) 2004-06-10
JP2000250768A (ja) 2000-09-14
US6959307B2 (en) 2005-10-25

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
JP3072709B2 (ja) 要求伝達方法
US6044224A (en) Mechanism for dynamically associating a service dependent representation with objects at run time
US6260078B1 (en) Using a distributed object system to find and download java-based applications
US5737607A (en) Method and apparatus for allowing generic stubs to marshal and unmarshal data in object reference specific data formats
US5732270A (en) System and method for providing interoperability among heterogeneous object systems
JP2978807B2 (ja) 遠隔プロシージャ・コール・システムおよび方法
US8359570B2 (en) Adaptive scripting tool
US7533388B1 (en) Method and apparatus for dynamic Stubs and Ties in RMI-IIOP
US20030182457A1 (en) Method and apparatus for generating a code bridge
US20010037417A1 (en) Method and system for dynamically dispatching function calls from a first execution environment to a second execution environment
GB2326255A (en) Automatic object distribution enables remote running of objects using local method calls
Oberleitner et al. The Vienna Component Framework enabling composition across component models
Chiang Wrapping legacy systems for use in heterogeneous computing environments
Turtschi et al. C#. Net Developer's Guide
Pautet et al. CORBA & DSA: Divorce or marriage?
Pautet et al. GLADE users guide
Van Heiningen et al. Exploiting dynamic proxies in middleware for distributed, parallel, and mobile Java applications
US7596572B1 (en) Methods and apparatus for providing a categorical approach to valuetype bridge support
Mykkänen et al. Component and Service Technology Families
Akbay et al. Design and implementation of an enterprise information system utilizing a component based three-tier client/server database system
Cerqueira et al. Binding an interpreted language to CORBA
Zhang A comparative study of DCOM/CORBA and. NET/J2EE

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