Como desplegar un Azure App Service sin tiempos de caída

Es muy probable que si estamos realizando y desplegando una API o una web usando App Services, necesitemos que nuestro producto este siempre on-line, sin dejar de dar servicio en ningún momento durante el proceso de despliegue. También es posible que quieras probar manualmente que todo funciona correctamente, pero sin que esto afecte a los usuarios en producción. O simplemente te puede interesar realizar pruebas A/B y redirigir parte del trafico entrante a distintos servicios. Para ello, Azure App Service ofrece los Staging Slots.

Hemos de tener en cuenta que esta característica no esta disponible en todos los niveles del servicio, por lo que en los niveles gratuitos, compartidos y el básico no podrás utilizarlo. También es algo normal, ya que es una característica útil en entornos productivos.

Listado de las características incluidas en el app service, entre ellas se encuentra staging slot, en este caso permite hasta cinco slots

Vamos a ver como crear y configurar un App Service que no deje de dar servicio durante un despliegue.

Configuración en Azure

Lo primero será crear un app service y acceder a la sección “Deployment slots”.

Menú en portal de azure donde una de las opciones es Deployment slots

Una vez dentro de la configuración de Slots, solo tienes que añadir uno nuevo y asignarle un nombre (en nuestro caso le he puesto “staging”). Le decimos si queremos que clone los settings y lo creamos.

Pantalla de configuración de los slots, uno de los punto de menú es añadir slot

Pantalla de creación del slot. Hay que introducir el nombre que le ponemos, en nuestro caso staging y la configuración de clonado de configuración

En este punto, disponemos de un slot de producción y otro para el staging. Podemos comprobar, como cada slot tiene su propia URL:

Slot de producción
Slot de staging

Además, esta configurado para que todo el trafico vaya al slot de producción por defecto. Lo que hemos de hacer ahora, es desplegar sobre el slot de staging, y una vez realizadas las comprobaciones pertinentes, hacer un intercambio entre staging y producción. Cuando cambiemos entre slots internamente re-direccionara y no tendremos ni un segundo de downtime. Vamos a ver como hacer esto con Azure DevOps.

Configuración del despliegue con Azure DevOps

Para el ejemplo que estamos viendo, he creado una release que despliega una página web en un web-app. Como se puede apreciar en la imagen, la release es muy sencilla. Por una lado una tarea que desplegará sobre el slot, y finalmente, otra tarea que realizará el swap entre los slots. Para el ejemplo he puesto una intervención manual, simplemente para probar el funcionamiento, pero no sería necesario.

Vamos a ver la configuración de las tareas.

La primera de las tareas es la que se encargará de desplegar en el app service. En este punto tan solo hemos de indicar que se ha de desplegar sobre un slot e indicar sobre cual, tal y como se puede apreciar en la siguiente imagen:

Despúes, una vez finalizado el despliegue en el slot, indicaremos que se realice un swap con la tarea “Azure app service manage” e indicando la acción de “Swap slots”:

Finalmente solo hay que indicar el slot de origen y en nuestro caso marcamos que realice el swap sobre el slot de producción, pero podría ser sobre cualquier otro que tengamos creado.

¡Y listo!, hemos desplegado la web con cero downtime.

Soporte completo con PowerShell para Cosmo DB

Hace algún tiempo me tope con la necesidad de tener que realizar algunas modificaciones sobre una Cosmo DB en tiempo de Release y no pude por que no se soportaba mediante ARM, API ni PowerShell. En aquel momento, vote sobre una petición abierta al respecto en los foros de feedback de Microsoft (mira si hace tiempo, que por aquel entonces era Document DB)

Ya había olvidado el tema (no lo he vuelto a necesitar) cuando hoy me ha llegado un correo avisando que la petición ha sido finalizada:

Por lo tanto, Cosmo DB ya tiene soporte PowerShell para todos sus recursos. Una lista de lo que se puede hacer:


https://docs.microsoft.com/en-us/azure/cosmos-db/powershell-samples

¡Nos leemos!

Tareas de Azure DevOps: ARM Outputs

Voy a iniciar una serie de entradas para ir comentando algunas tareas de Azure DevOps que por un motivo u otro me han facilitado la vida. Voy a empezar con ARM Outputs. Esta tarea no viene por defecto y hay que descargarla e instalarla desde el Market.

Esta tarea nos permite obtener valores que hemos definido como outoputs en una plantilla ARM para poder utilizarlos posteriormente como variables en las siguientes tareas. Por ejemplo, podemos definir como outputs las distintas claves de servicios creados por ARM, que después podemos usar para insertar en valores de settings.

Sigue leyendo Tareas de Azure DevOps: ARM Outputs

Azure Logic Apps. Como crearlas, gestionarlas y desplegarlas con Visual Studio

El otro día fui a la .Net Conf Barcelona 2018 y pude asistir a la charla que dieron @tonirecio y @barbosound en la que hablaban sobre como habían usado Azure logic apps para automatizar ciertas tareas recurrentes en su organización.

Logic apps es uno de esos temas en los que llevaba tiempo pensando, pero ya sabes, el tiempo es limitado y nunca me ponía a ello, por lo que esta charla me vino de maravillas para conocer de que va el tema e interesarme por ellas.

Azure Logic Apps te permite crear flujos de trabajo y procesos sin tirar una sola linea de código. Es el concepto de no tirar una sola linea de código lo que me tiraba un poco para atrás a la hora de ponerme con ello, pero me he dado cuenta de que bien usado y con cabeza, puede ser una herramienta muy potente que nos puede ahorrar muchas horas de trabajo y algún que otro dolor de cabeza. 

Como ejemplo, he creado una logic app que “escucha” Twitter y si detecta un hastag concreto, captura el Tweet y me lo envía por correo. Lo he hecho en cinco minutos. Por muy rápido que seas picando, seguro que tardas mas.

Sigue leyendo Azure Logic Apps. Como crearlas, gestionarlas y desplegarlas con Visual Studio

Cambiar al nuevo diseño en Azure DevOps

Hace unos meses que el equipo de Azure DevOps cambio el aspecto y la navegación radicalmente.

Puede que en su momento te apareciese un mensaje en el portal  para que cambiases al nuevo aspecto y le dijeras que no, o puede que ni te hayas dado cuenta y aún estés usando el “antiguo” aspecto. La cosa es que ya me ha pasado varias veces, que al compartir la pantalla con compañeros para enseñarles algo que estoy haciendo, me dicen que ellos no lo ven igual (por que no han activado la nueva versión, claro) y por eso me he decidido a colgar esta pequeña píldora para mostrar como cambiarlo. Es muy sencillo.

Haz clic sobre las opciones de usuario, arriba a la derecha y pulsa sobre “Preview features”

Sigue leyendo Cambiar al nuevo diseño en Azure DevOps

DevOps con Azure DevOps(III) – Crear una Build

Desde hace muy poco tiempo Visual Studio Team Services ha cambiado de nombre para pasar a llamarse Azure Devops y esto me ha obligado a cambiar el título de la serie de entradas en las que llevo trabajando un tiempo. A parte de eso y de todos los cambios de UI, la filosofía sigue siendo la misma. Ya hemos visto como crear una cuenta de Azure DevOps  y como crear un proyecto y añadir el repositorio de Git. El siguiente paso es crear y configurar una “Build” que se encargue compilar el código y generar los paquetes necesarios para automatizar el despliegue. Todo ello pensando en un futuro proceso de integración y despliegue continuo.

Sigue leyendo DevOps con Azure DevOps(III) – Crear una Build

Despliegue continuo en Azure con plantillas ARM

Las plantillas ARM (Azure Resource Manager) nos permiten parametrizar y automatizar la creación y despliegue de toda la infraestructura Azure necesaria en un proyecto (la web, el service plan, las bases de datos, etc…) permitiendo así la creación de nuevos entornos exactamente iguales en cuestión de minutos y sin esfuerzo. Además, como por defecto el despliegue es incremental, si modificamos algún elemento de la ecuación este se actualizará sin afectar al resto.

Vamos a ver como crear una plantilla ARM y como integrarla en el proceso de despliegue.

Sigue leyendo Despliegue continuo en Azure con plantillas ARM

WebCast sobre Integración y despliegue continuo (CI/CD)

Ante de ayer tuve la oportunidad de hacer un webcast en directo con la gente de @CATzure sobre integración y despliegue continuo, utilizando como herramienta Visual Studio Team Services.

Hable sobre que es integración y despliegue continuo y sobre todo hice una demo donde iba implementando cada uno de los puntos que traté: políticas de ramas, entornos, buils y releases.

Por algún motivo no puedo incrustar el vídeo aquí, por lo que os dejo la URL del canal de Youtube donde esta la grabación: https://www.youtube.com/watch?v=N2QjktDk82s

La presentación que he utilizado lo puedes ver/descargar haciendo click en “Seguir Leyendo”.

Sigue leyendo WebCast sobre Integración y despliegue continuo (CI/CD)

Cerrar Work Items automáticamente al completar un Pull Request en Visual Studio Team Services

Hoy quiero dejar una pequeña píldora, una curiosidad que nos ofrece VSTS. Y es que podemos completar automáticamente la tarea asociada al Pull Request cuando completemos este.

Tiene mucho sentido, ya que si completamos el PR, es muy probable que sea por que se hemos terminado la tarea asociada a este, y con este pequeño truco podemos evitar el mas que probable olvido de actualizar el estado de la tarea (vamos, ahora me diréis que no os ha pasado nunca).

Sigue leyendo Cerrar Work Items automáticamente al completar un Pull Request en Visual Studio Team Services