JavaTM Platform
Standard Ed. 6

javax.management
クラス JMX

java.lang.Object
  上位を拡張 javax.management.JMX

public class JMX
extends Object

JMX API からの static メソッドです。このクラスのインスタンスは存在しません。

導入されたバージョン:
1.6

フィールドの概要
static String DEFAULT_VALUE_FIELD
          defaultValue フィールドの名前です。
static String IMMUTABLE_INFO_FIELD
          immutableInfo フィールドの名前です。
static String INTERFACE_CLASS_NAME_FIELD
          interfaceClassName フィールドの名前です。
static String LEGAL_VALUES_FIELD
          legalValues フィールドの名前です。
static String MAX_VALUE_FIELD
          maxValue フィールドの名前です。
static String MIN_VALUE_FIELD
          minValue フィールドの名前です。
static String MXBEAN_FIELD
          mxbean フィールドの名前です。
static String OPEN_TYPE_FIELD
          openType フィールドの名前です。
static String ORIGINAL_TYPE_FIELD
          originalType フィールドの名前です。
 
メソッドの概要
static boolean isMXBeanInterface(Class<?> interfaceClass)
           インタフェースが MXBean インタフェースかどうかをテストします。
static
<T> T
newMBeanProxy(MBeanServerConnection connection, ObjectName objectName, Class<T> interfaceClass)
           ローカルまたはリモートの MBean Server 内に Standard MBean のプロキシを作成します。
static
<T> T
newMBeanProxy(MBeanServerConnection connection, ObjectName objectName, Class<T> interfaceClass, boolean notificationBroadcaster)
           ローカルまたはリモートの MBean Server 内に Standard MBean 用のプロキシを作成します。
static
<T> T
newMXBeanProxy(MBeanServerConnection connection, ObjectName objectName, Class<T> interfaceClass)
           ローカルまたはリモートの MBean Server 内に MXBean のプロキシを作成します。
static
<T> T
newMXBeanProxy(MBeanServerConnection connection, ObjectName objectName, Class<T> interfaceClass, boolean notificationBroadcaster)
           ローカルまたはリモートの MBean Server 内に MXBean 用のプロキシを作成します。
 
クラス java.lang.Object から継承されたメソッド
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
 

フィールドの詳細

DEFAULT_VALUE_FIELD

public static final String DEFAULT_VALUE_FIELD
defaultValue フィールドの名前です。

関連項目:
定数フィールド値

IMMUTABLE_INFO_FIELD

public static final String IMMUTABLE_INFO_FIELD
immutableInfo フィールドの名前です。

関連項目:
定数フィールド値

INTERFACE_CLASS_NAME_FIELD

public static final String INTERFACE_CLASS_NAME_FIELD
interfaceClassName フィールドの名前です。

関連項目:
定数フィールド値

LEGAL_VALUES_FIELD

public static final String LEGAL_VALUES_FIELD
legalValues フィールドの名前です。

関連項目:
定数フィールド値

MAX_VALUE_FIELD

public static final String MAX_VALUE_FIELD
maxValue フィールドの名前です。

関連項目:
定数フィールド値

MIN_VALUE_FIELD

public static final String MIN_VALUE_FIELD
minValue フィールドの名前です。

関連項目:
定数フィールド値

MXBEAN_FIELD

public static final String MXBEAN_FIELD
mxbean フィールドの名前です。

関連項目:
定数フィールド値

OPEN_TYPE_FIELD

public static final String OPEN_TYPE_FIELD
openType フィールドの名前です。

関連項目:
定数フィールド値

ORIGINAL_TYPE_FIELD

public static final String ORIGINAL_TYPE_FIELD
originalType フィールドの名前です。

関連項目:
定数フィールド値
メソッドの詳細

newMBeanProxy

public static <T> T newMBeanProxy(MBeanServerConnection connection,
                                  ObjectName objectName,
                                  Class<T> interfaceClass)
 

ローカルまたはリモートの MBean Server 内に Standard MBean のプロキシを作成します。

 

MBean Server mbsObjectName name を持つ MBean が含まれていて、MBean の管理インタフェースが Java インタフェース MyMBean によって記述されている場合は、次のようにして MBean のプロキシを構築できます。

 
 MyMBean proxy = JMX.newMBeanProxy(mbs, name, MyMBean.class);
 
 

MyMBean は、次のようになります。

 
 public interface MyMBean {
     public String getSomeAttribute();
     public void setSomeAttribute(String value);
     public void someOperation(String param1, int param2);
 }
 
 

これで、次の内容を実行できます。

 

このメソッドにより返されるオブジェクトは、Proxy です。このオブジェクトの InvocationHandlerMBeanServerInvocationHandler です。

 

このメソッドは、newMBeanProxy(connection, objectName, interfaceClass, false) と等価です。

型パラメータ:
T - たとえば、interfaceClass パラメータが MyMBean.class であれば、戻り値の型は MyMBean になることをコンパイラに知らせる
パラメータ:
connection - 送信先の MBean サーバー
objectName - connection 内で渡される MBean の名前
interfaceClass - MBean がエクスポートする 管理インタフェース。これも返されるプロキシにより実装される
戻り値:
新しいプロキシのインスタンス

newMBeanProxy

public static <T> T newMBeanProxy(MBeanServerConnection connection,
                                  ObjectName objectName,
                                  Class<T> interfaceClass,
                                  boolean notificationBroadcaster)
 

ローカルまたはリモートの MBean Server 内に Standard MBean 用のプロキシを作成します。これは、NotificationEmitter のメソッドもサポートする場合があります。

 

このメソッドの動作は newMBeanProxy(MBeanServerConnection, ObjectName, Class) と同じですが、加えて notificationBroadcastertrue の場合、MBean は NotificationBroadcaster または NotificationEmitter であると見なされ、返されるプロキシは NotificationEmitter および interfaceClass を実装します。このプロキシ上で NotificationBroadcaster.addNotificationListener(javax.management.NotificationListener, javax.management.NotificationFilter, java.lang.Object) を呼び出すと、MBeanServerConnection.addNotificationListener(ObjectName, NotificationListener, NotificationFilter, Object) が呼び出されます。 NotificationBroadcaster および NotificationEmitter のその他のメソッドの場合も同様です。

型パラメータ:
T - たとえば、interfaceClass パラメータが MyMBean.class であれば、戻り値の型は MyMBean になることをコンパイラに知らせる
パラメータ:
connection - 送信先の MBean サーバー
objectName - connection 内で渡される MBean の名前
interfaceClass - MBean がエクスポートする 管理インタフェース。これも返されるプロキシにより実装される
notificationBroadcaster - connection 経由でメソッドを渡すことにより、 返されたプロキシに NotificationEmitter を実装させる
戻り値:
新しいプロキシのインスタンス

newMXBeanProxy

public static <T> T newMXBeanProxy(MBeanServerConnection connection,
                                   ObjectName objectName,
                                   Class<T> interfaceClass)
 

ローカルまたはリモートの MBean Server 内に MXBean のプロキシを作成します。

 

MBean Server mbsObjectName name を持つ MXBean が含まれていて、MXBean の管理インタフェースが Java インタフェース MyMXBean によって記述されている場合は、次のようにして MXBean のプロキシを構築できます。

 
 MyMXBean proxy = JMX.newMXBeanProxy(mbs, name, MyMXBean.class);
 
 

MyMXBean は、次のようになります。

 
 public interface MyMXBean {
     public String getSimpleAttribute();
     public void setSimpleAttribute(String value);
     public MemoryUsage getMappedAttribute();
     public void setMappedAttribute(MemoryUsage memoryUsage);
     public MemoryUsage someOperation(String param1, MemoryUsage param2);
 }
 
 

次のようになります。

 

このメソッドにより返されるオブジェクトは、Proxy です。このオブジェクトの InvocationHandlerMBeanServerInvocationHandler です。

 

このメソッドは、newMXBeanProxy(connection, objectName, interfaceClass, false) と等価です。

型パラメータ:
T - たとえば、interfaceClass パラメータが MyMXBean.class であれば、戻り値の型は MyMXBean になることをコンパイラに知らせる
パラメータ:
connection - 送信先の MBean サーバー
objectName - connection 内で渡される MBean の名前
interfaceClass - MXBean インタフェース。 これも返されるプロキシにより実装される
戻り値:
新しいプロキシのインスタンス

newMXBeanProxy

public static <T> T newMXBeanProxy(MBeanServerConnection connection,
                                   ObjectName objectName,
                                   Class<T> interfaceClass,
                                   boolean notificationBroadcaster)
 

ローカルまたはリモートの MBean Server 内に MXBean 用のプロキシを作成します。これは、NotificationEmitter のメソッドもサポートする場合があります。

 

このメソッドの動作は newMXBeanProxy(MBeanServerConnection, ObjectName, Class) と同じですが、加えて notificationBroadcastertrue の場合、MXBean は NotificationBroadcaster または NotificationEmitter であると見なされ、返されるプロキシは NotificationEmitter および interfaceClass を実装します。このプロキシ上で NotificationBroadcaster.addNotificationListener(javax.management.NotificationListener, javax.management.NotificationFilter, java.lang.Object) を呼び出すと、MBeanServerConnection.addNotificationListener(ObjectName, NotificationListener, NotificationFilter, Object) が呼び出されます。 NotificationBroadcaster および NotificationEmitter のその他のメソッドの場合も同様です。

型パラメータ:
T - たとえば、interfaceClass パラメータが MyMXBean.class であれば、戻り値の型は MyMXBean になることをコンパイラに知らせる
パラメータ:
connection - 送信先の MBean サーバー
objectName - connection 内で渡される MBean の名前
interfaceClass - MXBean インタフェース。 これも返されるプロキシにより実装される
notificationBroadcaster - connection 経由でメソッドを渡すことにより、 返されたプロキシに NotificationEmitter を実装させる
戻り値:
新しいプロキシのインスタンス

isMXBeanInterface

public static boolean isMXBeanInterface(Class<?> interfaceClass)
 

インタフェースが MXBean インタフェースかどうかをテストします。@MXBean または @MXBean(true) が注釈として付加されているか、@MXBean の注釈はないが名前が "MXBean" で終わる場合は、MXBean インタフェースです。

パラメータ:
interfaceClass - 候補のインタフェース
戻り値:
interfaceClass がインタフェースであり、 示された条件を満たす場合は true
例外:
NullPointerException - interfaceClass が null の場合

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 も参照してください。