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
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).
No painel Conexões, expanda o nome do servidor e clique em Pools de Aplicativos e no pool de aplicativos que deseja editar.
No painel Ações, clique em Configurações Avançadas...
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.
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 .
|
||||||
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:
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