用WMI實現Windows系統自動管理

  與以前的操作系統相比,Windows 2000/XP的優點之一是具有更好的可管理性。例如它支持Windows 2000服務器終端服務下的遠程管理模式,支持Microsoft管理控制檯(MMC),再有一個就是支持WMI。WMI是Windows Management Instrumentation的縮寫,即Windows管理規範。WMI有許多用途,其中之一就是通過腳本編程實現管理自動化。

  一、爲什麼要用腳本?

  回顧九十年代,Windows NT之所以獲得成功,原因之一就在於相對而言這個操作系統比較容易使用,任何能夠使用Windows 3.1的用戶差不多就可以管理一個簡單的NT網絡(這在今天聽起來有點不可思議,但事實是,Windows NT 3.1比Windows 2000/XP功能少得多,因而簡單得多)。只要看看NT的控制面板,這個操作系統可以做些什麼就大致有個印象了。

  隨着操作系統的發展,原來友好的界面變得更加友好。在Windows 2K/XP中,幾乎每一個操作過程都有嚮導,每一個操作系統級的對象都有圖形化的屬性頁;不同的操作選擇引導你到達最終完成任務的對話框,MMC允許你把常用的工具(甚至是第三方的工具)插入到定製的工具集。

  然而,高級用戶感到友好的GUI實在太繁瑣了。另外,儘管在命令行上也可以執行某些任務,但命令行沒有圖形工具那樣完備的功能。爲了讓Windows 2000/XP下的操作任務自動化,一種較好的途徑是通過腳本程序直接訪問圖形化工具訪問的管理接口。WMI允許用戶通過一個統一的接口,用腳本語言訪問操作系統的幾乎任意一個部分。當然,用腳本對WMI編程也有一些限制,例如不能直接訪問Win32 API。

  二、WMI是什麼?

  WMI是Windows 2000/XP管理系統的核心;對於其他的Win32操作系統,WMI是一個有用的插件。WMI以CIMOM爲基礎,CIMOM即公共信息模型對象管理器(Common Information Model Object Manager),是一個描述操作系統構成單元的對象數據庫,爲MMC和腳本程序提供了一個訪問操作系統構成單元的公共接口。有了WMI,工具軟件和腳本程序訪問操作系統的不同部分時不需要使用不同的API;相反,操作系統的不同部分都可以插入WMI,如圖一所示(該圖來自MSDN),工具軟件和WMI可以方便地讀寫WMI。

圖一

  Windows 2000/XP和Windows 98都支持WMI;如果爲Windows NT 4.0和Windows 95加上了Service Pack 4或更高版本也支持WMI。因此,用WMI進行遠程管理時,並非一定要用Windows 2000/XP(當然,如果WMI腳本在一臺沒有性能監視器的Windows 9x機器上運行,就不能在遠程Windows 9x系統上查詢Windows 2000/XP的性能監視器。

  如前所述,WMI允許通過一個公共的接口訪問多種操作系統構成單元,因此不必分別對待各種底層接口或所謂的“提供者”。利用WMI可以高效地管理遠程和本地的計算機;與此相對,並非所有的Windows 2000/XP命令行工具都支持遠程運行。

  WMI是WBEM模型的一種實現。WBEM即Web-Based Enterprise Management,或基於Web的企業管理,WBEM由DMTF(Distributed Management Task Force,分佈式管理任務組)在許多廠商的幫助下創立,包括Compaq、Sun、Microsoft等。WBEM的目標是,爲管理企業環境開發一個標準的接口集。WBEM模型最關鍵的部分是它的數據模型(或描述和定義對象的方式)、編碼規範(Encoding Specification),以及在客戶端和服務器端之間傳輸數據的模式。

  WBEM的數據模型是CIM(Common Information Model,公共信息模型)。CIM是一個用來命名計算機的物理和邏輯單元的標準的命名系統(或稱爲命名模式),例如硬盤的邏輯分區、正在運行的應用的一個實例,或者一條電纜。

  CIM是一個面向對象的模型,使用一組面向對象的術語進行描述。CIM包含類(Class),類是被管理單元的模板。類的實例稱爲對象(Object),對象代表着底層系統的一個具體單元。名稱空間(Namespace)是一個類的集合,每個名稱空間面向一個特定的管理領域。類包含屬性(Property)和方法(Method)。

  CIM分三層。第一層是核心模型(Core Model),這一層包含的類定義對於所有管理領域來說都是共同的。第二層是公共模型(Common Model),這一層包含的類定義對於特定的管理領域來說是公共的,但與具體的操作系統和系統設計無關。第三層是擴展模型(Extension model),這一層包含的類定義與特定的操作系統或技術有關。

  WMI是Microsoft擴展CIM 2.0得到的面向Win32系統的擴展模型。引用WMI類和屬性的形式是“擴展前綴_類名稱.屬性名稱”,例如Win32_ComputerSystem.Name,其中Win32是CIM模式cimv2名稱空間內WMI擴展類的前綴,ComputerSystem是類,Name是屬性。

  編寫WMI腳本的很大一部分工作涉及到讀取和設置屬性值。當前,WMI提供的方法還很有限,但隨着時間的推移,相信WMI和CIM提供的方法都會越來越豐富。

  三、WMI軟件開發包

  利用WMI軟件開發包(SDK)可以方便地查看可用的CIM和Win32類。WMI SDK可以從http://msdn.microsoft.com/downloads/default.asp?URL=/code/sample.asp?url=/msdn-files/027/001/566/msdncompositedoc.xml下載,有8M多,可謂不小。

  WMI SDK要求操作系統必須是Windows 2000/XP或者Windows NT 4.0 SP4或更高版本;儘管Windows 9x系統上可以安裝WMI支持軟件,但SDK不能在Windows 9x上運行。另外,爲支持SDK的ActiveX控件,SDK還要求有IE 5.0或更高版本。SDK對機器性能的最低要求是:Pentium處理器,32 Mb的RAM,40 Mb的磁盤空間,以及至少要有800 x 600、256色的顯示設備。對於運行Windows 2000/XP的機器來說,這些要求應該不會成爲問題。CIMOM默認以服務的形式運行,但如果機器沒有網卡,CIMOM不能作爲服務運行,不過此時可以作爲一個應用運行,只需執行winmgmt.exe即可。winmgmt.exe在%systemroot%/system32/wbem的WMI主目錄下。

  SDK必須由管理員組的成員安裝。安裝過程很簡單,執行WMISdk.exe啓動向導,指定安裝的目標目錄(默認是/Program Files/wmi)。選擇要安裝的可選組件(默認安裝除了SNMP支持以外的所有組件),最後點擊Finish。安裝SDK不需要重新啓動。安裝完成後,“開始/程序”菜單上會增加一個WMI SDK組。

  點擊WMI SDK程序組的WMI CIM Studio。CIM Studio提示連接名稱空間,並顯示默認連接的名稱空間是root/cimv2,確認即可。如果你用Administrator身分登錄Windows,再次點擊確定以當前身份登錄;如果你用其他的身份登錄Windows,請改用Administrator登錄。

  現在,假設我們要在當前的機器上查找一個對象:C:驅動器。我們不知道C:驅動器在CIM或WMI中的具體名稱,瀏覽CIM Studio列出的數百個類又太麻煩,怎麼辦呢?可以使用Find按鈕(左邊上方的望遠鏡,參見圖三)。圖二顯示了點擊Find按鈕後顯示的Search for Class對話框,在這裏輸入我們猜想C:驅動器的類名稱中應當包含的單詞,然後點擊Go!按鈕。由於我們正在尋找一個命名的磁盤分區,而且我們知道Windows把這種分區叫做Logical Disk或Logical Drive,因此這裏的搜索關鍵詞可以是logical。當然,搜索關鍵詞也可以是disk,但這時會有大量的搜索結果出現。

圖二

  圖二顯示了搜索關鍵詞logical得到的結果。選擇Win32_LogicalDisk並點擊OK,圖三的窗口出現(爲什麼不選擇CIM_LogicalDisk?前面已經提到,WMI管理的所有對象都帶有Win32前綴。如果選擇CIM_LogicalDisk然後要求顯示出它的實例,不可能看到可用邏輯驅動器的任何具體信息,只能看到對應每一個可用邏輯驅動器的Win32_LogicalDisk條目)。現在,窗口的右邊顯示出Win32_logicalDisk類的屬性。可以看到,屬性的值都爲空,這是因爲我們正在查看的是一個類,而不是類的具體實例。要顯示出Win32_LogicalDisk類的實例,點擊右邊上面的Instances按鈕(右數第四)。

圖三

  點擊Instances按鈕之後,窗口顯示出當前機器上所有邏輯驅動器的實例,包括網絡邏輯驅動器。點擊設備ID爲“C:”的實例,顯示出圖四的結果。右邊窗格包含了當前實例的屬性和方法,當前邏輯驅動器的名稱顯示在右邊窗格的上方。

圖四

  利用腳本可以修改這些屬性或調用這些方法。如果對某個屬性的含義不太清楚,只需選擇Win32_LogialDisk類或Win32_LogicalDisk.DeviceID="C:"實例,再點擊Help按鈕。大多數對象的屬性和方法都有詳細的說明。

  四、腳本編程初步

  前面我們通過SDK查看了Win32_LogicalDisk類和它的屬性,下面來看看如何在腳本中訪問這些信息。如果你的系統上安裝了Microsoft Windows 2000 Resource Kit,/Program Files/Resource Kit文件夾下默認會有一個listfreespace.vbs腳本。這個腳本查詢Win32_LogicalDisk類的各個對象,分別提取一組屬性值:DeviceID,即驅動器標識符;FreeSpace,驅動器空閒空間的字節數。假設一臺機器的A:是軟盤驅動器,D:是CD-ROM驅動器,listfreespace.vbs的輸出類如:

  下面顯示了getfree.vbs腳本程序的代碼,它用更少的代碼獲取類似的信息。啓動getfree.vbs時要指定驅動器標識符,getfree.vbs將顯示出驅動器空閒空間和文件系統類型。

  在Windows命令行窗口中,執行“Wscript getfree.vbs c:”將顯示出類如圖五的結果。如果執行“Cscript getfree.vbs c:”,則提示信息以字符方式顯示。

圖五

  又如,下面的VBScript腳本提示輸入遠程機器的名字,然後關閉指定的遠程機器:

  當然,如果只有本文的知識,你還不能算是一個WMI腳本編程的高手。但現在你已經瞭解瞭如何用SDK查詢信息,如何通過腳本訪問對象的屬性和方法。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章