Personalizar el ciclo de vida de un rol web o de trabajo en .NET
Importante
Cloud Services (clásico) ahora está en desuso para todos los clientes a partir del 1 de septiembre de 2024. Microsoft detendrá y apagará las implementaciones en ejecución existentes y los datos se perderán permanentemente a partir de octubre de 2024. Las nuevas implementaciones deben utilizar el nuevo modelo de implementación basado en Azure Resource Manager Azure Cloud Services (soporte extendido) .
Cuando cree un rol de trabajo, amplíe la clase RoleEntryPoint que ofrece métodos para invalidar que le permiten responder a eventos del ciclo de vida. Para los roles web esta clase es opcional, por lo que debe usarla para responder a eventos del ciclo de vida.
Extender la clase RoleEntryPoint
La clase RoleEntryPoint incluye métodos a los que llama Azure cuando se inicia, se ejecuta o se detiene un rol web o de trabajo. Opcionalmente, puede invalidar estos métodos para administrar la inicialización de roles, las secuencias de apagado de rol o el subproceso de ejecución del rol.
Al extender RoleEntryPoint, debe tener en cuenta los siguientes comportamientos de los métodos:
El método OnStart devuelve un valor booleano, por lo que es posible devolver false desde este método.
Si el código devuelve false, el proceso del rol finaliza precipitadamente, sin ejecutar ninguna secuencia de apagado que pueda tener implantada. En general, debería evitar devolver false del método OnStart.
Cualquier excepción no detectada en una sobrecarga de un método RoleEntryPoint se trata como una excepción no controlada.
Si se produce una excepción dentro de uno de los métodos del ciclo de vida, Azure genera el evento UnhandledException y luego finaliza el proceso. Después de que el rol se desconecte, Azure lo reinicia. Cuando se inicia una excepción no controlada, no se genera el evento Stopping y no se llama al método OnStop.
Si el rol no se inicia, o se recicla entre los estados de inicialización, ocupado y detención, el código puede iniciar una excepción no controlada en uno de los eventos de ciclo de vida cada vez que se reinicie el rol. En este caso, use el evento UnhandledException para determinar la causa de la excepción y controlarla de manera adecuada. Puede que su rol también se pueda devolver desde el método Ejecutar , que hace que se reinicie el rol. Para obtener más información acerca de los estados de implementación, vea Problemas comunes que hacen que se reciclen los roles.
Nota:
Si está usando la Azure Tools para Microsoft Visual Studio para desarrollar su aplicación, las plantillas de proyecto de rol extienden automáticamente la clase RoleEntryPoint, en los archivos WebRole.cs y WorkerRole.cs.
Método OnStart
Al método OnStart se llama cuando Azure pone en línea la instancia de rol. Mientras se ejecuta el código OnStart, la instancia de rol se marca como ocupada y el equilibrador de carga no le dirige ningún tráfico externo. Puede invalidar este método para realizar trabajo de inicialización, como la implementación de controladores de eventos el inicio de Diagnósticos de Azure.
Si OnStart devuelve true, la instancia se inicializa correctamente y Azure llama al método RoleEntryPoint.Run. Si OnStart devuelve false, el rol finaliza de inmediato, sin ejecutar ninguna secuencia de apagado planeado.
En el ejemplo de código siguiente se muestra cómo invalidar el método OnStart . Este método configura e inicia un monitor de diagnóstico cuando se inicia la instancia de rol y se configura una transferencia de datos de registro a una cuenta de almacenamiento:
public override bool OnStart()
{
var config = DiagnosticMonitor.GetDefaultInitialConfiguration();
config.DiagnosticInfrastructureLogs.ScheduledTransferLogLevelFilter = LogLevel.Error;
config.DiagnosticInfrastructureLogs.ScheduledTransferPeriod = TimeSpan.FromMinutes(5);
DiagnosticMonitor.Start("DiagnosticsConnectionString", config);
return true;
}
Método OnStop
El método OnStop se llama después de que Azure desconecte una instancia de rol Azure y antes de que salga el proceso. Puede invalidar este método para llamar al código necesario para que la instancia de rol se desconecte sin errores.
Importante
El código que se ejecuta en el método OnStop tiene un tiempo limitado para finalizar cuando se llama por motivos distintos del apagado iniciado por un usuario. Después de que transcurra este tiempo, el proceso finaliza, por lo que debe asegurarse de que el código del método OnStop puede ejecutarse rápidamente o de que no tolera que no haya ninguna ejecución para finalizar. Al método OnStop se le llama después de que se genere el evento Deteniendo.
Método Run
Puede invalidar el método Run para implementar un subproceso de larga ejecución para su instancia de rol.
No es necesario invalidar el método Run; la implementación predeterminada inicia un subproceso que se mantiene en suspensión indefinidamente. Si invalida el método Run , el código debe bloquearse indefinidamente. Si el método Run devuelve un valor, el rol se recicla automáticamente; es decir, Azure genera el evento Stopping y llama al método OnStop para que las secuencias de apagado se puedan ejecutar antes de que el rol se quede sin conexión.
Implementación de los métodos del ciclo de vida de ASP.NET para un rol web
Puede usar los métodos del ciclo de vida de ASP.NET, además de los proporcionados por la clase RoleEntryPoint, para administrar las secuencias de inicialización y apagado de un rol web. Este enfoque puede ser útil para fines de compatibilidad si va a portar una aplicación de ASP.NET existente a Azure. Se llama a los métodos de ciclo de vida de ASP.NET desde los métodos RoleEntryPoint . Se llama al método Application_Start después de que finalice el método RoleEntryPoint.OnStart. Se llama al método Application_End antes de llamar al método RoleEntryPoint.OnStop.
Pasos siguientes
Aprenda cómo crear un paquete de servicio en la nube.