Trabajando con Azure Resource Policies desde el CLI

Como ya comenté, Azure Resource Manager incluye la opción de definir políticas a la hora de crear recursos permitiéndonos fijar una serie de condiciones como el nombre que tienen que tener el recurso, la región donde se despliega o las etiquetas que incluye.

En un primer lugar, las políticas estaban soportadas a través de la API REST o Powershell pero no con el Azure CLI. Esto ha sido algo bastante común con anterioridad; sin embargo, la tan deseada paridad entre ambas formas de gestionar los recursos en Azure está haciéndose realidad. Ya es posible trabajar también con las políticas de recursos desde el CLI aunque la documentación no lo incluya. He realizado un pull request con los detalles de cómo hacerlo para que se incluya; sin embargo, mientras tanto podéis irlo probando de la siguiente manera

Continue reading Trabajando con Azure Resource Policies desde el CLI

Error accediendo al portal de gestión de Azure

Realizando la configuración inicial para un nuevo cliente, nos encontramos con un error accediendo al portal de Azure a nuestra suscripción. El mensaje era el siguiente:

“Some subscriptions couldn’t be retrieved. Consider checking your connection, your firewall settings, or try again later…”

Error acceso portal de Azure
Error acceso portal de Azure

Debido a esto, aunque el portal era navegable y los detalles de la suscripción eran visibles, algunas actividades como la creación de un nuevo grupo de recursos fallaba. Si estáis experimentando algo parecido, revisad vuestra configuración del firewall porque es posible que alguna de las URLs a las que accede el portal por debajo estén siendo bloqueadas.

En esta entrada del portal de Feedback podéis ver más detalles, algunas de las URLs necesarias son las siguientes:

  • *.azure.com
  • *.windows.net
  • *.azurecomcdn.net
  • *.azureedge.net
  • *.msecnd.net
  • login.microsoftonline.com
  • login.live.com

Si aún añadiendo estas en la White List continuáis con problemas, revisad en detalle los logs del Firewall/Proxy para comprobar qué URL está siendo bloqueada.

Desplegando Oracle Linux 5.x en Azure

A la hora de trabajar con cualquier plataforma es muy importante revisar las tecnologías y las versiones soportadas para poder estar cubiertos por los acuerdos de nivel de servicio y el soporte. Sin embargo, en algunas ocasiones es posible que necesitemos instalar una versión no soportada para realizar alguna prueba que en local no podemos realizar. En el caso de Azure, podéis encontrar el listado de distribuciones Linux y sus versiones soportadas directamente en la documentación.

En este caso en particular, el interés estaba en desplegar una versión antigua de Oracle Linux de la rama 5.x la cual se encuentra totalmente fuera de soporte. Dado que era para un escenario de desarrollo y pruebas como comentaba anteriormente, era aceptable asumir ese riesgo para ver si era posible hacer lo que buscábamos con Azure o no.

Si os encontráis en una situación similar, a continuación tenéis los pasos para configurar vuestra máquina Oracle Linux y poder arrancar máquinas virtuales en Azure.

Continue reading Desplegando Oracle Linux 5.x en Azure

Docker for Windows, una vista rápida del panorama actual

El pásado día 5 de mayo tuvo lugar en nuestras oficinas una nueva edición del Meetup de Docker Madrid. Gracias al equipo de DX de Microsoft España ya tenemos las sesiones disponibles en Channel 9.

En primer lugar, contamos con la participación de Ignacio Sánchez y Ramón Román de atSistemas donde me quedo sin duda con su clúster de Raspberry Pi integrado con los nuevos pipelines de Jenkins 2.0. Media hora de sesión donde ver cómo emplear Docker Swarm para la gestión de clústeres basados en Docker y la instanciación de aplicaciones basadas en microservicios. Muy útil las nuevas capacidades incorporadas en Swarm para reinstanciar los contenedores en otro nodo si el host se cae.

Tras ellos, por mi parte hice una breve introducción a cómo se encuentra el ecosistema de Docker en entornos basados en Windows. Desde los avances en Docker for Windows con Kitematic para permitirte trabajar con Docker directamente en Windows 10 con Hyper-V de forma sencilla, hasta los cambios que están llegando en la parte de Windows Server con la implementación a nivel del núcleo del soporte a contenedores.

Tenéis disponible el vídeo y la presentación

The Lord of the Keys, tus secretos a salvo con Azure Key Vault

El pásado día 16 de abril tuvo lugar en Madrid la cuarta edición del Global Azure Bootcamp. Se celebró por primera vez en 2014 con cerca de 140 asistentes, en 2015 subimos de los 200 y este año contamos con 390 personas en las oficinas de Microsoft Ibérica con tres tracks en paralelo.

En esta edición, repetí junto con Iria como speakers dejando a un lado los contenedores y las herramientas de gestión de la configuración y hablando sobre uno de los nuevos servicios de Azure: Key Vault.

Si no pudisteis asistir, aquí tenéis la descripción de la sesión junto con los materiales y el vídeo para este fin de semana:

Una de las principales preocupaciones al usar cualquier servicio que se encuentre fuera de nuestro paraguas de control es la seguridad, ¿qué sucede con la información que estoy alojando allí?. Pero no solo eso, también información más sensible como contraseñas, claves criptográficas u otros secretos que nuestras aplicaciones necesitan para funcionar correctamente. Azure Key Vault proporciona una solución rápida para gestionar estar información sensible de forma segura gracias al soprote de hardware security modules.

  • Presentación y scripts en GitHub
  • Vídeo en Channel 9

Creando una distribución de Linux desde cero como imagen base de Docker

A principios del pasado mes de diciembre tuve una sesión en Tajamar hablando sobre contenedores, Docker y la plataforma de Microsoft. Tuvimos una muy buena conversación sobre el tema y una de las preguntas que hizo @alber86 me dio que pensar. Su duda iba enfocada a cómo un contenedor de Docker puede ejecutar un “sistema operativo” en él, cómo se construye y cuáles son las diferencias respecto a la ejecución del mismo dentro de una máquina virtual.

A partir de ahí el reto estaba claro, entender cómo se puede generar una distribución de Linux desde cero y una vez construida, comprender cómo ejecutar mis propios contenedores de Docker basados en esa distribución como imagen base. El artículo es un breve resumen del proceso por si estás interesado en replicarlo.

Continue reading Creando una distribución de Linux desde cero como imagen base de Docker

Gestión de recursos en Azure Resource Manager con políticas personalizadas

Una de las gran ventajas de Azure Resource Manager (ARM) frente al modelo de Azure Service Manager (ASM) es la capacidad de permitir una gestión mucho más detallada de los permisos de acceso a nuestros recursos por diferentes usuarios gracias al modelo Role Based Access Control (RBAC). RBAC se centra únicamente en las acciones que un usuario puede realizar dentro de una suscripción; es decir: acceder a un grupo de recursos concreto, poder gestionar únicamente máquinas virtuales, visualizar en modo lectura la información visible en el portal, etc. Sin embargo, hay ciertos escenarios que no es posible cubrir con RBAC en exclusiva.

¿Qué podemos hacer si queremos restringir en qué regiones se pueden desplegar recursos por temas legales? ¿O qué servicios son los que se puede usar o no? ¿Qué pasa si queremos seguir una nomenclatura estándar en todos nuestros recursos para facilitar la gestión? Si alguna vez os habéis preguntado algo similar, las políticas personalizadas son vuestra solución.

Continue reading Gestión de recursos en Azure Resource Manager con políticas personalizadas

Azure Load Balancer en Azure Resource Manager

Uno de los elementos claves a la hora de desplegar nuestra solución dentro de máquinas virtuales en Azure es el balanceador de carga. Esto se debe a que para estar cubiertos por el acuerdo de nivel de servicio es necesario tener nuestra aplicación ejecutándose en al menos dos máquinas virtuales dentro de un conjunto de disponibilidad. Aunque ahí de forma directa no se menciona al balanceador, es la pieza clave que hace que nuestros clientes sigan recibiendo servicio si una de nuestras máquinas falla es él.

Trabajando con el modelo de Azure Service Manager, ASM o clásico, cada vez que aprovisionábamos una nueva máquina virtual automáticamente se generaba un nuevo balanceador asociado a la misma. En el caso de Azure Resource Manager, ARM o “el nuevo”, es necesario que de forma activa nosotros creemos el balanceador y hagamos las conexiones necesarias con nuestras máquinas virtuales. Esto se debe a que un balanceador es un recurso más que se encuentra bajo el provedor de recursos de Microsoft.Network. Si queréis más detalles sobre las diferencias entre ASM y ARM podéis encontrarlo en la documentación bajo el artículo “Resource Manager Deployment Model”.

¿Cuál es el problema entonces? A día hoy no existe opción en el portal de gestión de Azure para crear un nuevo balanceador de carga. Esto nos obliga a utilizar PowerShell o las nuevas plantillas de despliegues en JSON para realizarlo. Este artículo entrará en más detalle en conocer cómo crear nuestro balanceador desde dichas plantillas y las opciones de configuración que nos ofrece este tipo de recurso.

Continue reading Azure Load Balancer en Azure Resource Manager

Configuración de Windows Containers paso a paso sobre Hyper-V

En la última Technical Preview de Windows Server, la TP3, una de las novedades incluídas más esperadas era la primera versión de la implementación de contenedores por parte de Microsoft en el sistema operativo. Si queréis conocer más detalles de todo lo relacionado con ello os recomiendo que consultéis la documentación que han hecho pública en MSDN.

Para facilitarnos todo el proceso de evaluación han creado una serie de scripts de PowerShell que automatizan todo el proceso. Desde cómo crear una máquina virtual en nuestro host para evaluarlo, cómo instalar un host en una máquina virtual existente o cómo actualizar uno configurado previamente. Todos los scripts están disponibles en el repositorio de GitHub de Microsoft, otra muestra más de cómo las cosas están cambiando dentro de la compañía.

Dado que me gusta conocer en detalle cómo funcionan las cosas, me he puesto a analizar los scripts para entender mejor los requisitos y la configuración necesaria. En este artículo revisaré el script New-ContainerHost.ps1
Continue reading Configuración de Windows Containers paso a paso sobre Hyper-V

Cómo preparar una máquina virtual para trabajar con Docker en Azure

Las máquinas virtuales a la hora de probar cosas nuevas son muy prácticas, más si están desplegadas directamente en la nube. Gracias a ello tu equipo se mantiene limpio y no se ocupa espacio ni recursos. Preparando una sesión de introducción a los contenedores y en especial a Docker he estado preparando el entorno para hacer todas las demos en Azure. La idea es tener todas las herramientas relacionadas con Docker y su integración con Azure en un mismo lugar permitiendo de esta manera facilitar el trabajo.

La idea es instalar la versión experimental de Docker y así disfrutar de las últimas novedades de la DockerCon. Junto con ello, disponer de Machine, Compose, Swarm y también de las herramientas de línea de comandos de Azure para linux. Un pack básico para sacar todo el provecho de Docker en Azure. ¡Empecemos!

Continue reading Cómo preparar una máquina virtual para trabajar con Docker en Azure