1 '\" t
   2 .\" Copyright (c) 1999, 2013, Oracle and/or its affiliates. All rights reserved.
   3 .\" Title: tnameserv
   4 .\" Language: English
   5 .\" Date: 2013年11月21日
   6 .\" SectDesc: Java IDLおよびRMI-IIOPツール
   7 .\" Software: JDK 8
   8 .\" Arch: 汎用
   9 .\"
  10 .\" DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
  11 .\"
  12 .\" This code is free software; you can redistribute it and/or modify it
  13 .\" under the terms of the GNU General Public License version 2 only, as
  14 .\" published by the Free Software Foundation.
  15 .\"
  16 .\" This code is distributed in the hope that it will be useful, but WITHOUT
  17 .\" ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
  18 .\" FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
  19 .\" version 2 for more details (a copy is included in the LICENSE file that
  20 .\" accompanied this code).
  21 .\"
  22 .\" You should have received a copy of the GNU General Public License version
  23 .\" 2 along with this work; if not, write to the Free Software Foundation,
  24 .\" Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
  25 .\"
  26 .\" Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
  27 .\" or visit www.oracle.com if you need additional information or have any
  28 .\" questions.
  29 .\"
  30 .pl 99999
  31 .TH "tnameserv" "1" "2013年11月21日" "JDK 8" "Java IDLおよびRMI-IIOPツール"
  32 .\" -----------------------------------------------------------------
  33 .\" * Define some portability stuff
  34 .\" -----------------------------------------------------------------
  35 .\" ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
  36 .\" http://bugs.debian.org/507673
  37 .\" http://lists.gnu.org/archive/html/groff/2009-02/msg00013.html
  38 .\" ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
  39 .ie \n(.g .ds Aq \(aq
  40 .el       .ds Aq '
  41 .\" -----------------------------------------------------------------
  42 .\" * set default formatting
  43 .\" -----------------------------------------------------------------
  44 .\" disable hyphenation
  45 .nh
  46 .\" disable justification (adjust text to left margin only)
  47 .ad l
  48 .\" -----------------------------------------------------------------
  49 .\" * MAIN CONTENT STARTS HERE *
  50 .\" -----------------------------------------------------------------
  51 .SH "NAME"
  52 tnameserv \- インタフェース定義言語(IDL)。
  53 .SH "概要"
  54 .sp
  55 .if n \{\
  56 .RS 4
  57 .\}
  58 .nf
  59 \fItnameserve\fR \fI\-ORBInitialPort\fR [ \fInameserverport\fR ]
  60 .fi
  61 .if n \{\
  62 .RE
  63 .\}
  64 .PP
  65 \-ORBInitialPort \fInameserverport\fR
  66 .RS 4
  67 ネーミング・サービスがORBの\fIresolve_initial_references\fRメソッドと\fIlist_initial_references\fRメソッドの実装に使用するブートストラップ・プロトコルをリスニングする初期ポートです。
  68 .RE
  69 .SH "説明"
  70 .PP
  71 Java IDLには、Object Request Broker Daemon (ORBD)が含まれます。ORBDは、ブートストラップ・サービス、一時ネーミング・サービス、永続ネーミング・サービスおよびサーバー・マネージャを含むデーモン・プロセスです。Java IDLのすべてのチュートリアルではORBDを使用していますが、一時ネーミング・サービスを使用する例では、\fIorbd\fRのかわりに\fItnameserv\fRを使用できます。
  72 .PP
  73 http://docs\&.oracle\&.com/javase/8/docs/technotes/guides/idl/jidlNaming\&.htmlにある
  74 orbd(1)または「Naming Service」を参照してください。
  75 .PP
  76 CORBAのCOS (Common Object Services)ネーミング・サービスは、ファイル・システムがファイルに対してディレクトリ構造を提供しているのと同じように、オブジェクト参照に対してツリー構造のディレクトリを提供します。Java IDLの一時ネーム・サービスである\fItnameserv\fRは、COSネーム・サービスの仕様を単純な形で実装したものです。
  77 .PP
  78 オブジェクト参照はネームスペースに名前で格納され、オブジェクト参照と名前のペアは、それぞれネーム・バインディングと呼ばれます。ネーム・バインディングはネーミング・コンテキストに組み込むことができます。ネーミング・コンテキストはネーム・バインディングであり、ファイル・システムのサブディレクトリと同じ編成機能を持ちます。すべてのバインディングは初期ネーミング・コンテキストの下に格納されます。初期ネーミング・コンテキストは、ネームスペースの唯一の永続バインディングです。Java IDLネーミング・サービス・プロセスを停止して再起動すると、残りのネームスペースは失われます。
  79 .PP
  80 アプレットまたはアプリケーションからCOSネーミング・サービスを使用するためには、そのORBがネーミング・サービスが動作しているホストのポートを知っているか、そのネーミング・サービスの初期ネーミング・コンテキスト文字列にアクセスできる必要があります。ネーム・サービスは、Java IDLのネーム・サービスでもその他のCOS準拠のネーム・サービスでもかまいません。
  81 .SS "ネーミング・サービスの起動"
  82 .PP
  83 Java IDLネーム・サービスは、ネーム・サービスを使用するアプリケーションまたはアプレットより前に起動しておく必要があります。Java IDL製品をインストールすると、Java IDLネーミング・サービスを起動するスクリプト(Oracle Solaris:
  84 \fItnameserv\fR)または実行可能ファイル(Windows:
  85 \fItnameserv\&.exe\fR)が作成されます。バックグラウンドで動作するように、ネーム・サービスを起動してください。
  86 .PP
  87 特に指定しない場合、Java IDLネーミング・サービスは、ORBの\fIresolve_initial_references\fRメソッドと\fIlist_initial_references methods\fRメソッドの実装に使用するブートストラップ・プロトコルに対してポート900でリスニングします。
  88 .sp
  89 .if n \{\
  90 .RS 4
  91 .\}
  92 .nf
  93 tnameserv \-ORBInitialPort nameserverport&
  94 .fi
  95 .if n \{\
  96 .RE
  97 .\}
  98 .PP
  99 ネーム・サーバー・ポートを指定しない場合、デフォルトでポート900が使用されます。Oracle Solarisソフトウェアの実行時、1024より小さいポートでプロセスを開始する場合は、rootユーザーになる必要があります。このため、1024以上のポート番号を使用することをお薦めします。1050のように別のポートを指定し、ネーム・サービスをバックグラウンドで実行するには、UNIXコマンド・シェルで次のように入力します。
 100 .sp
 101 .if n \{\
 102 .RS 4
 103 .\}
 104 .nf
 105 tnameserv \-ORBInitialPort 1050&
 106 .fi
 107 .if n \{\
 108 .RE
 109 .\}
 110 .PP
 111 WindowsのMS\-DOSシステム・プロンプトでは、次のように入力します。
 112 .sp
 113 .if n \{\
 114 .RS 4
 115 .\}
 116 .nf
 117 start tnameserv \-ORBInitialPort 1050
 118 .fi
 119 .if n \{\
 120 .RE
 121 .\}
 122 .PP
 123 ネーム・サーバーのクライアントには、新しいポート番号を知らせる必要があります。これを行うには、ORBオブジェクトの作成時に\fIorg\&.omg\&.CORBA\&.ORBInitialPort\fRプロパティに新しいポート番号を設定します。
 124 .SS "異なるホスト上でのサーバーとクライアントの実行"
 125 .PP
 126 Java IDLとRMI\-IIOPのほとんどのチュートリアルでは、ネーミング・サービス、サーバーおよびクライアントはすべて開発用のマシン上で実行されます。実際にデプロイメントする場合には、クライアントとサーバーを、ネーミング・サービスとは異なるホスト・マシン上で実行することが多くなります。
 127 .PP
 128 クライアントとサーバーがネーム・サービスを見つけるには、クライアントとサーバーが、ネーム・サービスが実行されているポートの番号とホストを認識している必要があります。そのためには、クライアントとサーバーのファイル内の\fIorg\&.omg\&.CORBA\&.ORBInitialPort\fRプロパティと\fIorg\&.omg\&.CORBA\&.ORBInitialHost\fRプロパティをネーム・サービスが実行されているポートの番号とマシンの名前に設定します。この例は、「Getting Started Using RMI\-IIOP」
 129 (http://docs\&.oracle\&.com/javase/8/docs/technotes/guides/rmi\-iiop/rmiiiopexample\&.html)に示されています
 130 .PP
 131 コマンドライン・オプション\fI\-ORBInitialPort nameserverport#\fRと\fI\-ORBInitialHost nameserverhostname\fRを使用して、クライアントとサーバーに対してネーミング・サービスを探す場所を指定することもできます。コマンドライン・オプションを使用してこれを行う方法の1つの例は、http://docs\&.oracle\&.com/javase/8/docs/technotes/guides/idl/tutorial/jidl2machines\&.htmlの「Java IDL: The Hello World Example on Two Machines」
 132 を参照してください
 133 .PP
 134 たとえば、一時ネーム・サービス\fItnameserv\fRが、ホスト\fInameserverhost\fRのポート1050上で実行されているとします。さらに、クライアントがホスト\fIclienthost\fR上で実行され、サーバーはホスト\fIserverhost\fR上で実行されているとします。
 135 .PP
 136 ホスト\fInameserverhost\fR上で\fItnameserv\fRを起動します。
 137 .sp
 138 .if n \{\
 139 .RS 4
 140 .\}
 141 .nf
 142 tnameserv \-ORBInitialPort 1050
 143 .fi
 144 .if n \{\
 145 .RE
 146 .\}
 147 .PP
 148 \fIserverhost\fR上でサーバーを起動します。
 149 .sp
 150 .if n \{\
 151 .RS 4
 152 .\}
 153 .nf
 154 java Server \-ORBInitialPort 1050 \-ORBInitialHost nameserverhost
 155 .fi
 156 .if n \{\
 157 .RE
 158 .\}
 159 .PP
 160 
 161 \fIclienthost\fR上でクライアントを起動します。
 162 .sp
 163 .if n \{\
 164 .RS 4
 165 .\}
 166 .nf
 167 java Client \-ORBInitialPort 1050 \-ORBInitialHost nameserverhost
 168 .fi
 169 .if n \{\
 170 .RE
 171 .\}
 172 .SS "ネーミング・サービスの停止"
 173 .PP
 174 Java IDLネーミング・サービスを停止するには、Unixの場合は、\fIkill\fRなどのオペレーティング・システムのコマンドを使用し、Windowsの場合は、\fI[Ctrl]+[C]\fRキーを使用します。ネーミング・サービスを明示的に停止するまでは、呼出し待機状態が続きます。サービスを終了させると、Java IDLネーム・サービスに登録されている名前は失われます。
 175 .SH "オプション"
 176 .PP
 177 \-J\fIoption\fR
 178 .RS 4
 179 Java仮想マシンに\fIoption\fRを渡します。\fIoption\fRには、Javaアプリケーション起動ツールのリファレンス・ページに記載されているオプションを1つ指定します。たとえば、\fI\-J\-Xms48m\fRと指定すると、スタートアップ・メモリーは48MBに設定されます。java(1)を参照してください。
 180 .RE
 181 .SH "例"
 182 .SS "ネームスペースへのオブジェクトの追加"
 183 .PP
 184 次の例では、ネームスペースに名前を追加する方法を示します。このサンプル・プログラムは、このままの状態で完全に動作する一時ネーム・サービス・クライアントで、次のような単純なツリーを作成するものです。
 185 .sp
 186 .if n \{\
 187 .RS 4
 188 .\}
 189 .nf
 190 Initial Naming Context
 191      plans
 192      Personal
 193           calendar
 194           schedule
 195 .fi
 196 .if n \{\
 197 .RE
 198 .\}
 199 .PP
 200 この例で、\fIplans\fRはオブジェクト参照、\fIPersonal\fRは\fIcalendar\fRと\fIschedule\fRの2つのオブジェクト参照を含むネーミング・コンテキストです。
 201 .sp
 202 .if n \{\
 203 .RS 4
 204 .\}
 205 .nf
 206 import java\&.util\&.Properties;
 207 import org\&.omg\&.CORBA\&.*;
 208 import org\&.omg\&.CosNaming\&.*;
 209  
 210 public class NameClient {
 211 
 212     public static void main(String args[]) {
 213 
 214         try {
 215 .fi
 216 .if n \{\
 217 .RE
 218 .\}
 219 .PP
 220 ネーミング・サービスの起動で、\fInameserver\fRはポート1050で起動されました。次のコードで、このポート番号をクライアント・システムに知らせます。
 221 .sp
 222 .if n \{\
 223 .RS 4
 224 .\}
 225 .nf
 226             Properties props = new Properties();
 227             props\&.put("org\&.omg\&.CORBA\&.ORBInitialPort", "1050");
 228             ORB orb = ORB\&.init(args, props);
 229 .fi
 230 .if n \{\
 231 .RE
 232 .\}
 233 .PP
 234 次のコードでは、初期ネーミング・コンテキストを取得し、それを\fIctx\fRに代入します。2行目では、\fIctx\fRをダミーのオブジェクト参照\fIobjref\fRにコピーします。このobjrefには、あとで様々な名前を割り当ててネームスペースに追加します。
 235 .sp
 236 .if n \{\
 237 .RS 4
 238 .\}
 239 .nf
 240             NamingContext ctx =
 241                 NamingContextHelper\&.narrow(
 242                     orb\&.resolve_initial_references("NameService"));
 243              NamingContext objref = ctx;
 244 .fi
 245 .if n \{\
 246 .RE
 247 .\}
 248 .PP
 249 次のコードでは、\fItext\fRタイプの名前\fIplans\fRを作成し、それをダミーのオブジェクト参照にバインドします。その後、\fIrebind\fRメソッドを使用して初期ネーミング・コンテキストの下に\fIplans\fRを追加しています。\fIrebind\fRメソッドを使用すれば、\fIbind\fRメソッドを使用した場合に発生する例外を発生させずに、このプログラムを何度も繰返し実行できます。
 250 .sp
 251 .if n \{\
 252 .RS 4
 253 .\}
 254 .nf
 255             NameComponent nc1 = new NameComponent("plans", "text");
 256             NameComponent[] name1 = {nc1};
 257             ctx\&.rebind(name1, objref);
 258             System\&.out\&.println("plans rebind successful!");
 259 .fi
 260 .if n \{\
 261 .RE
 262 .\}
 263 .PP
 264 次のコードでは、\fIdirectory\fRタイプの\fIPersonal\fRというネーミング・コンテキストを作成します。その結果得られるオブジェクト参照\fIctx2\fRを\fIname\fRにバインドし、初期ネーミング・コンテキストに追加します。
 265 .sp
 266 .if n \{\
 267 .RS 4
 268 .\}
 269 .nf
 270             NameComponent nc2 = new NameComponent("Personal", "directory");
 271             NameComponent[] name2 = {nc2};
 272             NamingContext ctx2 = ctx\&.bind_new_context(name2);
 273             System\&.out\&.println("new naming context added\&.\&.");
 274 .fi
 275 .if n \{\
 276 .RE
 277 .\}
 278 .PP
 279 残りのコードでは、ダミーのオブジェクト参照を\fIschedule\fRと\fIcalendar\fRという名前でネーミング・コンテキスト\fIPersonal\fR(\fIctx2\fR)にバインドします。
 280 .sp
 281 .if n \{\
 282 .RS 4
 283 .\}
 284 .nf
 285             NameComponent nc3 = new NameComponent("schedule", "text");
 286             NameComponent[] name3 = {nc3};
 287             ctx2\&.rebind(name3, objref);
 288             System\&.out\&.println("schedule rebind successful!");
 289  
 290             NameComponent nc4 = new NameComponent("calender", "text");
 291             NameComponent[] name4 = {nc4};
 292             ctx2\&.rebind(name4, objref);
 293             System\&.out\&.println("calender rebind successful!");
 294         } catch (Exception e) {
 295             e\&.printStackTrace(System\&.err);
 296         }
 297     }
 298 }
 299 .fi
 300 .if n \{\
 301 .RE
 302 .\}
 303 .SS "ネームスペースの参照"
 304 .PP
 305 次のサンプル・プログラムでは、ネームスペースをブラウズする方法を示します。
 306 .sp
 307 .if n \{\
 308 .RS 4
 309 .\}
 310 .nf
 311 import java\&.util\&.Properties;
 312 import org\&.omg\&.CORBA\&.*;
 313 import org\&.omg\&.CosNaming\&.*;
 314  
 315 public class NameClientList {
 316 
 317     public static void main(String args[]) {
 318 
 319         try {
 320 .fi
 321 .if n \{\
 322 .RE
 323 .\}
 324 .PP
 325 ネーミング・サービスの起動で、\fInameserver\fRはポート1050で起動されました。次のコードで、このポート番号をクライアント・システムに知らせます。
 326 .sp
 327 .if n \{\
 328 .RS 4
 329 .\}
 330 .nf
 331             Properties props = new Properties();
 332             props\&.put("org\&.omg\&.CORBA\&.ORBInitialPort", "1050");
 333             ORB orb = ORB\&.init(args, props);
 334 .fi
 335 .if n \{\
 336 .RE
 337 .\}
 338 .PP
 339 次のコードでは、初期ネーミング・コンテキストを取得しています。
 340 .sp
 341 .if n \{\
 342 .RS 4
 343 .\}
 344 .nf
 345             NamingContext nc =
 346             NamingContextHelper\&.narrow(
 347                 orb\&.resolve_initial_references("NameService"));
 348 .fi
 349 .if n \{\
 350 .RE
 351 .\}
 352 .PP
 353 \fIlist\fRメソッドは、ネーミング・コンテキストのバインディングをリストします。この場合、最大1000個までのバインディングが初期ネーミング・コンテキストから\fIBindingListHolder\fRに返されます。残りのバインディングは、\fIBindingIteratorHolder\fRに返されます。
 354 .sp
 355 .if n \{\
 356 .RS 4
 357 .\}
 358 .nf
 359             BindingListHolder bl = new BindingListHolder();
 360             BindingIteratorHolder blIt= new BindingIteratorHolder();
 361             nc\&.list(1000, bl, blIt);
 362 .fi
 363 .if n \{\
 364 .RE
 365 .\}
 366 .PP
 367 次のコードでは、返された\fIBindingListHolder\fRからバインディングの配列を取得します。バインディングがない場合は、プログラムが終了します。
 368 .sp
 369 .if n \{\
 370 .RS 4
 371 .\}
 372 .nf
 373             Binding bindings[] = bl\&.value;
 374             if (bindings\&.length == 0) return;
 375 .fi
 376 .if n \{\
 377 .RE
 378 .\}
 379 .PP
 380 残りのコードでは、バインディングに対してループ処理を行い、名前を出力します。
 381 .sp
 382 .if n \{\
 383 .RS 4
 384 .\}
 385 .nf
 386             for (int i=0; i < bindings\&.length; i++) {
 387  
 388                 // get the object reference for each binding
 389                 org\&.omg\&.CORBA\&.Object obj = nc\&.resolve(bindings[i]\&.binding_name);
 390                 String objStr = orb\&.object_to_string(obj);
 391                 int lastIx = bindings[i]\&.binding_name\&.length\-1;
 392  
 393                 // check to see if this is a naming context
 394                 if (bindings[i]\&.binding_type == BindingType\&.ncontext) {
 395                     System\&.out\&.println("Context: " +
 396                         bindings[i]\&.binding_name[lastIx]\&.id);
 397                 } else {
 398                     System\&.out\&.println("Object: " +
 399                         bindings[i]\&.binding_name[lastIx]\&.id);
 400                 }
 401             }
 402         } catch (Exception e) {
 403             e\&.printStackTrace(System\&.err)
 404         }
 405     }
 406 }
 407 .fi
 408 .if n \{\
 409 .RE
 410 .\}
 411 .SH "関連項目"
 412 .sp
 413 .RS 4
 414 .ie n \{\
 415 \h'-04'\(bu\h'+03'\c
 416 .\}
 417 .el \{\
 418 .sp -1
 419 .IP \(bu 2.3
 420 .\}
 421 orbd(1)
 422 .RE
 423 .br
 424 'pl 8.5i
 425 'bp