Skip to content

Latest commit

 

History

History
108 lines (69 loc) · 7.99 KB

day48.md

File metadata and controls

108 lines (69 loc) · 7.99 KB

Alternativas a Docker

Dije al principio de esta sección que íbamos a usar Docker, simplemente porque tiene muchos recursos ya que la comunidad es muy grande, pero también porque fue de aquí de donde vinieron los impulsos para popularizar los contenedores. Te animo a que veas algo de la historia de los contenedores, me pareció muy útil para entender todos los conceptos que trae.

Pero como he aludido existen alternativas a Docker si pensamos en lo que es Docker y de qué se ocupa: una plataforma para desarrollar, probar, desplegar y gestionar aplicaciones.

Quiero destacar algunas alternativas a Docker que podrías ver o verás en el futuro.

Podman

¿Qué es Podman? Podman es un motor de contenedores sin demonio para desarrollar, gestionar y ejecutar contenedores OCI en tu sistema Linux. Los contenedores se pueden ejecutar como root o en modo rootless.

Al igual que Docker no hay ningún requisito para la virtualización, pero utilizará el sistema operativo subyacente y por eso no se puede ejecutar en Windows a pelo. Se puede ejecutar bajo WSL2 pero no es tan visual como la experiencia con Docker Desktop, que está hecho para quienes usan el ratón.

También hay un cliente remoto de Windows donde se puede conectar a una máquina virtual Linux donde se ejecutarán los contenedores. Con el Ubuntu en WSL2 de la versión 20.04, siguiendo los siguientes pasos podrás instalar Podman en tu instancia WSL.

echo "deb https://download.opensuse.org/repositories/devel:/kubic:/libcontainers:/stable/xUbuntu_20.04/ /" |
sudo tee /etc/apt/sources.list.d/devel:kubic:libcontainers:stable.list

Para añadir la clave GPG:

curl -L "https://download.opensuse.org/repositories/devel:/kubic:\
/libcontainers:/stable/xUbuntu_20.04/Release.key" | sudo apt-key add -

Ejecute una actualización del sistema con sudo apt-get update && sudo apt-get upgrade. Por último, podemos instalar podman usando sudo apt install podman. Espero que os déis cuenta de la incomodidad que es usar un sistema operativo que no sea Linux para trabajar con contenedores. Suele pasar con la mayoría de aplicaciones de Sistemas o desarrollo. Así como hemos visto la optimización de los contenedores, deberéis tener en cuenta que el sistema operativo anfitrión también es importante.

Ahora podemos utilizar muchos de los mismos comandos que hemos estado utilizando para docker. Como puedes ver a continuación, he utilizado podman images y no tengo nada después de la instalación. Luego, he utilizado podman pull ubuntu para bajar la imagen del contenedor ubuntu.

Podemos ejecutar nuestra imagen de Ubuntu usando podman run -dit ubuntu y podman ps para ver nuestra imagen en ejecución.

Para entrar en ese contenedor podemos ejecutar podman attach dazzling_darwin el nombre de tu contenedor seguramente será diferente.

Si te estás moviendo de docker a podman también es común cambiar el archivo de configuración para tener alias docker=podman de esa manera cualquier comando que ejecute con docker utilizará podman.

LXC

LXC es un motor de contenedorización que permite a los usuarios crear múltiples entornos de contenedores Linux aislados. A diferencia de Docker, LXC actúa como un hipervisor para crear múltiples máquinas Linux con archivos de sistema separados, y características de red. Existió antes que Docker y volvió a aparecer debido a las deficiencias de Docker.

Sin embargo, LXC es tan ligero como Docker y fácil de desplegar.

Containerd

Un runtime de contenedor independiente. Containerd aporta simplicidad y robustez, así como, por supuesto, portabilidad. Containerd era antes una herramienta que se ejecutaba como parte de los servicios de contenedores Docker hasta que Docker decidió graduar sus componentes en componentes independientes.

Es un proyecto de la Cloud Native Computing Foundation, lo que lo sitúa en la misma clase que herramientas de contenedores populares como Kubernetes, Prometheus y CoreDNS. De hecho, a partir de la versión 1.11, Kubernetes utiliza containerd como su runtime de contenedor predeterminado mientras que antes era Docker.

Otras herramientas Docker

También podríamos mencionar herramientas y opciones alrededor de Rancher, y VirtualBox pero podemos cubrirlas en más detalle en otra ocasión.

Gradle

  • Las exploraciones de construcción permiten a los equipos depurar sus scripts de forma colaborativa y realizar un seguimiento del historial de todas las construcciones.
  • Las opciones de ejecución dan a los equipos la capacidad de construir continuamente de modo que cada vez que se introducen cambios, la tarea se ejecuta automáticamente.
  • El diseño personalizado del repositorio ofrece a los equipos la posibilidad de tratar cualquier estructura de directorios de archivos como un repositorio de artefactos.

Packer

  • Posibilidad de crear varias imágenes de máquina en paralelo para ahorrar tiempo a los desarrolladores y aumentar la eficacia.
  • Los equipos pueden depurar fácilmente las compilaciones mediante el depurador de Packer, que inspecciona los fallos y permite a los equipos probar soluciones antes de reiniciar las compilaciones.
  • Compatibilidad con muchas plataformas mediante plugins para que los equipos puedan personalizar sus compilaciones.

Logspout

  • Herramienta de registro: la capacidad de personalización de la herramienta permite a los equipos enviar los mismos registros a varios destinos.
  • Los equipos pueden gestionar fácilmente sus archivos porque la herramienta sólo requiere acceso al socket Docker.
  • Completamente de código abierto y fácil de desplegar.

Logstash

  • Personaliza tu pipeline utilizando el marco de trabajo pluggable de Logstash.
  • Analice y transforme fácilmente sus datos para el análisis y para ofrecer valor empresarial.
  • La variedad de salidas de Logstash le permite dirigir sus datos hacia donde desee.

Portainer

  • Utilice plantillas prediseñadas o cree las suyas propias para desplegar aplicaciones.
  • Cree equipos y asigne funciones y permisos a sus miembros.
  • Sepa qué se está ejecutando en cada entorno mediante el panel de control de la herramienta.

Recursos

Nos vemos en el Día 49