Debug-Storage Sub System

Finds problems with a storage subsystem and recommends solutions.

Syntax

Debug-StorageSubSystem
     [-StorageSubSystemFriendlyName] <String[]>
     [-CimSession <CimSession>]
     [-ThrottleLimit <Int32>]
     [-AsJob]
     [<CommonParameters>]
Debug-StorageSubSystem
     -StorageSubSystemUniqueId <String[]>
     [-CimSession <CimSession>]
     [-ThrottleLimit <Int32>]
     [-AsJob]
     [<CommonParameters>]
Debug-StorageSubSystem
     -StorageSubSystemName <String[]>
     [-CimSession <CimSession>]
     [-ThrottleLimit <Int32>]
     [-AsJob]
     [<CommonParameters>]
Debug-StorageSubSystem
     -InputObject <CimInstance>
     [-CimSession <CimSession>]
     [-ThrottleLimit <Int32>]
     [-AsJob]
     [<CommonParameters>]

Description

The Debug-StorageSubSystem cmdlet finds problems with a storage subsystem and recommends solutions.

Examples

Example 1: Debug the local storage subsystem

PS C:\>Get-StorageSubsystem | Debug-StorageSubSystem

This command gets the local storage subsystem and passes it to the Debug-StorageSubsystem cmdlet. The current cmdlet generates a health report for the storage subsystem.

Required Parameters

-InputObject

Specifies the input object that is used in a pipeline command.

Type: CimInstance
Position: Named
Default value: None
Accept pipeline input: True (ByValue)
Accept wildcard characters: False
-StorageSubSystemFriendlyName

Specifies the friendly name of the Storage subsystem for which to gather storage diagnostics. It may denote the Storage subsystem of the local computer (on which the cmdlet is run) or a remote Storage subsystem (standalone or cluster).

Selecting the local subsystem:

  • On a standalone machine, no remote subsystems: All logs are gathered for that computer.

  • On a standalone machine, remote subsystems registered: All logs are gathered for the standalone machine, including the client-side remoting calls.

  • On a cluster node: All logs for that particular cluster node are gathered, even ones that belong in the cluster subsystem for that node only. None of the other nodes are logged.

Selecting the cluster subsystem:

  • All logs are gathered for each node in that cluster. This includes and logs or tracing that may correspond to a node's local subsystem.

Selecting a remote subsystem:

  • Tracing and logs are only gathered for the remote endpoint. What logs and tracing are gathered depend on whether it is a cluster or a standalone machine (see above cases).

  • Tracing and logs for the client-side operations (running on the management node) are not collected. It is expected that if there is a failure, it is most likely in the remote subsystem.

In order to gather the client-side calls, you must also include the management node's local subsystem.

Type: String[]
Position: 0
Default value: None
Accept pipeline input: True (ByValue)
Accept wildcard characters: False
-StorageSubSystemName

Specifies the name of the Storage subsystem for which to gather Storage diagnostics. It may denote the Storage subsystem of the local computer (on which the cmdlet is run) or a remote Storage subsystem (standalone or cluster).

Selecting the local subsystem:

  • On a standalone machine, no remote subsystems: All logs are gathered for that computer.

  • On a standalone machine, remote subsystems registered: All logs are gathered for the standalone machine, including the client-side remoting calls.

  • On a cluster node: All logs for that particular cluster node are gathered, even ones that belong in the cluster subsystem for that node only. None of the other nodes are logged.

Selecting the cluster subsystem:

  • All logs are gathered for each node in that cluster. This includes and logs or tracing that may correspond to a node's local subsystem.

Selecting a remote subsystem:

  • Tracing and logs are only gathered for the remote endpoint. What logs and tracing are gathered depend on whether it is a cluster or a standalone machine (see above cases).

  • Tracing and logs for the client-side operations (running on the management node) are not collected. It is expected that if there is a failure, it is most likely in the remote subsystem.

In order to gather the client-side calls, you must also include the management node's local subsystem.

Type: String[]
Position: Named
Default value: None
Accept pipeline input: True (ByValue)
Accept wildcard characters: False
-StorageSubSystemUniqueId

Specifies the unique ID of the Storage subsystem for which to gather Storage diagnostics. It may denote the Storage subsystem of the local computer (on which the cmdlet is run) or a remote Storage subsystem (standalone or cluster).

Selecting the local subsystem:

  • On a standalone machine, no remote subsystems: All logs are gathered for that computer.

  • On a standalone machine, remote subsystems registered: All logs are gathered for the standalone machine, including the client-side remoting calls.

  • On a cluster node: All logs for that particular cluster node are gathered, even ones that belong in the cluster subsystem for that node only. None of the other nodes are logged.

Selecting the cluster subsystem:

  • All logs are gathered for each node in that cluster. This includes and logs or tracing that may correspond to a node's local subsystem.

Selecting a remote subsystem:

  • Tracing and logs are only gathered for the remote endpoint. What logs and tracing are gathered depend on whether it is a cluster or a standalone machine (see above cases).

  • Tracing and logs for the client-side operations (running on the management node) are not collected. It is expected that if there is a failure, it is most likely in the remote subsystem.

In order to gather the client-side calls, you must also include the management node's local subsystem.

Type: String[]
Position: Named
Default value: None
Accept pipeline input: True (ByValue)
Accept wildcard characters: False

Optional Parameters

-AsJob

Runs the cmdlet as a background job. Use this parameter to run commands that take a long time to complete.

Type: SwitchParameter
Position: Named
Default value: None
Accept pipeline input: False
Accept wildcard characters: False
-CimSession

Runs the cmdlet in a remote session or on a remote computer. Enter a computer name or a session object, such as the output of a New-CimSession or Get-CimSession cmdlet. The default is the current session on the local computer.

Type: CimSession
Position: Named
Default value: None
Accept pipeline input: False
Accept wildcard characters: False
-ThrottleLimit

Specifies the maximum number of concurrent operations that can be established to run the cmdlet. If this parameter is omitted or a value of 0 is entered, then Windows PowerShell® calculates an optimum throttle limit for the cmdlet based on the number of CIM cmdlets that are running on the computer. The throttle limit applies only to the current cmdlet, not to the session or to the computer.

Type: Int32
Position: Named
Default value: None
Accept pipeline input: False
Accept wildcard characters: False