Sun WBEM 開発ガイド

インスタンスの処理

この節では、CIM インスタンスの作成、削除、および更新 (1 つ以上のインスタンスのプロパティ値の取得と設定) の各方法について説明します。

インスタンスの作成

既存のクラスのインスタンスを作成するには、newInstance メソッドを使用します。既存のクラスがキープロパティを持つ場合、アプリケーションはそのプロパティを固有の値に設定する必要があります。インスタンスは、必要に応じてそのクラスに定義されていない別の修飾子を定義することもできます。それらの修飾子をインスタンスまたは特定のインスタンスプロパティ用に定義できますが、クラス宣言内で定義する必要はありません。

アプリケーションは、クラスに定義されている一連の修飾子を getQualifiers メソッドを使用して取得できます。

例 - インスタンスの作成

例 6-4 のコードセグメントは、newInstance メソッドを使用して、Solaris_Package クラスの CIM インスタンス (Solaris パッケージなど) を表す Java クラスを作成します。


例 6-4 インスタンスの作成 (newInstance())

 
/*ローカルホストの root¥cimv2 ネームスペースの CIM Object Manager に接続 */
CIMClient cc = new CIMClient();
 
// Solaris_Package クラスを取得
cimclass = cc.getClass(newCIMObjectPath("Solaris_Package");
/* プロパティのデフォルト値を使用して生成された Solaris_Package
 クラスの新しいインスタンスを作成。このクラスのプロバイダが
 デフォルト値を指定しない場合、プロパティの値は NULL であり、 
 明示的に設定される必要がある。*/
 ci = cimclass.newInstance();
 


インスタンスの削除

インスタンスの削除には、deleteInstance メソッドを使用します。

例 - インスタンスの削除

例 6-5 は、クライアントアプリケーションを CIM Object Manager に接続し、次に示すインタフェースを使用してクラスのインスタンスをすべて削除します。


例 6-5 インスタンスの削除 (deleteInstance)

 
import java.rmi.*;
import com.sun.wbem.client.CIMClient;
import com.sun.wbem.cim.CIMInstance;
import com.sun.wbem.cim.CIMValue;
import com.sun.wbem.cim.CIMProperty;
import com.sun.wbem.cim.CIMNameSpace;
import com.sun.wbem.cim.CIMObjectPath;
import com.sun.wbem.cim.CIMClass;
import java.util.Enumeration;
 
public class DeleteInstances {
		public static void main(String args[]) throws CIMException {
			CIMClient cc = null;
			try {
					/* コマンド行引数を含むネームスペースオブジェクトを 
					   構築 */
					CIMNameSpace cns = new CIMNameSpace(args[0]);
 
					/* このネームスペースオブジェクトを CIM Object Manager に渡す。*/
 				  CIMClient cc = new CIMClient(cns);
 
					/* 削除するオブジェクトの CIM オブジェクトパスを含む 
					   オブジェクトを構築 */
 				  CIMObjectPath cop = new CIMObjectPath(args[1]);
 
					/* オブジェクトインスタンスのディープ (deep) 列挙を行う 
            (deep は CIMClient.DEEP に設定される)。 
            クラスインスタンスのディープ列挙を行うと、クラスおよび 
            そのサブクラスのすべてのインスタンスが返される。 */
					Enumeration e = cc.enumInstances(cop, CIMClient.DEEP);
	    
					// 各オブジェクト名を出力し、インスタンスを削除
					while(e.hasMoreElements()) {
						CIMObjectPath op = (CIMObjectPath)e.nextElement();
						System.out.println(op);
						cc.deleteInstance(op);
	   		 	}
				}
			catch (Exception e) {
	    			System.out.println("Exception: "+e);
			}
 
  		// クライアント接続が開いている場合、接続を閉じる。
			if(cc != null) {
          	cc.close();
    	}
		}
}
 


インスタンスの取得と設定

アプリケーションが、 CIM Object Manager から CIM インスタンスを検出する場合、getInstance メソッドがよく使用されます。

例 - インスタンスの取得

例 6-6 のコードセグメントは、特定のシステム上のすべてのプロセスを表示します。この例では、enumInstances メソッドを使用して CIM_Process クラスのインスタンス名を取得します。このコードを Microsoft Windows 32 システムで実行すると、Windows 32 のプロセスが返されます。このコードを Solaris システムで実行すると、Solaris プロセスが返されます。


例 6-6 クラスインスタンスの取得 (getInstance)

{
//ネームスペース cns を作成
CIMnameSpace cns = new CIMNameSpace; 
 
//CIM Object Manager 上で cns ネームスペースに接続
cc = new CIMClient(cns); 
 
/* CIM_Process クラスの CIM オブジェクトパスを
CIM Object Manager に渡す (このクラスのインスタンスを取得する)。 */ 
 
CIMObjectPath op = new CIMObjectPath("CIM_Process"); 
 
/* CIM Object Manager が、オブジェクトパスのベクトル 
(CIM_Process クラスのインスタンス名) を返す。 */
Vector v = cc.enumInstances(op, true); 
 
/* インスタンスオブジェクトパスが入ったベクトルのサイズ分だけ繰り返す。
各オブジェクト名によって参照されるインスタンスを取得するには、 
CIM Client の getInstance インタフェースを使用する。 */
 
for (int i=0; i < v.size(); i++) {
 
		// インスタンスを取得
		CIMInstance ci = cc.getInstance(v.elementAt(i));
 
		/* CIM_Process の各インスタンスのプロセス ID 文字列を 
		取得 */
		CIMProperty cp = ci.getProperty("Handle");
}


例 - プロパティの取得

例 6-7 は、すべての Solaris プロセスの lockspeed プロパティの値を出力します。このコードセグメントは、次のメソッドを使用します。


例 6-7 プロセッサ情報の出力 (getProperty)

/* myhost の /root ネームスペースで、パスワード contrary を 
持つユーザー mary として CIM Object Manager に接続 */
{
CIMNameSpace cns = new CIMNamesSpace ("myhost" "/root");
cc = new CIMClient (cns, "/root", "mary", "contrary");
 
// Solaris_Processor のすべてのインスタンスの名前を取得
Vector op cc.enumInstances("Solaris_Processor")
 
// 各 Solaris プロセッサごとに、そのインスタンスデータを取得
while (vector has more elements) {
        cn.getNextElement();
        cc.getInstance (cn);
 
// 各プロセッサの lockspeed を出力
p = ci.getProperty("lockspeed")
        System.out.println(p.getValue().getValue());
}


例 - インスタンスの設定

例 6-8 のコードセグメントは、CIM インスタンスを取得してそのプロパティ値の 1 つを変更し、変更後のインスタンスを CIM Object Manager に渡します。

CIM プロパティは、CIM クラスの特性を記述するために使用される値です。プロパティは、プロパティ値を設定する機能と、プロパティ値を取得する機能の組み合わせと考えることができます。


例 6-8 インスタンスの設定 (setInstance)

{
/* ベクトル内の各要素のインスタンスを取得し、 
各インスタンスで b のプロパティ値を 10 に変更し、 
変更後のインスタンスを CIM Object Manager に渡す。 */
 
For (int i=0; i(v.size(); i++) {
		CIMInstance ci = cc.getInstance(v.elementAt(i));
		ci.setProperty("b",new CIMValue(10)); 
		cc.setInstance(new CIMObjectPath(),ci); 
 
}