Configurações de falha para um pool de aplicativos <failure>

Visão geral

O elemento <failure> do elemento <add> na coleção <applicationPools> configura as ações a serem executadas quando um pool de aplicativos falha. Os atributos autoShutdownExe, orphanActionExe e rapidFailProtection do elemento <failure> podem ser especialmente úteis ao solucionar problemas ou depurar aplicativos, pois eles oferecem a flexibilidade para especificar a ação que os Serviços de Informações da Internet (IIS) executarão quando um aplicativo falhar, como executar um arquivo executável externo para registrar ou depurar a falha.

Compatibilidade

Versão Observações
IIS 10.0 O elemento <failure> não foi modificado no IIS 10.0.
IIS 8.5 O elemento <failure> não foi modificado no IIS 8.5.
IIS 8.0 O elemento <failure> não foi modificado no IIS 8.0.
IIS 7.5 O elemento <failure> não foi modificado no IIS 7.5.
IIS 7.0 O elemento <failure> foi introduzido no IIS 7.0.
IIS 6,0 O elemento <failure> substitui partes da propriedade de metabase IIsApplicationPools do IIS 6.0.

Instalação

A coleção <applicationPools> está incluída na instalação padrão do IIS 7.

Instruções

Como editar configurações de proteção rápida contra falhas

  1. Abra o Gerenciador dos Serviços de Informações da Internet (IIS):

    • Caso você esteja usando o Windows Server 2012 ou o Windows Server 2012 R2:

      • Na barra de tarefas, clique em Gerenciador do Servidor, em Ferramentas e em Gerenciador dos Serviços de Informações da Internet (IIS).
    • Se você estiver usando o Windows 8 ou Windows 8.1:

      • Mantenha pressionada a tecla Windows, pressione a letra X e clique em Painel de Controle.
      • Clique em Ferramentas Administrativas e clique duas vezes em Gerenciador dos Serviços de Informações da Internet (IIS).
    • Caso você esteja usando o Windows Server 2008 ou o Windows Server 2008 R2:

      • Na barra de tarefas, clique em Iniciar, vá para Ferramentas Administrativas e clique em Gerenciador dos Serviços de Informações da Internet (IIS).
    • Se você estiver usando o Windows Vista ou Windows 7:

      • Na barra de tarefas, clique em Iniciar e, depois, em Painel de Controle.
      • Clique duas vezes em Ferramentas Administrativas e clique duas vezes em Gerenciador dos Serviços de Informações da Internet (IIS).
  2. No painel Conexões, expanda o nome do servidor e clique em Pools de Aplicativos e no pool de aplicativos que deseja editar.
    Image of Connections pane displaying App Default Pool option highlighted.

  3. No painel Ações, clique em Configurações Avançadas...

  4. Na caixa de diálogo Configurações Avançadas, clique na propriedade da proteção rápida contra falhas que deseja editar, edite o valor na seção de valor da propriedade da caixa de diálogo e clique em OK. Por exemplo, altere o Intervalo de Falha (minutos) para 4 e Falhas Máximas para 4.
    Screenshot of Advanced Settings dialog box displaying Maximum Failures highlighted.

Configuração

Atributos

Atributo Descrição
autoShutdownExe Atributo de cadeia de caracteres opcional. Especifica um arquivo executável a ser executado quando o serviço WWW desliga um pool de aplicativos. Você pode usar o atributo autoShutdownParams para enviar parâmetros para o arquivo executável.
autoShutdownParams Atributo de cadeia de caracteres opcional. Especifica parâmetros de linha de comando para o arquivo executável especificado no atributo autoShutdownExe.
loadBalancerCapabilities Atributo de enumeração opcional. Especifica o comportamento quando um processo de trabalho não pode ser iniciado, como quando a fila de solicitação está cheia ou um pool de aplicativos está em proteção contra falhas rápidas. O atributo loadBalancerCapabilities pode ser um dos valores possíveis a seguir. O valor padrão é HttpLevel.

Valor Descrição
HttpLevel Especifica que um código de erro 503 foi retornado. Balanceadores de carga que não estiverem cientes de HTTP não mudarão para um nó diferente porque a resposta 503 informa ao balanceador de carga que o computador está íntegro.

O valor numérico é 2.

TcpLevel Especifica que a conexão TCP será encerrada. Isso é útil quando você usa um balanceador de carga que não esteja ciente de HTTP.

O valor numérico é 1.

orphanActionExe Atributo de cadeia de caracteres opcional. Especifica um arquivo executável a ser executado quando o serviço WWW órfão de um processo de trabalho (se o atributo orphanWorkerProcess for definido como true). Você pode usar o atributo orphanActionParams para enviar parâmetros para o arquivo executável.
orphanActionParams Atributo de cadeia de caracteres opcional. Indica parâmetros de linha de comando para o arquivo executável nomeado pelo atributo orphanActionExe. Para especificar a ID do processo órfão, use %1%.
orphanWorkerProcess Atributo booliano opcional. Especifica se um processo de trabalho deve ser atribuído a um estado órfão em vez de encerrá-lo quando um pool de aplicativos falhar.

O valor padrão é false.
rapidFailProtection Atributo booliano opcional. A configuração como true instrui o serviço WWW a remover do serviço todos os aplicativos que estão em um pool de aplicativos quando:

  • O número de falhas no processo de trabalho tiver atingido o máximo especificado no atributo rapidFailProtectionMaxCrashes.
  • As falhas ocorrem dentro do número de minutos especificado no atributo rapidFailProtectionInterval.
O valor padrão é true.
rapidFailProtectionInterval Atributo timeSpan opcional. Especifica o número de minutos antes que a contagem de falhas de um processo seja redefinida.

O valor padrão é 00:05:00 (cinco minutos).
rapidFailProtectionMaxCrashes Atributo uint opcional. Especifica o número máximo de falhas permitidas dentro do número de minutos especificado pelo atributo rapidFailProtectionInterval. Observação: a partir do IIS 7.5, esse valor deve estar entre 1 e 2147483647.

O valor padrão é 5.

Elementos filho

Nenhum.

Exemplo de configuração

O exemplo de configuração a seguir permite a proteção rápida contra falhas para um único pool de aplicativos chamado DefaultAppPool, configura um intervalo rápido de proteção contra falhas de 5 minutos e define o número máximo de falhas no número de minutos como 5.

<applicationPools>
   <add name="DefaultAppPool">
     <failure rapidFailProtection="true"
        rapidFailProtectionInterval="00:05:00"
        rapidFailProtectionMaxCrashes="5" />
   </add>
   <applicationPoolDefaults>
     <processModel identityType="NetworkService" />
   </applicationPoolDefaults>
</applicationPools>

Exemplo de código

Os exemplos de código a seguir habilitam a proteção rápida contra falhas para o DefaultAppPool no seu servidor e, em seguida, definem o intervalo de proteção como cinco minutos e definem o número máximo de falhas como 5.

AppCmd.exe

appcmd.exe set config -section:system.applicationHost/applicationPools /[name='DefaultAppPool'].failure.rapidFailProtection:"True" /commit:apphost

appcmd.exe set config -section:system.applicationHost/applicationPools /[name='DefaultAppPool'].failure.rapidFailProtectionInterval:"00:05:00" /commit:apphost

appcmd.exe set config -section:system.applicationHost/applicationPools /[name='DefaultAppPool'].failure.rapidFailProtectionMaxCrashes:"5" /commit:apphost

Observação

Defina o parâmetro commit para apphost quando usar AppCmd.exe para definir essas configurações. Isso confirma as definições de configuração para a seção de local apropriado no arquivo ApplicationHost.config.

C#

using System;
using System.Text;
using Microsoft.Web.Administration;

internal static class Sample
{

   private static void Main()
   {

      using (ServerManager serverManager = new ServerManager())
      {
         Configuration config = serverManager.GetApplicationHostConfiguration();
         ConfigurationSection applicationPoolsSection = config.GetSection("system.applicationHost/applicationPools");
         ConfigurationElementCollection applicationPoolsCollection = applicationPoolsSection.GetCollection();
         ConfigurationElement addElement = FindElement(applicationPoolsCollection, "add", "name", @"DefaultAppPool");
         if (addElement == null) throw new InvalidOperationException("Element not found!");

         ConfigurationElement failureElement = addElement.GetChildElement("failure");
         failureElement["rapidFailProtection"] = true;
         failureElement["rapidFailProtectionInterval"] = TimeSpan.Parse("00:05:00");
         failureElement["rapidFailProtectionMaxCrashes"] = 5;
         serverManager.CommitChanges();
      }
   }

   private static ConfigurationElement FindElement(ConfigurationElementCollection collection, string elementTagName, params string[] keyValues)
   {
      foreach (ConfigurationElement element in collection)
      {
         if (String.Equals(element.ElementTagName, elementTagName, StringComparison.OrdinalIgnoreCase))
         {
            bool matches = true;
            for (int i = 0; i < keyValues.Length; i += 2)
            {
               object o = element.GetAttributeValue(keyValues[i]);
               string value = null;
               if (o != null)
               {
                  value = o.ToString();
               }
               if (!String.Equals(value, keyValues[i + 1], StringComparison.OrdinalIgnoreCase))
               {
                  matches = false;
                  break;
               }
            }
            if (matches)
            {
               return element;
            }
         }
      }
      return null;
   }
}

VB.NET

Imports System
Imports System.Text
Imports Microsoft.Web.Administration

Module Sample
   Sub Main()
      Dim serverManager As ServerManager = New ServerManager
      Dim config As Configuration = serverManager.GetApplicationHostConfiguration
      Dim applicationPoolsSection As ConfigurationSection = config.GetSection("system.applicationHost/applicationPools")
      Dim applicationPoolsCollection As ConfigurationElementCollection = applicationPoolsSection.GetCollection
      Dim addElement As ConfigurationElement = FindElement(applicationPoolsCollection, "add", "name", "DefaultAppPool")

      If (addElement Is Nothing) Then
         Throw New InvalidOperationException("Element not found!")
      End If

      Dim failureElement As ConfigurationElement = addElement.GetChildElement("failure")
      failureElement("rapidFailProtection") = True
      failureElement("rapidFailProtectionInterval") = TimeSpan.Parse("00:05:00")
      failureElement("rapidFailProtectionMaxCrashes") = 5

      serverManager.CommitChanges()
   End Sub

   Private Function FindElement(ByVal collection As ConfigurationElementCollection, ByVal elementTagName As String, ByVal ParamArray keyValues() As String) As ConfigurationElement
      For Each element As ConfigurationElement In collection
         If String.Equals(element.ElementTagName, elementTagName, StringComparison.OrdinalIgnoreCase) Then
            Dim matches As Boolean = True
            Dim i As Integer
            For i = 0 To keyValues.Length - 1 Step 2
               Dim o As Object = element.GetAttributeValue(keyValues(i))
               Dim value As String = Nothing
               If (Not (o) Is Nothing) Then
                  value = o.ToString
               End If
               If Not String.Equals(value, keyValues((i + 1)), StringComparison.OrdinalIgnoreCase) Then
                  matches = False
                  Exit For
               End If
            Next
            If matches Then
               Return element
            End If
         End If
      Next
      Return Nothing
   End Function


End Module

JavaScript

var adminManager = new ActiveXObject('Microsoft.ApplicationHost.WritableAdminManager');
adminManager.CommitPath = "MACHINE/WEBROOT/APPHOST";

var applicationPoolsSection = adminManager.GetAdminSection("system.applicationHost/applicationPools", "MACHINE/WEBROOT/APPHOST");

var applicationPoolsCollection = applicationPoolsSection.Collection;

var addElementPos = FindElement(applicationPoolsCollection, "add", ["name", "DefaultAppPool"]);
if (addElementPos == -1) throw "Element not found!";
var addElement = applicationPoolsCollection.Item(addElementPos);

var failureElement = addElement.ChildElements.Item("failure");
failureElement.Properties.Item("rapidFailProtection").Value = true;
failureElement.Properties.Item("rapidFailProtectionInterval").Value = "00:05:00";
failureElement.Properties.Item("rapidFailProtectionMaxCrashes").Value = 5;

adminManager.CommitChanges();

function FindElement(collection, elementTagName, valuesToMatch) {
   for (var i = 0; i < collection.Count; i++) {
      var element = collection.Item(i);
      if (element.Name == elementTagName) {
         var matches = true;
         for (var iVal = 0; iVal < valuesToMatch.length; iVal += 2) {
            var property = element.GetPropertyByName(valuesToMatch[iVal]);
            var value = property.Value;
            if (value != null) {
               value = value.toString();
            }
            if (value != valuesToMatch[iVal + 1]) {
               matches = false;
               break;
            }
         }
         if (matches) {
            return i;
         }
      }
   }
   return -1;
}

VBScript

Set adminManager = WScript.CreateObject("Microsoft.ApplicationHost.WritableAdminManager")
adminManager.CommitPath = "MACHINE/WEBROOT/APPHOST"
Set applicationPoolsSection = adminManager.GetAdminSection("system.applicationHost/applicationPools", "MACHINE/WEBROOT/APPHOST")
Set applicationPoolsCollection = applicationPoolsSection.Collection
addElementPos = FindElement(applicationPoolsCollection, "add", Array("name", "DefaultAppPool"))

If (siteElementPos = -1) Then
   WScript.Echo "Element not found!"
   WScript.Quit
End If

Set addElement = applicationPoolsCollection.Item(addElementPos)
Set failureElement = addElement.ChildElements.Item("failure")
failureElement.Properties.Item("rapidFailProtection").Value = true
failureElement.Properties.Item("rapidFailProtectionInterval").Value = "00:05:00"
failureElement.Properties.Item("rapidFailProtectionMaxCrashes").Value = 5

adminManager.CommitChanges()

Function FindElement(collection, elementTagName, valuesToMatch)
   For i = 0 To CInt(collection.Count) - 1
      Set element = collection.Item(i)
      If element.Name = elementTagName Then
         matches = True
         For iVal = 0 To UBound(valuesToMatch) Step 2
            Set property = element.GetPropertyByName(valuesToMatch(iVal))
            value = property.Value
            If Not IsNull(value) Then
               value = CStr(value)
            End If
            If Not value = CStr(valuesToMatch(iVal + 1)) Then
               matches = False
               Exit For
            End If
         Next
         If matches Then
            Exit For
         End If
      End If
   Next
   If matches Then
      FindElement = i
   Else
      FindElement = -1
   End If
End Function