Compartilhar via


WorkerProcess.GetState Method2

Retorna o estado de tempo de execução de um processo de trabalho.

Sintaxe

oWorkerProcess.GetState  
var workerProcessState = objWorkerProcess.GetState();  

Parâmetros

Este método não aceita parâmetros.

Valor de retorno

Um uint32 que identifica o estado do pool de aplicativos. Os valores retornados são mostrados na tabela a seguir.

Valor retornado Descrição
0 Indica que o processo de trabalho está sendo iniciado.
1 Indica que o processo de trabalho está em execução.
2 Indica que o processo de trabalho está parando.
3 Indica que o processo de trabalho é desconhecido.

Comentários

Esse método é novo para o provedor WMI do IIS 7 e não tem equivalente no IIS 6.0.

Exemplo

O exemplo a seguir retorna o estado de cada processo de trabalho em cada pool de aplicativos em um servidor.

' Connect to the WMI WebAdministration namespace.  
Set oWebAdmin = GetObject("winmgmts:root\WebAdministration")  
  
' Return all application pools that are present on the server.  
Set colAppPools = oWebAdmin.ExecQuery("SELECT * FROM ApplicationPool")  
  
' Return each application pool name.  
For Each oAppPool In colAppPools  
    WScript.Echo oAppPool.Name  
    WScript.Echo String(Len(oAppPool.Name), "-")  
  
    ' Get all worker processes in the application pool.  
    Set oWorkerProcesses = _  
        oAppPool.Associators_("ApplicationPoolContainsProcess")  
  
    ' Return each worker process ID and report its state by using  
    ' the GetStateDescription helper function.  
    For Each oWorkerProcess In oWorkerProcesses  
        WScript.Echo "Process ID " & oWorkerProcess.ID & _  
            " is " & GetStateDescription(oWorkerProcess.GetState) & "."  
    Next  
    WScript.Echo  
Next  
  
' Return the text string that corresponds to the state code.  
Function GetStateDescription(StateCode)  
    Select Case StateCode  
        Case 0  
            GetStateDescription = "starting"  
        Case 1  
            GetStateDescription = "running"  
        Case 2  
            GetStateDescription = "stopping"  
        Case 3  
            GetStateDescription = "unknown"  
        Case Else  
            GetStateDescription = _  
                "Attempt to retrieve worker process state failed."  
    End Select  
End Function  

Como WorkerProcess é um objeto transitório, o estado relatado pelo WMI quando o script é executado pode não ser mais válido após algum tempo decorrido.

Requisitos

Tipo Descrição
Cliente – IIS 7.0 no Windows Vista
– IIS 7.5 no Windows 7
– IIS 8.0 no Windows 8
– IIS 10.0 no Windows 10
Servidor – IIS 7.0 no Windows Server 2008
– IIS 7.5 no Windows Server 2008 R2
– IIS 8.0 no Windows Server 2012
– IIS 8.5 no Windows Server 2012 R2
– IIS 10.0 no Windows Server 2016
Product – IIS 7.0, IIS 7.5, IIS 8.0, IIS 8.5, IIS 10.0
Arquivo MOF WebAdministration.mof

Confira também

ApplicationPool Class
ApplicationPoolContainsProcess Class
WorkerProcess Class