JavaTM Platform
Standard Ed. 6

java.rmi.activation
クラス ActivationGroup

java.lang.Object
  上位を拡張 java.rmi.server.RemoteObject
      上位を拡張 java.rmi.server.RemoteServer
          上位を拡張 java.rmi.server.UnicastRemoteObject
              上位を拡張 java.rmi.activation.ActivationGroup
すべての実装されたインタフェース:
Serializable, ActivationInstantiator, Remote

public abstract class ActivationGroup
extends UnicastRemoteObject
implements ActivationInstantiator

ActivationGroup は、グループ内の「起動可能な」オブジェクトの新しいインスタンスを生成し、グループの ActivationMonitor に対して、オブジェクトの起動や停止、あるいはグループ全体の停止を通知します。

ActivationGroup は最初、次のどれかの方法で作成します。

アクティベータだけが、ActivationGroup を作成し直すことができます。必要に応じてアクティベータは、登録された起動グループごとに別個の VM を子プロセスなどとして生成し、起動要求を適切なグループにリダイレクトします。VM を生成する方法は、実装によって異なります。起動グループは、static メソッド ActivationGroup.createGroup により作成します。createGroup メソッドでグループを作成する場合、次の 2 つの必要条件があります。1) グループは、ActivationGroup の具象サブクラスであること、2) グループには、次の 2 つの引数をとるコンストラクタがあることです。

グループが作成されると、ActivationGroup のデフォルトの実装では、このグループの ActivationGroupDesc を作成したときに要求されたプロパティーによりシステムのプロパティーがオーバーライドされ、java.rmi.RMISecurityManager がデフォルトのシステムセキュリティーマネージャーとして設定されます。グループ内でオブジェクトが起動されるときに、特定のプロパティーの設定を必要とするアプリケーションの場合、任意の ActivationDesc を作成する前 (デフォルトの ActivationDesc が作成される前) に、アプリケーションに必要なプロパティーで構成される特別な Properties オブジェクトを作成します。そして、その Properties を設定して ActivationGroupDesc を作成してから、ActivationGroup.createGroup を使います。java.rmi.RMISecurityManager 以外のセキュリティーマネージャーが必要なアプリケーションの場合は、ActivativationGroupDescriptor プロパティーリストで、java.security.manager プロパティーをインストールするセキュリティーマネージャーの名前に設定できます。

導入されたバージョン:
1.2
関連項目:
ActivationInstantiator, ActivationGroupDesc, ActivationGroupID, 直列化された形式

フィールドの概要
 
クラス java.rmi.server.RemoteObject から継承されたフィールド
ref
 
コンストラクタの概要
protected ActivationGroup(ActivationGroupID groupID)
          指定された起動グループ識別子を持つ起動グループを構築します。
 
メソッドの概要
protected  void activeObject(ActivationID id, MarshalledObject<? extends Remote> mobj)
          この protected メソッドは、サブクラスがグループのモニターに activeObject コールバックを行うために必要です。
abstract  void activeObject(ActivationID id, Remote obj)
          グループの activeObject メソッドは、オブジェクトがエクスポートされるときに呼び出されます。
static ActivationGroup createGroup(ActivationGroupID id, ActivationGroupDesc desc, long incarnation)
          現在の VM で使う起動グループを作成および設定します。
static ActivationGroupID currentGroupID()
          現在の起動グループの識別子を返します。
static ActivationSystem getSystem()
          VM が使う起動システムを返します。
protected  void inactiveGroup()
          この protected メソッドは、サブクラスがグループのモニターに inactiveGroup コールバックを行うために必要です。
 boolean inactiveObject(ActivationID id)
          グループの inactiveObject メソッドは、Activatable.inactive メソッドの呼び出しを介して間接的に呼び出されます。
static void setSystem(ActivationSystem system)
          VM が使う起動システムを設定します。
 
クラス java.rmi.server.UnicastRemoteObject から継承されたメソッド
clone, exportObject, exportObject, exportObject, unexportObject
 
クラス java.rmi.server.RemoteServer から継承されたメソッド
getClientHost, getLog, setLog
 
クラス java.rmi.server.RemoteObject から継承されたメソッド
equals, getRef, hashCode, toString, toStub
 
クラス java.lang.Object から継承されたメソッド
finalize, getClass, notify, notifyAll, wait, wait, wait
 
インタフェース java.rmi.activation.ActivationInstantiator から継承されたメソッド
newInstance
 

コンストラクタの詳細

ActivationGroup

protected ActivationGroup(ActivationGroupID groupID)
                   throws RemoteException
指定された起動グループ識別子を持つ起動グループを構築します。このグループは java.rmi.server.UnicastRemoteObject としてエクスポートされます。

パラメータ:
groupID - グループの識別子
例外:
RemoteException - このグループをエクスポートできない場合
導入されたバージョン:
1.2
メソッドの詳細

inactiveObject

public boolean inactiveObject(ActivationID id)
                       throws ActivationException,
                              UnknownObjectException,
                              RemoteException
グループの inactiveObject メソッドは、Activatable.inactive メソッドの呼び出しを介して間接的に呼び出されます。リモートオブジェクトの実装では、そのオブジェクトがアクティブでなくなったとき (アクティブでなくなったとみなされるとき) に Activatableinactive メソッドを呼び出さなければなりません。オブジェクトが終了時に Activatable.inactive を呼び出さないと、グループは自身が作成したオブジェクトへの強参照を保持するので、オブジェクトは決してガベージコレクトされません。

 

グループの inactiveObject メソッドは、リモートオブジェクトを RMI ランタイムからアンエクスポートし、RMI 着信呼び出しの受け付けができないようにします。オブジェクトのアンエクスポートは、保留中あるいは実行中の呼び出しをオブジェクトが持っていない場合にだけ可能です。ActivationGroup のサブクラスは、このメソッドをオーバーライドしてオブジェクトをアンエクスポートする必要があります。

 

RMI ランタイムからオブジェクトを削除後、グループはその ActivationMonitor に、モニターの inactiveObject メソッドを通じて、リモートオブジェクトが起動中でないことを通知する必要があります。これにより、以後の起動要求のときに、アクティベータによってリモートオブジェクトがふたたび起動されます。

 

このメソッドは、グループのモニターにオブジェクトが終了していることを通知するだけです。オブジェクトのアンエクスポートに必要なその他の条件を満足するかどうかは、ActivationGroup の具象サブクラスによります。

パラメータ:
id - オブジェクトの起動識別子
戻り値:
オブジェクトが正常に終了した場合は true、そうでない場合は false
例外:
UnknownObjectException - オブジェクトが不明の場合。すでに終了している場合もある
RemoteException - 呼び出し通知モニターが失敗した場合
ActivationException - グループが停止している場合
導入されたバージョン:
1.2

activeObject

public abstract void activeObject(ActivationID id,
                                  Remote obj)
                           throws ActivationException,
                                  UnknownObjectException,
                                  RemoteException
グループの activeObject メソッドは、オブジェクトがエクスポートされるときに呼び出されます。エクスポートは、Activatable オブジェクトの構築、あるいは Activatable.exportObject の明示的な呼び出しによって実行されます。オブジェクトが起動されていることをグループの ActivationMonitor に対してまだ通知していない場合、グループは、モニターの activeObject メソッドを使ってこれを通知する必要があります。

パラメータ:
id - オブジェクトの識別子
obj - 実装されたリモートオブジェクト
例外:
UnknownObjectException - オブジェクトが未登録の場合
RemoteException - 呼び出し通知モニターが失敗した場合
ActivationException - グループが停止している場合
導入されたバージョン:
1.2

createGroup

public static ActivationGroup createGroup(ActivationGroupID id,
                                          ActivationGroupDesc desc,
                                          long incarnation)
                                   throws ActivationException
現在の VM で使う起動グループを作成および設定します。起動グループを設定できるのは、それが現在設定されていない場合だけです。起動グループが createGroup メソッドを使用して設定されるのは、着信する activate 要求を実行するために、Activator が起動グループの再作成を開始したときです。グループは、最初に ActivationSystem を使って登録されたあとに、このメソッドを使って作成できるようになります。  

ActivationGroupDesc で指定されたグループのクラスは、ActivationGroup の具象サブクラスであり、また、2 つの引数をとる public コンストラクタを持っている必要があります。その引数は、ActivationGroupDesc から取得される、グループの ActivationGroupID と、グループの初期化データを含む MarshalledObject です。  

ActivationGroupDesc で指定されたグループのクラス名が null の場合、このメソッドは、デフォルトの起動グループの実装クラス名に含まれるグループ記述子のように動作します。  

注: 独自の起動グループを作成するアプリケーションの場合は、そのグループのセキュリティーマネージャーを設定する必要があります。そうしないと、グループ内でオブジェクトを起動できません。デフォルトでは java.rmi.RMISecurityManager がセキュリティーマネージャーとして設定されます。  

セキュリティーマネージャーがグループ VM に設定されている場合、このメソッドは最初にセキュリティーマネージャーの checkSetFactory メソッドを呼び出します。この結果、SecurityException になることがあります。別のセキュリティーマネージャーを設定する必要のあるアプリケーションの場合、グループの ActivationGroupDesc で指定されたポリシーファイルで、新しいセキュリティーマネージャーを設定するために必要な許可をそのグループに与える必要があります(注: これは、グループがセキュリティーマネージャーをダウンロードおよび設定する場合に必要)。  

グループが作成されると、ActivationSystem にグループが起動したことを通知するために activeGroup メソッドが呼び出され、このメソッドはグループの ActivationMonitor を返します。アプリケーションから activeGroup を個別に呼び出す必要はありません。なぜなら、この処理はこのメソッドにより行われるからです。  

グループが作成されると、以後の currentGroupID メソッドへの呼び出しは、グループが終了するまではこのグループの識別子を返します。

パラメータ:
id - 起動グループの識別子
desc - 起動グループの記述子
incarnation - グループの生成番号。グループを最初に作成した時には 0
戻り値:
VM が使う起動グループ
例外:
ActivationException - グループがすでに存在する場合、あるいはグループの作成中にエラーが発生した場合
SecurityException - グループを作成する許可が与えられなかった場合。なお、セキュリティーマネージャーの checkSetFactory メソッドのデフォルトの実装は、「setFactory」の RuntimePermission を必要とする
導入されたバージョン:
1.2
関連項目:
SecurityManager.checkSetFactory()

currentGroupID

public static ActivationGroupID currentGroupID()
現在の起動グループの識別子を返します。現在起動中のグループが VM にない場合は null を返します。

戻り値:
起動グループの識別子
導入されたバージョン:
1.2

setSystem

public static void setSystem(ActivationSystem system)
                      throws ActivationException
VM が使う起動システムを設定します。起動システムは、現在起動中のグループがない場合にだけ設定できます。起動システムをこの呼び出しで設定できない場合は、ActivationSystem への参照を取得するために、getSystem メソッドが、アクティベータのレジストリで名前「java.rmi.activation.ActivationSystem」を検索します。デフォルトでは、起動システムの検索に使用されるポート番号は、ActivationSystem.SYSTEM_PORT で定義されています。このポート定義は、プロパティー java.rmi.activation.port を設定することによりオーバーライドできます。  

セキュリティーマネージャーが存在する場合、このメソッドは最初にセキュリティーマネージャーの checkSetFactory メソッドを呼び出します。この結果、SecurityException がスローされることがあります。

パラメータ:
system - ActivationSystem へのリモート参照
例外:
ActivationException - 起動システムがすでに設定されている場合
SecurityException - 起動システムを設定する許可が与えられなかった場合。なお、セキュリティーマネージャーの checkSetFactory メソッドのデフォルトの実装は、「setFactory」の RuntimePermission を必要とする
導入されたバージョン:
1.2
関連項目:
getSystem(), SecurityManager.checkSetFactory()

getSystem

public static ActivationSystem getSystem()
                                  throws ActivationException
VM が使う起動システムを返します。起動システムは、setSystem メソッドで設定できます。setSystem メソッドで起動システムを設定できない場合は、ActivationSystem への参照を取得するために、getSystem メソッドがアクティベータのレジストリで名前「java.rmi.activation.ActivationSystem」を検索します。デフォルトでは、起動システムの検索に使用されるポート番号は、ActivationSystem.SYSTEM_PORT で定義されています。このポート定義は、プロパティー java.rmi.activation.port を設定することによりオーバーライドできます。

戻り値:
VM またはグループが使う起動システム
例外:
ActivationException - 起動システムを取得できないか、バインドされていない (停止中である) 場合 。
導入されたバージョン:
1.2
関連項目:
setSystem(java.rmi.activation.ActivationSystem)

activeObject

protected void activeObject(ActivationID id,
                            MarshalledObject<? extends Remote> mobj)
                     throws ActivationException,
                            UnknownObjectException,
                            RemoteException
この protected メソッドは、サブクラスがグループのモニターに activeObject コールバックを行うために必要です。この呼び出しは、グループの ActivationMonitor にすぐに転送されます。

パラメータ:
id - オブジェクトの識別子
mobj - リモートオブジェクトのスタブを含む、整列化されたオブジェクト
例外:
UnknownObjectException - オブジェクトが未登録の場合
RemoteException - 呼び出し通知モニターが失敗した場合
ActivationException - 起動エラーが発生した場合
導入されたバージョン:
1.2

inactiveGroup

protected void inactiveGroup()
                      throws UnknownGroupException,
                             RemoteException
この protected メソッドは、サブクラスがグループのモニターに inactiveGroup コールバックを行うために必要です。この呼び出しは、グループの ActivationMonitor にすぐに転送されます。また、VM が使う現在のグループが null に設定されます。

例外:
UnknownGroupException - グループが未登録の場合
RemoteException - 呼び出し通知モニターが失敗した場合
導入されたバージョン:
1.2

JavaTM Platform
Standard Ed. 6

バグの報告と機能のリクエスト
さらに詳しい API リファレンスおよび開発者ドキュメントについては、Java SE 開発者用ドキュメントを参照してください。開発者向けの詳細な解説、概念の概要、用語の定義、バグの回避策、およびコード実例が含まれています。

Copyright 2009 Sun Microsystems, Inc. All rights reserved. Use is subject to license terms. Documentation Redistribution Policy も参照してください。