PowerShell
WMI i CIM
Szukaj…
Uwagi
CIM vs WMI
Począwszy od programu PowerShell 3.0 istnieją dwa sposoby pracy z klasami zarządzania w PowerShell, WMI i CIM. PowerShell 1.0 i 2.0 obsługuje tylko moduł WMI, który jest teraz zastępowany przez nowy i ulepszony moduł CIM. W późniejszej wersji programu PowerShell polecenia cmdlet WMI zostaną usunięte.
Porównanie modułów CIM i WMI:
Polecenie cmdlet CIM | Polecenie cmdlet WMI | Co to robi |
---|---|---|
Get-CimInstance | Get-WmiObject | Pobiera obiekty CIM / WMI dla klasy |
Invoke-CimMethod | Invoke-WmiMethod | Wywołuje metodę klasy CIM / WMI |
Register-CimIndicationEvent | Zarejestruj się WmiEvent | Rejestruje zdarzenie dla klasy CIM / WMI |
Remove-CimInstance | Usuń-WmiObject | Usuń obiekt CIM / WMI |
Set-CimInstance | Set-WmiInstance | Aktualizuje / zapisuje obiekt CIM / WMI |
Get-CimAssociatedInstance | Nie dotyczy | Uzyskaj powiązane instancje (połączony obiekt / klasy) |
Get-CimClass | Get-WmiObject -List | Lista klas CIM / WMI |
New-CimInstance | Nie dotyczy | Utwórz nowy obiekt CIM |
Get-CimSession | Nie dotyczy | Wyświetla listę sesji CIM |
New-CimSession | Nie dotyczy | Utwórz nową sesję CIM |
New-CimSessionOption | Nie dotyczy | Tworzy obiekt z opcjami sesji; protokół, kodowanie, wyłącz szyfrowanie itp. (do użytku z New-CimSession ) |
Remove-CimSession | Nie dotyczy | Usuwa / zatrzymuje sesję CIM |
Dodatkowe zasoby
Czy powinienem używać CIM lub WMI z Windows PowerShell? @ Hej, Skrypciarze! Blog
Zapytanie o przedmioty
CIM / WMI jest najczęściej używany do wyszukiwania informacji lub konfiguracji na urządzeniu. Klasa reprezentująca konfigurację, proces, użytkownika itp. W programie PowerShell istnieje wiele sposobów dostępu do tych klas i instancji, ale najczęstszymi sposobami są polecenia Get-CimInstance
(CIM) lub Get-WmiObject
(WMI).
Wyświetl wszystkie obiekty dla klasy CIM
Możesz wyświetlić listę wszystkich wystąpień klasy.
CIM:
> Get-CimInstance -ClassName Win32_Process
ProcessId Name HandleCount WorkingSetSize VirtualSize
--------- ---- ----------- -------------- -----------
0 System Idle Process 0 4096 65536
4 System 1459 32768 3563520
480 Secure System 0 3731456 0
484 smss.exe 52 372736 2199029891072
....
....
WMI:
Get-WmiObject -Class Win32_Process
Za pomocą filtra
Możesz zastosować filtr, aby uzyskać tylko określone wystąpienia klasy CIM / WMI. Filtry są zapisywane przy użyciu WQL
(domyślnie) lub CQL (dodaj -QueryDialect CQL
). -Filter
używa części WHERE
pełnego zapytania WQL / CQL.
CIM:
Get-CimInstance -ClassName Win32_Process -Filter "Name = 'powershell.exe'"
ProcessId Name HandleCount WorkingSetSize VirtualSize
--------- ---- ----------- -------------- -----------
4800 powershell.exe 676 88305664 2199697199104
WMI:
Get-WmiObject -Class Win32_Process -Filter "Name = 'powershell.exe'"
...
Caption : powershell.exe
CommandLine : "C:\Windows\System32\WindowsPowerShell\v1.0\powershell.exe"
CreationClassName : Win32_Process
CreationDate : 20160913184324.393887+120
CSCreationClassName : Win32_ComputerSystem
CSName : STACKOVERFLOW-PC
Description : powershell.exe
ExecutablePath : C:\Windows\System32\WindowsPowerShell\v1.0\powershell.exe
ExecutionState :
Handle : 4800
HandleCount : 673
....
Za pomocą zapytania WQL:
Możesz także użyć zapytania WQL / CQL do zapytania i filtrowania instancji.
CIM:
Get-CimInstance -Query "SELECT * FROM Win32_Process WHERE Name = 'powershell.exe'"
ProcessId Name HandleCount WorkingSetSize VirtualSize
--------- ---- ----------- -------------- -----------
4800 powershell.exe 673 88387584 2199696674816
Zapytanie o obiekty w innej przestrzeni nazw:
CIM:
> Get-CimInstance -Namespace "root/SecurityCenter2" -ClassName AntiVirusProduct
displayName : Windows Defender
instanceGuid : {D68DDC3A-831F-4fae-9E44-DA132C1ACF46}
pathToSignedProductExe : %ProgramFiles%\Windows Defender\MSASCui.exe
pathToSignedReportingExe : %ProgramFiles%\Windows Defender\MsMpeng.exe
productState : 397568
timestamp : Fri, 09 Sep 2016 21:26:41 GMT
PSComputerName :
WMI:
> Get-WmiObject -Namespace "root\SecurityCenter2" -Class AntiVirusProduct
__GENUS : 2
__CLASS : AntiVirusProduct
__SUPERCLASS :
__DYNASTY : AntiVirusProduct
__RELPATH : AntiVirusProduct.instanceGuid="{D68DDC3A-831F-4fae-9E44-DA132C1ACF46}"
__PROPERTY_COUNT : 6
__DERIVATION : {}
__SERVER : STACKOVERFLOW-PC
__NAMESPACE : ROOT\SecurityCenter2
__PATH : \\STACKOVERFLOW-PC\ROOT\SecurityCenter2:AntiVirusProduct.instanceGuid="{D68DDC3A-831F-4fae-9E44-DA132C1ACF46}"
displayName : Windows Defender
instanceGuid : {D68DDC3A-831F-4fae-9E44-DA132C1ACF46}
pathToSignedProductExe : %ProgramFiles%\Windows Defender\MSASCui.exe
pathToSignedReportingExe : %ProgramFiles%\Windows Defender\MsMpeng.exe
productState : 397568
timestamp : Fri, 09 Sep 2016 21:26:41 GMT
PSComputerName : STACKOVERFLOW-PC
Klasy i przestrzenie nazw
Istnieje wiele klas dostępnych w CIM i WMI, które są podzielone na wiele przestrzeni nazw. Najpopularniejszym (i domyślnym) obszarem nazw w systemie Windows jest root/cimv2
. Aby znaleźć klasę prawą, warto wymienić wszystkie lub wyszukać.
Wyświetl dostępne klasy
Możesz wyświetlić listę wszystkich dostępnych klas w domyślnej przestrzeni nazw ( root/cimv2
) na komputerze.
CIM:
Get-CimClass
WMI:
Get-WmiObject -List
Wyszukaj klasę
Możesz wyszukiwać określone klasy za pomocą symboli wieloznacznych. Np .: Znajdź klasy zawierające process
tekstowy.
CIM:
> Get-CimClass -ClassName "*Process*"
NameSpace: ROOT/CIMV2
CimClassName CimClassMethods CimClassProperties
------------ --------------- ------------------
Win32_ProcessTrace {} {SECURITY_DESCRIPTOR, TIME_CREATED, ParentProcessID, ProcessID...}
Win32_ProcessStartTrace {} {SECURITY_DESCRIPTOR, TIME_CREATED, ParentProcessID, ProcessID...}
Win32_ProcessStopTrace {} {SECURITY_DESCRIPTOR, TIME_CREATED, ParentProcessID, ProcessID...}
CIM_Process {} {Caption, Description, InstallDate, Name...}
Win32_Process {Create, Terminat... {Caption, Description, InstallDate, Name...}
CIM_Processor {SetPowerState, R... {Caption, Description, InstallDate, Name...}
Win32_Processor {SetPowerState, R... {Caption, Description, InstallDate, Name...}
...
WMI:
Get-WmiObject -List -Class "*Process*"
Wyświetl listę klas w innej przestrzeni nazw
Przestrzeń nazw root
nazywa się po prostu root
. Możesz wyświetlić listę klas w innej przestrzeni nazw, używając parametru -NameSpace
.
CIM:
> Get-CimClass -Namespace "root/SecurityCenter2"
NameSpace: ROOT/SecurityCenter2
CimClassName CimClassMethods CimClassProperties
------------ --------------- ------------------
....
AntiSpywareProduct {} {displayName, instanceGuid, pathToSignedProductExe, pathToSignedReportingE...
AntiVirusProduct {} {displayName, instanceGuid, pathToSignedProductExe, pathToSignedReportingE...
FirewallProduct {} {displayName, instanceGuid, pathToSignedProductExe, pathToSignedReportingE...
WMI:
Get-WmiObject -Class "__Namespace" -Namespace "root"
Wyświetl dostępne przestrzenie nazw
Aby znaleźć dostępne potomne przestrzenie nazw root
(lub innej przestrzeni nazw), przeszukaj obiekty w klasie __NAMESPACE
dla tej przestrzeni nazw.
CIM:
> Get-CimInstance -Namespace "root" -ClassName "__Namespace"
Name PSComputerName
---- --------------
subscription
DEFAULT
CIMV2
msdtc
Cli
SECURITY
HyperVCluster
SecurityCenter2
RSOP
PEH
StandardCimv2
WMI
directory
Policy
virtualization
Interop
Hardware
ServiceModel
SecurityCenter
Microsoft
aspnet
Appv
WMI:
Get-WmiObject -List -Namespace "root"