Compartir vía


Problemas comunes que hacen que se reciclen los roles del servicio en la nube de Azure (clásico)

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) .

En este artículo se describen algunas de las causas comunes de problemas relacionados con la implementación y se proporcionan sugerencias para la resolución de dichos problemas. Aparece una indicación de que existe un problema con una aplicación cuando la instancia de rol no se inicia o cuando alterna entre los estados inicializando, ocupado y deteniendo.

Si el problema de Azure no se trata en este artículo, visite los foros de Azure en Microsoft Q&A y Stack Overflow. Puede publicar su problema en ellos o en @AzureSupport en Twitter. También puede enviar una solicitud de soporte técnico de Azure. Para enviar una solicitud de soporte técnico, en la página de soporte técnico de Azure, seleccione Obtener soporte técnico.

Dependencias en tiempo de ejecución que faltan

Si un rol de la aplicación se basa en algún ensamblado que no forma parte de .NET Framework o de la biblioteca administrada de Azure, debe incluir explícitamente ese ensamblado en el paquete de aplicación. Tenga presente que otros marcos de trabajo de Microsoft no están disponibles en Azure de forma predeterminada. Si el rol se basa en uno de esos marcos de trabajo, debe agregar esos ensamblados al paquete de la aplicación.

Antes de compilar y empaquetar su aplicación, compruebe que las siguientes afirmaciones son ciertas:

  • Si usa Visual Studio, asegúrese de que la propiedad Copiar Local esté establecida enVerdadero para cada ensamblado al que se hace referencia en el proyecto que no forme parte del SDK de Azure ni de .NET Framework.
  • Asegúrese de que el archivo web.config no hace referencia a ningún ensamblado sin usar en el elemento de compilación.
  • El elemento Build Action de cada archivo .cshtml se establece en Content. Esta configuración garantiza que los archivos aparezcan correctamente en el paquete y habilita la aparición de otros archivos referenciados en el paquete.

El ensamblado tiene como destino la plataforma equivocada

Azure es un entorno de 64 bits. Por lo tanto, los ensamblados de .NET compilados para un destino de 32 bits no son compatibles con Azure.

El rol genera excepciones no controladas cuando se inicializa o se detiene

Todas las excepciones iniciadas por los métodos de la clase RoleEntryPoint, que incluye los métodos OnStart, OnStop y Run, son excepciones no controladas. Si se produce una excepción no controlada en uno de estos métodos, el rol se recicla. Si el rol se recicla de forma repetida, es posible que inicie una excepción no controlada cada vez que intente iniciarse.

El rol se devuelve del método Run

El método Ejecutar está pensado para que se ejecute indefinidamente. Si el código invalida el método Ejecutar , podría quedar inactivo indefinidamente. Si se devuelve el método Ejecutar , el rol se recicla.

Configuración incorrecta de DiagnosticsConnectionString

Si la aplicación usa Diagnósticos de Azure, el archivo de configuración de servicio debe especificar el valor de configuración de DiagnosticsConnectionString . Este valor debe especificar una conexión HTTPS a la cuenta de almacenamiento de Azure.

Para asegurarse de que la configuración de DiagnosticsConnectionString es correcta antes de implementar su paquete de aplicaciones en Azure, compruebe que las siguientes afirmaciones son ciertas:

  • El valor de DiagnosticsConnectionString apunta a una cuenta de almacenamiento válida de Azure.
    De forma predeterminada, este valor apunta a la cuenta de almacenamiento emulado, por lo que debe cambiar explícitamente esta configuración antes de implementar el paquete de aplicación. Si no cambia este valor, se produce una excepción cuando la instancia de rol intenta iniciar al monitor de diagnóstico. Este evento puede hacer que la instancia de rol se recicle indefinidamente.
  • La cadena de conexión se especifica en el siguiente formato. (El protocolo debe especificarse como HTTPS). Reemplace MyAccountName por el nombre de su cuenta de almacenamiento y MyAccountKey por la clave de acceso de su cuenta:
DefaultEndpointsProtocol=https;AccountName=MyAccountName;AccountKey=MyAccountKey

Si está desarrollando una aplicación con Azure Tools para Microsoft Visual Studio, puede usar las páginas de propiedades para establecer este valor.

El certificado exportado no incluye una clave privada

Para ejecutar un rol web bajo Seguridad de la capa de transporte (TLS), debe asegurarse de que su certificado de administración exportado incluye la clave privada. Si usa el administrador de certificados de Windows para exportar el certificado, asegúrese de seleccionar en la opción Exportar la clave privada. El certificado se debe exportar al formato .pfx, que es el único formato que se admite actualmente.

Pasos siguientes

Vea más artículos de solución de problemas para servicios en la nube.

En la series de blogs de Kevin Williamsonpuede ver más escenarios de reciclaje de roles.