Get-Service
ローカルまたはリモート コンピューター上のサービスを取得します。
構文
Get-Service
[[-Name] <String[]>]
[-ComputerName <String[]>]
[-DependentServices]
[-RequiredServices]
[-Include <String[]>]
[-Exclude <String[]>]
[<CommonParameters>]
Get-Service
[-ComputerName <String[]>]
[-DependentServices]
[-RequiredServices]
-DisplayName <String[]>
[-Include <String[]>]
[-Exclude <String[]>]
[<CommonParameters>]
Get-Service
[-ComputerName <String[]>]
[-DependentServices]
[-RequiredServices]
[-Include <String[]>]
[-Exclude <String[]>]
[-InputObject <ServiceController[]>]
[<CommonParameters>]
説明
Get-Service
コマンドレットは、実行中のサービスや停止されたサービスを含む、ローカル コンピューターまたはリモート コンピューター上のサービスを表すオブジェクトを取得します。 既定では、パラメーターなしで Get-Service
を実行すると、ローカル コンピューターのすべてのサービスが返されます。
サービス名またはサービスの表示名を指定して特定のサービスのみを取得するようにこのコマンドレットを指示するか、サービス オブジェクトをこのコマンドレットにパイプできます。
例
例 1: コンピューター上のすべてのサービスを取得する
この例では、コンピューター上のすべてのサービスを取得します。 Get-Service *
を入力したかのように動作します。 既定では、各サービスの状態、サービス名、表示名が表示されます。
Get-Service
例 2: 検索文字列で始まるサービスを取得する
この例では、サービス名が WMI
(Windows Management Instrumentation) で始まるサービスを取得します。
Get-Service "wmi*"
例 3: 検索文字列を含むサービスを表示する
次の使用例は、 network
という単語を含む表示名を持つサービスを表示します。 表示名を検索すると、サービス名に xmlprov、ネットワーク プロビジョニング サービスなどの Net
が含まれていない場合でも、ネットワーク関連のサービスが検索されます。
Get-Service -Displayname "*network*"
例 4: 検索文字列と除外で始まるサービスを取得する
この例では、WinRM サービスを除き、 win
で始まるサービス名を持つサービスのみを取得します。
Get-Service -Name "win*" -Exclude "WinRM"
例 5: 現在アクティブなサービスを表示する
次の使用例は、状態が Running
のサービスのみを表示します。
Get-Service | Where-Object {$_.Status -eq "Running"}
Get-Service
は、コンピューター上のすべてのサービスを取得し、オブジェクトをパイプラインに送信します。 Where-Object
コマンドレットは、Status プロパティがRunning
のサービスのみを選択します。
Status は、サービス オブジェクトの 1 つのプロパティにすぎません。 すべてのプロパティを表示するには、「 Get-Service | Get-Member
」と入力します。
例 6: リモート コンピューターでサービスを取得する
Get-Service -ComputerName "Server02"
このコマンドは、Server02 リモート コンピューター上のサービスを取得します。
Get-Service
の ComputerName パラメーターは Windows PowerShell リモート処理を使用しないため、コンピューターが Windows PowerShell でリモート処理用に構成されていない場合でも、このパラメーターを使用できます。
例 7: 依存サービスを持つローカル コンピューター上のサービスを一覧表示する
この例では、依存サービスを持つサービスを取得します。
Get-Service |
Where-Object {$_.DependentServices} |
Format-List -Property Name, DependentServices, @{
Label="NoOfDependentServices"; Expression={$_.dependentservices.count}
}
Name : AudioEndpointBuilder
DependentServices : {AudioSrv}
NoOfDependentServices : 1
Name : Dhcp
DependentServices : {WinHttpAutoProxySvc}
NoOfDependentServices : 1
...
Get-Service
コマンドレットは、コンピューター上のすべてのサービスを取得し、パイプラインにオブジェクトを送信します。 Where-Object
コマンドレットは、DependentServices プロパティが null ではないサービスを選択します。
結果は、パイプラインから Format-List
コマンドレットに送信されます。 Property パラメーターには、サービスの名前、依存サービスの名前、および各サービスの依存サービスの数を表示する計算プロパティが表示されます。
例 8: プロパティ値でサービスを並べ替える
この例では、サービスを Status プロパティの値で昇順に並べ替えると、サービスを実行する前に停止したサービスが表示されることを示します。 これは、 Status の値が列挙体であり、 Stopped
が 1
の値を持ち、 Running
が 4
の値を持っているために発生します。 詳細については、「 ServiceControllerStatus」を参照してください。
実行中のサービスを最初に一覧表示するには、Sort-Object
コマンドレットの Descending パラメーターを使用します。
Get-Service "s*" | Sort-Object status
Status Name DisplayName
------ ---- -----------
Stopped stisvc Windows Image Acquisition (WIA)
Stopped SwPrv MS Software Shadow Copy Provider
Stopped SysmonLog Performance Logs and Alerts
Running Spooler Print Spooler
Running srservice System Restore Service
Running SSDPSRV SSDP Discovery Service
Running ShellHWDetection Shell Hardware Detection
Running Schedule Task Scheduler
Running SCardSvr Smart Card
Running SamSs Security Accounts Manager
Running SharedAccess Windows Firewall/Internet Connectio...
Running SENS System Event Notification
Running seclogon Secondary Logon
例 9: 複数のコンピューターでサービスを取得する
Get-Service -Name "WinRM" -ComputerName "localhost", "Server01", "Server02" |
Format-Table -Property MachineName, Status, Name, DisplayName -auto
MachineName Status Name DisplayName
------------ ------ ---- -----------
localhost Running WinRM Windows Remote Management (WS-Management)
Server01 Running WinRM Windows Remote Management (WS-Management)
Server02 Running WinRM Windows Remote Management (WS-Management)
このコマンドでは、Get-Service
コマンドレットを使用して、2 台のリモート コンピューターとローカル コンピューター (localhost
) でGet-Service Winrm
コマンドを実行します。
コマンドはリモート コンピューターで実行され、結果はローカル コンピューターに返されます。 パイプライン演算子 (|
) は、サービスをテーブルとして書式設定する Format-Table
コマンドレットに結果を送信します。 Format-Table
コマンドでは、Property パラメーターを使用して、テーブルに表示されるプロパティ (MachineName プロパティを含む) を指定します。
例 10: サービスの依存サービスを取得する
この例では、WinRM サービスに必要なサービスを取得します。 サービスの ServicesDependedOn プロパティの値が返されます。
Get-Service "WinRM" -RequiredServices
例 11: パイプライン 演算子を使用してサービスを取得する
この例では、ローカル コンピューター上の WinRM サービスを取得します。 サービス名の文字列は引用符で囲んで、パイプラインから Get-Service
に送信されます。
"WinRM" | Get-Service
パラメーター
-ComputerName
指定されたコンピューターで実行されているサービスを取得します。 既定値はローカル コンピューターです。
リモート コンピューターの NetBIOS 名、IP アドレス、または完全修飾ドメイン名 (FQDN) を入力します。
ローカル コンピューターを指定するには、コンピューター名、ドット (.
)、または localhost
を入力します。
このパラメーターは、Windows PowerShell リモート処理に依存しません。 コンピューターがリモート コマンドを実行するように構成されていない場合でも、Get-Service
の ComputerName パラメーターを使用できます。
型: | String[] |
Aliases: | Cn |
配置: | Named |
規定値: | None |
必須: | False |
パイプライン入力を受け取る: | True |
ワイルドカード文字を受け取る: | False |
-DependentServices
このコマンドレットは、指定されたサービスに依存するサービスのみを取得することを示します。
型: | SwitchParameter |
Aliases: | DS |
配置: | Named |
規定値: | False |
必須: | False |
パイプライン入力を受け取る: | False |
ワイルドカード文字を受け取る: | False |
-DisplayName
取得するサービスの表示名を文字列配列として指定します。 ワイルドカードを使用できます。
型: | String[] |
配置: | Named |
規定値: | None |
必須: | True |
パイプライン入力を受け取る: | False |
ワイルドカード文字を受け取る: | True |
-Exclude
文字列配列として、このコマンドレットが操作から除外するサービスを指定します。
このパラメーターの値は、 Name パラメーターを修飾します。 s*
などの名前要素またはパターンを入力します。 ワイルドカードを使用できます。
型: | String[] |
配置: | Named |
規定値: | None |
必須: | False |
パイプライン入力を受け取る: | False |
ワイルドカード文字を受け取る: | True |
-Include
文字列配列として、このコマンドレットが操作に含めるサービスを指定します。 このパラメーターの値は、 Name パラメーターを修飾します。 s*
などの名前要素またはパターンを入力します。 ワイルドカードを使用できます。
型: | String[] |
配置: | Named |
規定値: | None |
必須: | False |
パイプライン入力を受け取る: | False |
ワイルドカード文字を受け取る: | True |
-InputObject
取得するサービスを表す ServiceController オブジェクトを指定します。 オブジェクトが格納されている変数を入力するか、オブジェクトを取得するコマンドまたは式を入力します。 サービス オブジェクトをこのコマンドレットにパイプできます。
型: | ServiceController[] |
配置: | Named |
規定値: | None |
必須: | False |
パイプライン入力を受け取る: | True |
ワイルドカード文字を受け取る: | False |
-Name
取得するサービスのサービス名を指定します。 ワイルドカードを使用できます。
型: | String[] |
Aliases: | ServiceName |
配置: | 0 |
規定値: | None |
必須: | False |
パイプライン入力を受け取る: | True |
ワイルドカード文字を受け取る: | True |
-RequiredServices
このコマンドレットは、このサービスに必要なサービスのみを取得することを示します。 このパラメーターは、サービスの ServicesDependedOn プロパティの値を取得します。
型: | SwitchParameter |
Aliases: | SDO, ServicesDependedOn |
配置: | Named |
規定値: | False |
必須: | False |
パイプライン入力を受け取る: | False |
ワイルドカード文字を受け取る: | True |
入力
サービス オブジェクトをこのコマンドレットにパイプできます。
サービス名をこのコマンドレットにパイプできます。
出力
このコマンドレットは、コンピューター上のサービスを表すオブジェクトを返します。
メモ
Windows PowerShell には、 Get-Service
の次のエイリアスが含まれています。
gsv
このコマンドレットは、現在のユーザーがサービスを表示するアクセス許可を持っている場合にのみサービスを表示できます。 このコマンドレットでサービスが表示されない場合は、サービスを表示するアクセス許可がない可能性があります。
システム上の各サービスのサービス名と表示名を見つけるには、「 Get-Service
」と入力します。 サービス名は Name 列に表示され、表示名は DisplayName 列に表示されます。
Note
通常、 Get-Service
はドライバーではなくサービスに関する情報を返します。 ただし、ドライバーの名前を指定すると、 Get-Service
はドライバーに関する情報を返します。
- 列挙にデバイス ドライバー サービスが含まれていない
- ワイルドカードを指定すると、コマンドレットは Windows サービスのみを返します
- デバイス サービス名と完全に一致する Name または DisplayName を指定すると、デバイス インスタンスが返されます。
状態値で昇順に並べ替えると、サービスStopped
Running
前にサービスが表示されます。 サービスの Status プロパティは、状態の名前が整数値を表す列挙値です。 並べ替えは名前ではなく整数値に基づいて行われます。 Running
Stopped
は1
の値を持ち、Running
には4
の値があるため、Stopped
の前に表示されます。 詳細については、「 ServiceControllerStatus」を参照してください。
関連リンク
PowerShell