Instalando el cliente de Docker 1.6 en Windows con OneGet

En noviembre del año pasado se anunciaba el primer pull request del cliente de Docker para Windows. Para probar su funcionamiento había que realizar una compilación directa del código fuente disponible en el repositorio de Github. Sin embargo, en el anuncio realizado esta semana de la disponibilidad de la versión 1.6 de Docker venía una sorpresa: el cliente para Windows.

Para la instalación vamos a tener dos alternativas, realizarlo directamente desde el ejecutable disponible que nos permitirá tener una instalación similar a la que los usuarios de Mac venían disfrutando: Docker 1.6 + Boot2Docker + VirtualBox + msysGit. La propia página de documentación de Docker incluye una guía detallada de cómo hacerlo. O la segunda, la que vamos a ver hoy, instalar únicamente el cliente de Docker a través del paquete de Chocolatey disponible.

Continue reading Instalando el cliente de Docker 1.6 en Windows con OneGet

Una vuelta de tuerca a los contenedores de la mano de Microsoft

Las tecnologías de contenerización suponen una gran disrupción en la forma que estamos acostumbrados a trabajar tanto en el mundo del desarrollo como de la infraestructura.

Los grandes actores del panorama tecnológico están tomando posiciones; lo hemos podido ver la semana pasada con Google Ventures invirtiendo doce millones de dólares en CoreOS, una distribución minimalista de Linux enfocada a la ejecución de aplicaciones contenerizadas en los grandes datacenters. También con Microsoft y su acuerdo de colaboración con Docker, uno de los principales jugadores en el mundo actual de contenedores con más de 100 millones de contenedores de Docker descargados y más de 70.000 aplicaciones dockerizadas. Tenemos también a Red Hat colaborando activamente con Project Atomic para crear un standar de contenerización en el mundo open source o VMware facilitando la integración de sus herramientas y plataforma con estas nuevas tecnologías.

Sin embargo, de todos ellos, creo que Microsoft es el que se puede encontrar en una posición más ventajosa a día de hoy. Comparado con los anteriores, es el único que tiene su propio sistema operativo de servidor, Windows Server;  su propia plataforma de virtualización, Hyper-V; y su propia solución de cloud computing, Microsoft Azure.

Este ecosistema permite por ejemplo que todo lo que aprende desplegando y gestionando un servicio de cloud con cientos de miles de servidores pueda reinvertilo en mejorar y construir productos adecuados a las necesidades de sus usuarios. Mientras tanto, el resto de jugadores tienen que buscar en terceros esas “patas” de conocimiento que les faltan.

Gracias a lo anterior, es aquí donde pienso que una vez más Microsoft ha dado una vuelta de tuerca a una tecnología, en este caso: los contenedores.

Continue reading Una vuelta de tuerca a los contenedores de la mano de Microsoft

Filtros y estrategias de planificación de un cluster con Swarm

Swarm tiene disponible a día de hoy dos estrategias para desplegar los contenedores entre los nodos de Docker del cluster: BinPacking y Random. Por defecto, Swarm utiliza la primera; la segunda únicamente escoge un nodo al azar y está pensada para tareas de depuración según indica la documentación.

En este artículo cubriremos los detalles del planificador y los filtros que se le pueden aplicar para desplegar nuestros contenedores.

Continue reading Filtros y estrategias de planificación de un cluster con Swarm

Mecanismos de descubrimiento de nodos con Swarm

En el artículo anterior sobre Swarm cubrimos uno de los mecanismos de descubrimiento de nodos que tiene. Sin embargo, la plataforma a día de hoy soporta otros gracias a un modelo extensible basado en plugins:

  • Servicio de descubrimiento alojado en Docker Hub (Hosted Discovery Service): el mecanismo utilizado en el artículo anterior.
  • Fichero de descripción del cluster.
  • Listado estático de IPs.
  • Etcd: un almacenamiento basado en claves de caracter distribuido y consistente para el descubrimiento de servicios y entornos de configuración compartida.
  • Consul: una herramienta para facilitar el descubrimiento y la configuración de servicios en tu infraestructura.
  • Apache Zookeper: un servidor open-source enfocado a la coordinación de sistemas distribuidos de forma altamente fiable.

En este artículo veremos cómo funciona dicho método de descubrimiento y cómo podemos hacer el descubrimiento de los nodos a través de otros dos métodos: un fichero de descripción del cluster y un listado de direcciones IP.

Continue reading Mecanismos de descubrimiento de nodos con Swarm

Desplegando un cluster de Docker con Swarm en Azure

En las últimas entradas en las que hablaba sobre Docker, todo el rato trabajaba contra un único servidor donde estaba alojado el motor. A la hora de realizar pruebas puede ser suficiente; sin embargo, a la hora de desplegar entornos más complejos, con alta disponibilidad y otras características de nivel empresarial, es necesario disponer de más herramientas.

El equipo de Docker está trabajando en ello con Machine, Compose y Swarm. La primera de ellas ya la cubrí en un artículo anterior, la segunda vendrá en uno futuro y la tercera es la que explicaré en este artículo.

Swarm es la solución nativa de clusterización para contenedores de Docker. Permite unificar diferentes motores como un único host virtual y desplegar en él tus soluciones. Lo mejor es que se puede gestionar desde otras herramientas de forma transparente como el propio cliente de Docker, Compose, Jenkins, etc

Vamos a ver cómo podemos montar un cluster de Docker y gestionarlo con Swarm desde cero en Azure. En lugar de utilizar las extensiones disponibles en Azure para máquinas virtuales, veremos cómo crearlo paso por paso a mano.

Continue reading Desplegando un cluster de Docker con Swarm en Azure

Utilizando los nuevos perfiles de Azure para PowerShell

Hace unos pocos días se actualizaron las herramientas de PowerShell para Azure a su última versión, la 0.8.15. Entre las novedades se encuentra una que me acaba de resultar muy útil para gestionar múltiples suscripciones de Azure desde PowerShell: los perfiles.

Nota: Si quieres actualizar tu versión de las herramientas de PowerShell o instalarlas desde cero recuerda que te resultará más fácil utilizando el script de PowerShell que creé.

Si alguna vez has intentado ejecutar un script contra múltiples suscripciones seguro que te has encontrado con las dificultades de desplegar los recursos en la suscripción correcta. Un perfil es un contenedor para agrupar una serie de suscripciones para ser usado como forma de autentificación contra los extremos de Azure. Es posible seleccionar qué perfil queremos ejecutar en cada momento de forma general para la sesión actual de PowerShell o pasándolo a cada comando con el parámetro -Profile

Podemos crear un nuevo perfil en memoria con el comando New-AzureProfile. Soporta como métodos de autenticación Azure Active Directory o Certificados. En mi caso, la segunda opción era la que buscaba. Si queréis más detalles de cómo hacerlo con Active Directory podéis consultar la documentación con Get-Help New-AzureProfile

$profile = New-AzureProfile -SubscriptionId "GUIDIdentificadorSuscripcion" -Certificate "HuellaDelCertificado"

Dicho certificado lo habremos creado previamente siguiendo las instrucciones disponibles en la documentación y lo habremos subido a través del portal de Azure. La huella del certificado lo podremos obtener de forma fácil a través de Powershell

Get-Item "Cert:\CurrentUser\My\$HuellaDelCertificado"

Una vez que tengamos nuestro perfil creado, podremos seleccionarlo para utilizarlo en nuestra sesión actual con:

Select-AzureProfile -Profile $profile

Si queremos terminar con nuestro perfil en memoria y queremos volver a emplear el que está guardado en disco podemos hacerlo con:

Select-AzureProfile -Default

En el caso de que queramos ejecutar un comando en un perfil específico podemos utilizar el parámetro -Profile para evitar tener que cambiar con Select-AzureProfile al perfil que queremos y volver después a cambiar al perfil que estábamos usando anteriormente para continuar. Por ejemplo, creando una cuenta de almacenamiento en el perfil que tengo guardado en mi variable $produccion

New-AzureStorageAccount -StorageAccountName "myAzureStorageAccount" -Location "North Europe" -Type Standard_RAGRS -Profile $produccion

Espero que os salve de algún apuro ;)

Desplegando nuestros hosts de Docker a Azure con Machine

A la hora de desplegar nuestro host o motor de Docker en Azure, ya estuve hablando sobre cómo se podía hacer utilizando la extensión disponible para máquinas virtuales o desde cero dentro de nuestra propia máquina virtual.

Sin embargo, estos mecanismos no proporcionan una solución rápida o fácilmente automatizable en entornos que así lo requieran. Por ello, desde Docker no están haciendo evolucionar la plataforma únicamente en el área de su motor y cliente, sino que también hay una serie de proyectos satélites que buscan completarla proporcionando las herramientas de orquestación y automatización necesarias.

A finales de febrero, liberaron la primera versión beta de tres de ellas: Swarm, Compose y Machine.

  • Machine: el objetivo de esta herramienta es facilitar el despliegue del motor de Docker a través de un solo comando en tu ordenador, en tu propio datacenter o en un proveedor de cloud como Azure.
  • Compose: facilita el despliegue de aplicaciones distribuidas construidas sobre una solución basada en múltiples contenedores.
  • Swarm: es la solución de clusterización para contenedores de Docker. Permite unificar diferentes motores de Docker como un único host virtual y desplegar en él tus soluciones. Lo mejor es que se puede gestionar desde otras herramientas de forma transparente como el propio cliente de Docker, Compose, Jenkins, etc.

El artículo de hoy está enfocado a mostrar cómo hacer uso de Machine para desplegar nuestras hosts en Azure.
Continue reading Desplegando nuestros hosts de Docker a Azure con Machine

MeetUp – Docker para Linux en Azure, los mejores aliados para el mundo DevOps

La pasada semana tuve el placer de participar en el Meetup sobre Docker de la Comunidad Mad OpenTech hablando sobre cómo es posible integrar Docker en la plataforma cloud de Azure y la estrategia de Microsoft enfocada al despliegue y gestión de aplicaciones basadas en contendedores.

Junto conmigo, también estuvo Roberto Majadas, CTO de OpenShine, haciendo una completa introducción sobre en qué consiste la contenerización de aplicaciones y cómo emepezar a trabajar con Docker en su charla sobre “Docker, la revolución de los contenedores”
Ya están disponibles en la propia página del Meetup los materiales que ambos utilizamos en nuestras sesiones. A continuación podéis ver un resumen de qué es lo que hablamos.

– Roberto Majadas (OpenShine) presenta “Docker, la revolución de los contenedores” – MAD OpenTech

– José Ángel Fernández (Microsoft) presenta “Integración de tareas de gestión y despliegue de Docker en Azure ”

Preguntas frecuentes sobre Docker para usuarios de Windows

En artículos anteriores ya he estado haciendo una introducción de qué es Docker y cómo empezar a usarlo desde nuestros equipos con Windows o a través de Microsoft Azure. Sin embargo, para los usuarios acostumbrados a trabajar con Windows Server, no suele ser sencillo comprender las nuevas posibilidades que ofrece y cómo funciona. A través de Twitter llegué al blog de Richard Seroter donde recopilaba una buena colección de preguntas y respuesta enfocadas a aquellos usuarios que usan Windows. Tras pedirle permiso para adaptarlo al español os dejo a continuación con la colección de preguntas y respuestas.

Continue reading Preguntas frecuentes sobre Docker para usuarios de Windows

Actualización del script para mantener tu módulo de PowerShell de Azure al día

Configurando un nuevo equipo me he dado cuenta de que el script que publiqué para mantener las herramientas de PowerShell para Azure al día tenía un fallo, si no tenías ya el módulo instalado no funcionaba. Así que nada, unos pequeños cambios y ahora también es posible instalarlas por primera vez con él. Para que sea más fácil está publicado en GitHub el código.