tnameserv.1 14.7 KB
Newer Older
M
mfang 已提交
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59
'\" t
.\" Copyright (c) 1999, 2013, Oracle and/or its affiliates. All rights reserved.
.\" Title: tnameserv
.\" Language: English
.\" Date: 2013年11月21日
.\" SectDesc: Java IDLおよびRMI-IIOPツール
.\" Software: JDK 8
.\" Arch: 汎用
.\"
.\" DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
.\"
.\" This code is free software; you can redistribute it and/or modify it
.\" under the terms of the GNU General Public License version 2 only, as
.\" published by the Free Software Foundation.
.\"
.\" This code is distributed in the hope that it will be useful, but WITHOUT
.\" ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
.\" FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
.\" version 2 for more details (a copy is included in the LICENSE file that
.\" accompanied this code).
.\"
.\" You should have received a copy of the GNU General Public License version
.\" 2 along with this work; if not, write to the Free Software Foundation,
.\" Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
.\"
.\" Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
.\" or visit www.oracle.com if you need additional information or have any
.\" questions.
.\"
.pl 99999
.TH "tnameserv" "1" "2013年11月21日" "JDK 8" "Java IDLおよびRMI-IIOPツール"
.\" -----------------------------------------------------------------
.\" * Define some portability stuff
.\" -----------------------------------------------------------------
.\" ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
.\" http://bugs.debian.org/507673
.\" http://lists.gnu.org/archive/html/groff/2009-02/msg00013.html
.\" ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
.ie \n(.g .ds Aq \(aq
.el       .ds Aq '
.\" -----------------------------------------------------------------
.\" * set default formatting
.\" -----------------------------------------------------------------
.\" disable hyphenation
.nh
.\" disable justification (adjust text to left margin only)
.ad l
.\" -----------------------------------------------------------------
.\" * MAIN CONTENT STARTS HERE *
.\" -----------------------------------------------------------------
.SH "NAME"
tnameserv \- インタフェース定義言語(IDL)。
.SH "概要"
.sp
.if n \{\
.RS 4
.\}
.nf
\fItnameserve\fR \fI\-ORBInitialPort\fR [ \fInameserverport\fR ]
D
duke 已提交
60
.fi
M
mfang 已提交
61
.if n \{\
D
duke 已提交
62
.RE
M
mfang 已提交
63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91
.\}
.PP
\-ORBInitialPort \fInameserverport\fR
.RS 4
ネーミング・サービスがORBの\fIresolve_initial_references\fRメソッドと\fIlist_initial_references\fRメソッドの実装に使用するブートストラップ・プロトコルをリスニングする初期ポートです。
.RE
.SH "説明"
.PP
Java IDLには、Object Request Broker Daemon (ORBD)が含まれます。ORBDは、ブートストラップ・サービス、一時ネーミング・サービス、永続ネーミング・サービスおよびサーバー・マネージャを含むデーモン・プロセスです。Java IDLのすべてのチュートリアルではORBDを使用していますが、一時ネーミング・サービスを使用する例では、\fIorbd\fRのかわりに\fItnameserv\fRを使用できます。
.PP
http://docs\&.oracle\&.com/javase/8/docs/technotes/guides/idl/jidlNaming\&.htmlにある
orbd(1)または「Naming Service」を参照してください。
.PP
CORBAのCOS (Common Object Services)ネーミング・サービスは、ファイル・システムがファイルに対してディレクトリ構造を提供しているのと同じように、オブジェクト参照に対してツリー構造のディレクトリを提供します。Java IDLの一時ネーム・サービスである\fItnameserv\fRは、COSネーム・サービスの仕様を単純な形で実装したものです。
.PP
オブジェクト参照はネームスペースに名前で格納され、オブジェクト参照と名前のペアは、それぞれネーム・バインディングと呼ばれます。ネーム・バインディングはネーミング・コンテキストに組み込むことができます。ネーミング・コンテキストはネーム・バインディングであり、ファイル・システムのサブディレクトリと同じ編成機能を持ちます。すべてのバインディングは初期ネーミング・コンテキストの下に格納されます。初期ネーミング・コンテキストは、ネームスペースの唯一の永続バインディングです。Java IDLネーミング・サービス・プロセスを停止して再起動すると、残りのネームスペースは失われます。
.PP
アプレットまたはアプリケーションからCOSネーミング・サービスを使用するためには、そのORBがネーミング・サービスが動作しているホストのポートを知っているか、そのネーミング・サービスの初期ネーミング・コンテキスト文字列にアクセスできる必要があります。ネーム・サービスは、Java IDLのネーム・サービスでもその他のCOS準拠のネーム・サービスでもかまいません。
.SS "ネーミング・サービスの起動"
.PP
Java IDLネーム・サービスは、ネーム・サービスを使用するアプリケーションまたはアプレットより前に起動しておく必要があります。Java IDL製品をインストールすると、Java IDLネーミング・サービスを起動するスクリプト(Oracle Solaris:
\fItnameserv\fR)または実行可能ファイル(Windows:
\fItnameserv\&.exe\fR)が作成されます。バックグラウンドで動作するように、ネーム・サービスを起動してください。
.PP
特に指定しない場合、Java IDLネーミング・サービスは、ORBの\fIresolve_initial_references\fRメソッドと\fIlist_initial_references methods\fRメソッドの実装に使用するブートストラップ・プロトコルに対してポート900でリスニングします。
.sp
.if n \{\
.RS 4
.\}
D
duke 已提交
92
.nf
M
mfang 已提交
93
tnameserv \-ORBInitialPort nameserverport&
D
duke 已提交
94
.fi
M
mfang 已提交
95 96 97 98 99 100 101 102 103
.if n \{\
.RE
.\}
.PP
ネーム・サーバー・ポートを指定しない場合、デフォルトでポート900が使用されます。Oracle Solarisソフトウェアの実行時、1024より小さいポートでプロセスを開始する場合は、rootユーザーになる必要があります。このため、1024以上のポート番号を使用することをお薦めします。1050のように別のポートを指定し、ネーム・サービスをバックグラウンドで実行するには、UNIXコマンド・シェルで次のように入力します。
.sp
.if n \{\
.RS 4
.\}
D
duke 已提交
104
.nf
M
mfang 已提交
105
tnameserv \-ORBInitialPort 1050&
D
duke 已提交
106
.fi
M
mfang 已提交
107 108 109 110 111 112 113 114 115
.if n \{\
.RE
.\}
.PP
WindowsのMS\-DOSシステム・プロンプトでは、次のように入力します。
.sp
.if n \{\
.RS 4
.\}
D
duke 已提交
116
.nf
M
mfang 已提交
117
start tnameserv \-ORBInitialPort 1050
D
duke 已提交
118
.fi
M
mfang 已提交
119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140
.if n \{\
.RE
.\}
.PP
ネーム・サーバーのクライアントには、新しいポート番号を知らせる必要があります。これを行うには、ORBオブジェクトの作成時に\fIorg\&.omg\&.CORBA\&.ORBInitialPort\fRプロパティに新しいポート番号を設定します。
.SS "異なるホスト上でのサーバーとクライアントの実行"
.PP
Java IDLとRMI\-IIOPのほとんどのチュートリアルでは、ネーミング・サービス、サーバーおよびクライアントはすべて開発用のマシン上で実行されます。実際にデプロイメントする場合には、クライアントとサーバーを、ネーミング・サービスとは異なるホスト・マシン上で実行することが多くなります。
.PP
クライアントとサーバーがネーム・サービスを見つけるには、クライアントとサーバーが、ネーム・サービスが実行されているポートの番号とホストを認識している必要があります。そのためには、クライアントとサーバーのファイル内の\fIorg\&.omg\&.CORBA\&.ORBInitialPort\fRプロパティと\fIorg\&.omg\&.CORBA\&.ORBInitialHost\fRプロパティをネーム・サービスが実行されているポートの番号とマシンの名前に設定します。この例は、「Getting Started Using RMI\-IIOP」
(http://docs\&.oracle\&.com/javase/8/docs/technotes/guides/rmi\-iiop/rmiiiopexample\&.html)に示されています
.PP
コマンドライン・オプション\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」
を参照してください
.PP
たとえば、一時ネーム・サービス\fItnameserv\fRが、ホスト\fInameserverhost\fRのポート1050上で実行されているとします。さらに、クライアントがホスト\fIclienthost\fR上で実行され、サーバーはホスト\fIserverhost\fR上で実行されているとします。
.PP
ホスト\fInameserverhost\fR上で\fItnameserv\fRを起動します。
.sp
.if n \{\
.RS 4
.\}
D
duke 已提交
141
.nf
M
mfang 已提交
142
tnameserv \-ORBInitialPort 1050
D
duke 已提交
143
.fi
M
mfang 已提交
144 145 146 147 148 149 150 151 152
.if n \{\
.RE
.\}
.PP
\fIserverhost\fR上でサーバーを起動します。
.sp
.if n \{\
.RS 4
.\}
D
duke 已提交
153
.nf
M
mfang 已提交
154
java Server \-ORBInitialPort 1050 \-ORBInitialHost nameserverhost
D
duke 已提交
155
.fi
M
mfang 已提交
156 157 158 159 160 161 162 163 164 165
.if n \{\
.RE
.\}
.PP

\fIclienthost\fR上でクライアントを起動します。
.sp
.if n \{\
.RS 4
.\}
D
duke 已提交
166
.nf
M
mfang 已提交
167
java Client \-ORBInitialPort 1050 \-ORBInitialHost nameserverhost
D
duke 已提交
168
.fi
M
mfang 已提交
169
.if n \{\
D
duke 已提交
170
.RE
M
mfang 已提交
171 172 173 174 175 176 177 178 179
.\}
.SS "ネーミング・サービスの停止"
.PP
Java IDLネーミング・サービスを停止するには、Unixの場合は、\fIkill\fRなどのオペレーティング・システムのコマンドを使用し、Windowsの場合は、\fI[Ctrl]+[C]\fRキーを使用します。ネーミング・サービスを明示的に停止するまでは、呼出し待機状態が続きます。サービスを終了させると、Java IDLネーム・サービスに登録されている名前は失われます。
.SH "オプション"
.PP
\-J\fIoption\fR
.RS 4
Java仮想マシンに\fIoption\fRを渡します。\fIoption\fRには、Javaアプリケーション起動ツールのリファレンス・ページに記載されているオプションを1つ指定します。たとえば、\fI\-J\-Xms48m\fRと指定すると、スタートアップ・メモリーは48MBに設定されます。java(1)を参照してください。
T
tbell 已提交
180
.RE
M
mfang 已提交
181 182 183 184 185 186 187 188
.SH "例"
.SS "ネームスペースへのオブジェクトの追加"
.PP
次の例では、ネームスペースに名前を追加する方法を示します。このサンプル・プログラムは、このままの状態で完全に動作する一時ネーム・サービス・クライアントで、次のような単純なツリーを作成するものです。
.sp
.if n \{\
.RS 4
.\}
D
duke 已提交
189
.nf
M
mfang 已提交
190 191 192 193 194
Initial Naming Context
     plans
     Personal
          calendar
          schedule
D
duke 已提交
195
.fi
M
mfang 已提交
196 197 198 199 200 201 202 203 204
.if n \{\
.RE
.\}
.PP
この例で、\fIplans\fRはオブジェクト参照、\fIPersonal\fRは\fIcalendar\fRと\fIschedule\fRの2つのオブジェクト参照を含むネーミング・コンテキストです。
.sp
.if n \{\
.RS 4
.\}
D
duke 已提交
205
.nf
M
mfang 已提交
206 207 208 209 210
import java\&.util\&.Properties;
import org\&.omg\&.CORBA\&.*;
import org\&.omg\&.CosNaming\&.*;
 
public class NameClient {
D
duke 已提交
211

M
mfang 已提交
212
    public static void main(String args[]) {
D
duke 已提交
213

M
mfang 已提交
214 215 216 217 218 219 220 221 222 223 224
        try {
.fi
.if n \{\
.RE
.\}
.PP
ネーミング・サービスの起動で、\fInameserver\fRはポート1050で起動されました。次のコードで、このポート番号をクライアント・システムに知らせます。
.sp
.if n \{\
.RS 4
.\}
D
duke 已提交
225
.nf
M
mfang 已提交
226 227 228
            Properties props = new Properties();
            props\&.put("org\&.omg\&.CORBA\&.ORBInitialPort", "1050");
            ORB orb = ORB\&.init(args, props);
D
duke 已提交
229
.fi
M
mfang 已提交
230 231 232 233 234 235 236 237 238
.if n \{\
.RE
.\}
.PP
次のコードでは、初期ネーミング・コンテキストを取得し、それを\fIctx\fRに代入します。2行目では、\fIctx\fRをダミーのオブジェクト参照\fIobjref\fRにコピーします。このobjrefには、あとで様々な名前を割り当ててネームスペースに追加します。
.sp
.if n \{\
.RS 4
.\}
D
duke 已提交
239
.nf
M
mfang 已提交
240 241 242 243
            NamingContext ctx =
                NamingContextHelper\&.narrow(
                    orb\&.resolve_initial_references("NameService"));
             NamingContext objref = ctx;
D
duke 已提交
244
.fi
M
mfang 已提交
245 246 247 248 249 250 251 252 253
.if n \{\
.RE
.\}
.PP
次のコードでは、\fItext\fRタイプの名前\fIplans\fRを作成し、それをダミーのオブジェクト参照にバインドします。その後、\fIrebind\fRメソッドを使用して初期ネーミング・コンテキストの下に\fIplans\fRを追加しています。\fIrebind\fRメソッドを使用すれば、\fIbind\fRメソッドを使用した場合に発生する例外を発生させずに、このプログラムを何度も繰返し実行できます。
.sp
.if n \{\
.RS 4
.\}
D
duke 已提交
254
.nf
M
mfang 已提交
255 256 257 258
            NameComponent nc1 = new NameComponent("plans", "text");
            NameComponent[] name1 = {nc1};
            ctx\&.rebind(name1, objref);
            System\&.out\&.println("plans rebind successful!");
D
duke 已提交
259
.fi
M
mfang 已提交
260 261 262 263 264 265 266 267 268
.if n \{\
.RE
.\}
.PP
次のコードでは、\fIdirectory\fRタイプの\fIPersonal\fRというネーミング・コンテキストを作成します。その結果得られるオブジェクト参照\fIctx2\fRを\fIname\fRにバインドし、初期ネーミング・コンテキストに追加します。
.sp
.if n \{\
.RS 4
.\}
D
duke 已提交
269
.nf
M
mfang 已提交
270 271 272 273
            NameComponent nc2 = new NameComponent("Personal", "directory");
            NameComponent[] name2 = {nc2};
            NamingContext ctx2 = ctx\&.bind_new_context(name2);
            System\&.out\&.println("new naming context added\&.\&.");
D
duke 已提交
274
.fi
M
mfang 已提交
275 276 277 278 279 280 281 282 283
.if n \{\
.RE
.\}
.PP
残りのコードでは、ダミーのオブジェクト参照を\fIschedule\fRと\fIcalendar\fRという名前でネーミング・コンテキスト\fIPersonal\fR(\fIctx2\fR)にバインドします。
.sp
.if n \{\
.RS 4
.\}
D
duke 已提交
284
.nf
M
mfang 已提交
285 286 287 288 289 290 291 292 293 294 295 296
            NameComponent nc3 = new NameComponent("schedule", "text");
            NameComponent[] name3 = {nc3};
            ctx2\&.rebind(name3, objref);
            System\&.out\&.println("schedule rebind successful!");
 
            NameComponent nc4 = new NameComponent("calender", "text");
            NameComponent[] name4 = {nc4};
            ctx2\&.rebind(name4, objref);
            System\&.out\&.println("calender rebind successful!");
        } catch (Exception e) {
            e\&.printStackTrace(System\&.err);
        }
D
duke 已提交
297 298 299
    }
}
.fi
M
mfang 已提交
300 301 302 303 304 305 306 307 308 309
.if n \{\
.RE
.\}
.SS "ネームスペースの参照"
.PP
次のサンプル・プログラムでは、ネームスペースをブラウズする方法を示します。
.sp
.if n \{\
.RS 4
.\}
D
duke 已提交
310
.nf
M
mfang 已提交
311 312 313 314 315
import java\&.util\&.Properties;
import org\&.omg\&.CORBA\&.*;
import org\&.omg\&.CosNaming\&.*;
 
public class NameClientList {
D
duke 已提交
316

M
mfang 已提交
317
    public static void main(String args[]) {
D
duke 已提交
318

M
mfang 已提交
319 320 321 322 323 324 325 326 327 328 329
        try {
.fi
.if n \{\
.RE
.\}
.PP
ネーミング・サービスの起動で、\fInameserver\fRはポート1050で起動されました。次のコードで、このポート番号をクライアント・システムに知らせます。
.sp
.if n \{\
.RS 4
.\}
D
duke 已提交
330
.nf
M
mfang 已提交
331 332 333
            Properties props = new Properties();
            props\&.put("org\&.omg\&.CORBA\&.ORBInitialPort", "1050");
            ORB orb = ORB\&.init(args, props);
D
duke 已提交
334
.fi
M
mfang 已提交
335 336 337 338 339 340 341 342 343
.if n \{\
.RE
.\}
.PP
次のコードでは、初期ネーミング・コンテキストを取得しています。
.sp
.if n \{\
.RS 4
.\}
D
duke 已提交
344
.nf
M
mfang 已提交
345 346 347
            NamingContext nc =
            NamingContextHelper\&.narrow(
                orb\&.resolve_initial_references("NameService"));
D
duke 已提交
348
.fi
M
mfang 已提交
349 350 351 352 353 354 355 356 357
.if n \{\
.RE
.\}
.PP
\fIlist\fRメソッドは、ネーミング・コンテキストのバインディングをリストします。この場合、最大1000個までのバインディングが初期ネーミング・コンテキストから\fIBindingListHolder\fRに返されます。残りのバインディングは、\fIBindingIteratorHolder\fRに返されます。
.sp
.if n \{\
.RS 4
.\}
D
duke 已提交
358
.nf
M
mfang 已提交
359 360 361
            BindingListHolder bl = new BindingListHolder();
            BindingIteratorHolder blIt= new BindingIteratorHolder();
            nc\&.list(1000, bl, blIt);
D
duke 已提交
362
.fi
M
mfang 已提交
363 364 365 366 367 368 369 370 371
.if n \{\
.RE
.\}
.PP
次のコードでは、返された\fIBindingListHolder\fRからバインディングの配列を取得します。バインディングがない場合は、プログラムが終了します。
.sp
.if n \{\
.RS 4
.\}
D
duke 已提交
372
.nf
M
mfang 已提交
373 374
            Binding bindings[] = bl\&.value;
            if (bindings\&.length == 0) return;
D
duke 已提交
375
.fi
M
mfang 已提交
376 377 378 379 380 381 382 383 384
.if n \{\
.RE
.\}
.PP
残りのコードでは、バインディングに対してループ処理を行い、名前を出力します。
.sp
.if n \{\
.RS 4
.\}
D
duke 已提交
385
.nf
M
mfang 已提交
386 387 388 389 390 391 392 393 394 395 396 397 398 399 400
            for (int i=0; i < bindings\&.length; i++) {
 
                // get the object reference for each binding
                org\&.omg\&.CORBA\&.Object obj = nc\&.resolve(bindings[i]\&.binding_name);
                String objStr = orb\&.object_to_string(obj);
                int lastIx = bindings[i]\&.binding_name\&.length\-1;
 
                // check to see if this is a naming context
                if (bindings[i]\&.binding_type == BindingType\&.ncontext) {
                    System\&.out\&.println("Context: " +
                        bindings[i]\&.binding_name[lastIx]\&.id);
                } else {
                    System\&.out\&.println("Object: " +
                        bindings[i]\&.binding_name[lastIx]\&.id);
                }
D
duke 已提交
401
            }
M
mfang 已提交
402 403
        } catch (Exception e) {
            e\&.printStackTrace(System\&.err)
D
duke 已提交
404
        }
M
mfang 已提交
405
    }
D
duke 已提交
406 407
}
.fi
M
mfang 已提交
408 409 410 411 412 413 414 415 416 417 418 419 420 421 422 423 424 425
.if n \{\
.RE
.\}
.SH "関連項目"
.sp
.RS 4
.ie n \{\
\h'-04'\(bu\h'+03'\c
.\}
.el \{\
.sp -1
.IP \(bu 2.3
.\}
orbd(1)
.RE
.br
'pl 8.5i
'bp