Interstage Application Server アプリケーション作成ガイド (データベース連携サービス編) |
目次 索引 |
第5章 サーバアプリケーションの開発(CORBAアプリケーション/C++言語) |
サーバアプリケーションをCORBAサービスのインプリメンテーションリポジトリとネーミングサービスへ登録する必要があります。登録は、OD_impl_instコマンド、OD_or_admコマンドを使用して行ってください。
インプリメンテーションリポジトリとネーミングサービスへの登録については以下に示します。
OD_impl_instコマンドを使用して、インプリメンテーションリポジトリにサーバアプリケーション情報を登録します。OD_impl_instコマンドの詳細については、“リファレンスマニュアル(コマンド編)”を参照してください。
OD_impl_inst -ax defname |
なお、OD_impl_instコマンドを実行する場合に指定するインプリメンテーション情報定義ファイルのアプリケーション固有データには、以下のようにサーバアプリケーションが使用するリソース定義ファイルを指定する必要があります。
アプリケーション固有データ(項目名:data)はダブルクォーテーションで囲んで、"RESOURCE:[RM名:]リソース定義名"と指定してください。扱うリソースが1個の場合にはRM名を省略することが可能です。なお、アプリケーションをマルチプロセス運用する場合、thr_conc_initに1を指定してください。
rep_id = IDL:ODdemo/calculator:1.0 proc_conc_max = 8 |
rep_id = IDL:ODdemo/calculator:1.0 proc_conc_max = 8 mode = SYNC_END |
rep_id = IDL:ODdemo/calculator:1.0 proc_conc_max = 8 mode = SYNC_END |
また、サーバアプリケーションが複数のリソースを扱う場合、data行の書式は以下のとおりです。
data="RESOURCE:Rmname1:defname1;Rmname2:defname2; ... ;RmnameN:defnameN" |
defnameNはリソース定義名、RMnameNはリソース定義名defnameNに対応したRM名です。また、RM名は対応したリソース定義ファイルに記述されているRM名と同一である必要があります。
1つのサーバアプリケーションが複数のリソースにアクセスするためのインプリメンテーション情報定義ファイル例を、以下に示します。
rep_id = IDL:ODdemo/calculator:1.0 |
rep_id = IDL:ODdemo/calculator:1.0 mode = SYNC_END |
rep_id = IDL:ODdemo/calculator:1.0 mode = SYNC_END |
上記の例は、サーバアプリケーションが2つのデータベースSymfoware/RDBと、Oracleにアクセスするために、data行に2つのリソース定義ファイルを設定しています。
複数のリソース定義ファイルを指定した定義書式によって登録されたアプリケーションは、複数リソースアクセス用のXA連携用ライブラリと結合されたサーバアプリケーションである必要があります。
また、OD_impl_instコマンドはサーバアプリケーション情報を削除することもできます。削除処理の例を以下に示します。
OD_impl_inst -d -r IDL:ODdemo/calculator:1.0 |
サーバアプリケーションを他のアプリケーションからアクセス可能にするためには、目的のアプリケーションを識別するためのオブジェクトリファレンスを作成する必要があります。また、同時に作成したオブジェクトリファレンスをネーミングサービスに登録することによって、他のアプリケーションからのアクセスが可能になります。
サーバアプリケーションのオブジェクトリファレンスの作成方法とネーミングサービスへの登録方法について、以下に説明します。
OD_or_admコマンド(ORBの管理コマンド)は、オブジェクトリファレンス作成後、ネーミングサービスに登録します。OD_or_admコマンドでの登録例と指定する情報を、以下に示します。
OD_or_adm -c IDL:ODdemo/calculator:1.0 -n ODdemo::calculator |
OD_or_admコマンドの詳細については、“リファレンスマニュアル(コマンド編)”を参照してください。
CORBA::ORB_ptr orb; //ORB::initで取得したObject CORBA::Environment *env = new CORBA::Environment(); CORBA::release(obj); CORBA::release(obj); CORBA::release(obj); CORBA::release(obj); // オブジェクトリファレンスの作成 NamingContext_obj->bind(*name,new_obj,*env); |
目次 索引 |