public abstract class RMIServerImpl extends Object implements Closeable, RMIServer
コネクタサーバーを表す RMI オブジェクトです。リモートクライアントは、newClient(Object) メソッドを使って接続を行えます。このメソッドは、接続を表す RMI オブジェクトを返します。
ユーザーコードは、必ずしもこのクラスを直接参照しません。通常、RMI 接続サーバーは、RMIConnectorServer クラスで作成されます。リモートクライアントは、通常、JMXConnectorFactory を使用するか、RMIConnector をインスタンス化することによって接続を作成します。
これは抽象クラスです。具象サブクラスは、JRMP と IIOP のどちらを使用するかなど、クライアント接続オブジェクトの詳細を定義します。
| コンストラクタと説明 |
|---|
RMIServerImpl(Map<String,?> env)
新しい
RMIServerImpl を構築します。 |
| 修飾子と型 | メソッドと説明 |
|---|---|
protected void |
clientClosed(RMIConnection client)
makeClient によって作成されたクライアント接続の終了時に呼び出されるメソッドです。 |
void |
close()
この接続サーバーを終了します。
|
protected abstract void |
closeClient(RMIConnection client)
makeClient で作成されたクライアント接続を終了します。 |
protected abstract void |
closeServer()
close() によって呼び出され、コネクタサーバーを終了します。 |
protected abstract void |
export()
この RMI オブジェクトをエクスポートします。
|
ClassLoader |
getDefaultClassLoader()
このコネクタサーバーで使用されるデフォルトの
ClassLoader を取得します。 |
MBeanServer |
getMBeanServer()
このコネクタサーバーの接続先の
MBeanServer です。 |
protected abstract String |
getProtocol()
このオブジェクトのプロトコル文字列を返します。
|
String |
getVersion()
このコネクタサーバーが認識する RMI コネクタプロトコルのバージョンです。
|
protected abstract RMIConnection |
makeClient(String connectionId, Subject subject)
新しいクライアント接続を作成します。
|
RMIConnection |
newClient(Object credentials)
新しいクライアント接続を作成します。
|
void |
setDefaultClassLoader(ClassLoader cl)
このコネクタサーバーのデフォルトの
ClassLoader を設定します。 |
void |
setMBeanServer(MBeanServer mbs)
このコネクタサーバーの接続先の
MBeanServer を設定します。 |
abstract Remote |
toStub()
このサーバーオブジェクトのリモート処理可能なスタブを返します。
|
protected abstract void export()
throws IOException
この RMI オブジェクトをエクスポートします。
IOException - この RMI オブジェクトをエクスポートできない場合。public abstract Remote toStub() throws IOException
IOException - スタブを取得できない場合。たとえば、RMIServerImpl がまだエクスポートされていない場合など。public void setDefaultClassLoader(ClassLoader cl)
このコネクタサーバーのデフォルトの ClassLoader を設定します。新しいクライアント接続は、このクラスローダーを使用します。既存のクライアント接続に影響はありません。
cl - このコネクタサーバーで使用される新しい ClassLoader。getDefaultClassLoader()public ClassLoader getDefaultClassLoader()
このコネクタサーバーで使用されるデフォルトの ClassLoader を取得します。
ClassLoader。setDefaultClassLoader(java.lang.ClassLoader)public void setMBeanServer(MBeanServer mbs)
このコネクタサーバーの接続先の MBeanServer を設定します。新しいクライアント接続は、この MBeanServer と相互に作用します。既存のクライアント接続に影響はありません。
mbs - 新しい MBeanServer。null でもよいが、その場合、新しいクライアント接続は拒否される。getMBeanServer()public MBeanServer getMBeanServer()
このコネクタサーバーの接続先の MBeanServer です。これは、このオブジェクト上で setMBeanServer(javax.management.MBeanServer) に渡される最後の値です。そのメソッドが呼び出されていない場合は null になります。
MBeanServer。setMBeanServer(javax.management.MBeanServer)public String getVersion()
RMIServerこのコネクタサーバーが認識する RMI コネクタプロトコルのバージョンです。次の形式の文字列になります。
protocol-version implementation-name
protocol-version はゼロ以上の複数の整数をピリオド (.) で区切った形式になります。このドキュメントに記載されているバージョンの実装では、文字列 1.0 を使用します。
プロトコルバージョンと実装名の間には空白文字を 1 つ入力します。実装名の形式は指定されていませんが、実装のバージョン番号を含めることをお勧めします。セキュリティー上の理由などにより、実装名として空文字列を指定することもできます。
getVersion、インタフェース: RMIServerpublic RMIConnection newClient(Object credentials) throws IOException
新しいクライアント接続を作成します。このメソッドは、makeClient を呼び出し、返されたクライアント接続オブジェクトを内部リストに追加します。close() メソッドにより、この RMIServerImpl が終了した場合、リスト内に残っている各オブジェクトの close() メソッドが呼び出されます。
この内部リスト内にクライアント接続オブジェクトが存在していても、このクライアント接続オブジェクトがガベージコレクションの対象から除外されるわけではありません。
newClient、インタフェース: RMIServercredentials - このオブジェクトは、RMIConnection を作成する前に、呼び出し側の認証用としてサーバーに渡されるユーザー定義の証明書を指定する。null も可。RMIConnection。これは通常、makeClient によって作成されたオブジェクトであるが、実装では、RMIConnection を実装する別のオブジェクトにこのオブジェクトをラップできる。IOException - 新しいクライアントオブジェクトを作成またはエクスポートできない場合。SecurityException - 指定された証明書では、サーバーがユーザーを認証できない場合。IllegalStateException - getMBeanServer() が null である場合。protected abstract RMIConnection makeClient(String connectionId, Subject subject) throws IOException
新しいクライアント接続を作成します。このメソッドは、公開メソッド newClient(Object) によって呼び出されます。
connectionId - 新しい接続の ID。このコネクタサーバーによって開かれたすべての接続は、それぞれ異なる ID を持つ。このパラメータが null の場合の動作は不定。subject - 認証済みのサブジェクト。null も可。RMIConnection。IOException - 新しいクライアントオブジェクトを作成またはエクスポートできない場合。protected abstract void closeClient(RMIConnection client) throws IOException
makeClient で作成されたクライアント接続を終了します。
client - 以前に makeClient によって返された、closeClient メソッドがまだ 1 回も呼び出されていない接続。client が null の場合を含めて、何らかの条件違反があった場合、動作は不定になる。IOException - クライアント接続を終了できない場合。protected abstract String getProtocol()
このオブジェクトのプロトコル文字列を返します。返される文字列は、RMI/JRMP の場合は rmi、RMI/IIOP の場合は iiop になります。
protected void clientClosed(RMIConnection client) throws IOException
makeClient によって作成されたクライアント接続の終了時に呼び出されるメソッドです。makeClient を定義するサブクラスは、生成されたオブジェクトの close メソッドが呼び出されたとき、このメソッドが呼び出されるように配置する必要があります。これにより、RMIServerImpl の接続リストからの削除が可能になります。このリスト内に client が存在していなくても、エラーではありません。
このメソッドは、接続リストから client を削除したあと、closeClient(client) を呼び出します。
client - 終了したクライアント接続。IOException - closeClient(javax.management.remote.rmi.RMIConnection) がこの例外をスローする場合。NullPointerException - client が null である場合。public void close()
throws IOException
この接続サーバーを終了します。このメソッドは、新しいクライアント接続をこれ以上受け付けないようにするため、最初に closeServer() メソッドを呼び出します。すると、makeClient によって返された残りの RMIConnection オブジェクトのそれぞれに対して、その close メソッドが呼び出されます。
このメソッドが 2 回以上呼び出されたときの動作は指定されていません。
closeServer() が IOException をスローした場合、個々の接続は終了します。その後、このメソッドから IOException がスローされます。
closeServer() は正常に復帰したが、1 つ以上の接続が IOException をスローした場合、すべての接続が終了したあと、これらの IOException のうちの 1 つがこのメソッドからスローされます。1 つ以上の接続が IOException をスローした場合、このメソッドからスローされる内容は不定になります。
close、インタフェース: Closeableclose、インタフェース: AutoCloseableIOException - closeServer() またはいずれかの RMIConnection.close() 呼び出しが IOException をスローした場合。protected abstract void closeServer()
throws IOException
close() によって呼び出され、コネクタサーバーを終了します。このメソッドの終了後、コネクタサーバーは新しい接続を一切受け付けなくなります。
IOException - コネクタサーバーの終了に失敗した場合。 バグまたは機能を送信
詳細な API リファレンスおよび開発者ドキュメントについては、Java SE のドキュメントを参照してください。そのドキュメントには、概念的な概要、用語の定義、回避方法、有効なコード例などの、開発者を対象にしたより詳細な説明が含まれています。
Copyright © 1993, 2013, Oracle and/or its affiliates. All rights reserved.