Desplegando una aplicación web de ASP.NET Core 3 en Azure App Service
Introducción
A principios de esta semana, Microsoft ha anunciado la disponibilidad de una nueva versión de .NET Core, en concreto .NET Core 3.0.
Con ello, una nueva versión de ASP.NET Core 3.0 ha sido también publicada alineada con nuevas versiones de otros paquetes.
Una de las preguntas que podemos hacernos en este caso es a partir de qué momento podremos utilizar .NET Core 3.0 en nuestras aplicaciones desplegadas en Azure.
Siendo de Microsoft todo, parece que esto debería ocurrir de forma inmediata, pero los cierto es que de momento Microsoft no tiene desplegada esta posibilidad, aunque debería ser prácticamente inminente la opción de utilizar .NET Core 3.0 en nuestros despliegues en Azure.
Así que si si el tiempo te apremia y no puedes esperar a que Microsoft tenga preparado todo para poder desplegar tu aplicación web en Azure utilizando ASP.NET Core 3.0, quiero que sepas que hay una forma de hacerlo.
En esta entrada te mostraré el proceso de cómo desplegar tu Azure App Service «por la puerta de atrás» para que utilice .NET Core 3.0.
Crear nuestra Azure App Service
Lo primero de todo es tener una Azure App Service ya preparada en Azure, y una aplicación de ASP.NET Core 3.0 lista para ser desplegada.
A la hora de crear nuestra Azure App Service veremos que el Runtime stack disponible es bastante amplio, pero aún no tenemos .NET 3.0 entre la lista de versiones disponibles de .NET Core.
Al crear nuestra Web App y en mi caso, he seleccionado .NET Core 2.2, si bien y como luego veremos, no tenemos que preocuparnos de este detalle.
Desarrollar nuestra aplicación Web
Una vez que hemos creado nuestra Web App, el siguiente paso es desarrollar nuestra aplicación Web de ASP.NET Core 3.0.
En mi caso he creado una aplicación MVC estándar de acuerdo a la plantilla de Visual Studio 2019.
La única salvedad es que he escrito un pequeño texto dentro de la vista Index.cshtml por aquello de comprobar de manera formal que realmente está en Azure, pero no es necesario ya que no es ni relevante ni necesario.
Desplegar nuestra aplicación web en Azure
Llegó la hora del despliegue de nuestra aplicación Web en Azure Web App.
A la hora de desplegar, voy a hacerlo con Visual Studio 2019 y para ello, voy a descargarme el publish profile de mi Azure Web App desde el portal de Azure.
Voy a hacer clic con el botón derecho del ratón sobre el proyecto, y voy a seleccionar la opción Publish.
Aparecerá una ventana similar a la siguiente:
En la ventana de publicación que aparecer, voy a pulsar sobre el botón Import Profile para importar el fichero que habremos descargado de nuestra Azure Web App en el paso anterior.
Aparecerá una ventana a modo resumen como la que se indica a continuación:
Pulsaremos a continuación el botón Publish para publicar nuestra aplicación Web en Azure Web App.
El proceso de publicación comenzará y si no se produce ningún error (como debería ser si sigues los pasos que he indicado), aparecerá nuestra aplicación en el navegador Web.
Sin embargo, nuestra aplicación web debería aparecer de esta forma:
Como podemos apreciar, Azure nos devuelve un error de tipo:
HTTP Error 500.0 – ANCM In-Process Handler Load Failure
Sabemos (porque lo vimos antes) que estamos utilizando .NET Core 2.2.
Como decía al principio, queríamos desarrollar una aplicación Web con ASP.NET Core 3, así que es evidente que este error no es otra cosa que la versión específica que nuestra aplicación Web necesita para ejecutarse ya sea Microsoft.NetCore.App o Microsoft.AspNetCore.App, no se ha podido encontrar.
Esto demuestra (como era de esperar) que no podemos desplegar nuestra aplicación .NET Core 3 en Azure, pero en realidad, no es así.
Existe una forma de llevar a cabo esta tarea.
Resolviendo el problema en el despliegue para .NET Core 3.0
A la hora de desplegar nuestras aplicaciones Web en Azure Web App, tenemos por lo general dos alternativas o modos de despliegue.
La primera de ellas, hacerlo a través de FDD o Framework-dependent deployments.
Este es el mecanismo por defecto (el que hemos usado en nuestro caso).
Y en este caso utilizaremos la versión de .NET Core que esté presente en el sistema,… en nuestro caso y lamentablemente… .NET Core 2.2 y no .NET Core 3.0, motivo por el cual estamos obteniendo el error mencionado.
La segunda de ellas, hacerlo a través de SCD o Self-contained deployments.
De esta forma, desplegaremos nuestra aplicación web y sus dependencias con la versión de .NET Core que utilicemos a la hora de hacer la build de nuestra aplicación.
Sin embargo, esta opción no incluye dependencias nativas de .NET Core.
Lo que hace esta opción de despliegue es arrastrar y publicar el runtime que utilizamos junto con nuestra aplicación.
Existe un tercer modo o mecanismo de despligue llamado FDE o Framework-dependent executables que no aplica en este caso.
Conviene leer todos los pros y contras y más detalles de forma adecuada, algo que podrás hacer en este interesante y recomendable enlace.
Así que en este caso (analiza siempre bien el caso particular en el que te mueves antes de realizar esta acción) lo que debemos hacer es cambiar de FDD a SCD en nuestro caso.
Esto lo haremos dentro de la ventana de despliegue que aparecía en Visual Studio 2019.
Una vez seleccionada esta opción, podremos cambiar sus valores como se indica en la siguiente imagen:
Pulsaremos el botón Save para guardar los cambios y volveremos a publicar nuestra aplicación web.
Si todo ha ido según lo esperado, aparecerá nuestra aplicación desplegada correctamente en Azure.
De esta forma, tendremos desplegada nuestra aplicación web en Azure a la espera de que Microsoft agregue esta posibilidad de forma directa y a través del modo de despliegue FDD.
Nota: asegúrate que en tu Azure Web App tienes una versión correcta/soportada de procesador x86 o x64 para desplegar tu aplicación web sin problemas.
Happy Coding!