Cuando el cliente y el servidor están en la misma máquina, la comunicación entre ambos se puede realizar a través de un socket IPC o un socket TCP. Y, cuando se encuentran en máquinas separadas, se realiza a través de un socket TCP.
A continuación, se muestran dos ejemplos donde se describe a alto nivel cómo es el flujo de ejecución de un comando y cuáles son los componentes que intervienen.
Ejemplo de ejecución del comando docker pull
En la figura 1.3, se muestra el flujo de ejecución a alto nivel del comando docker pull
, que es el comando utilizado para descargar una imagen de un Docker Registry.
En este ejemplo, se realizan los siguientes pasos:
1. En primer lugar, el usuario ejecuta el comando docker pull
desde la línea de comandos y el cliente Docker CLI se comunica con el servicio Docker daemon.
2. El servicio Docker daemon se encarga de gestionar la petición al Docker Registry para descargar la imagen solicitada por el cliente.
3. La imagen se descarga del Docker Registry y se almacena en el host de Docker.
Figura 1.3. Ejemplo del flujo de ejecución a alto nivel del comando docker pull.
Ejemplo de ejecución del comando docker run
En la figura 1.4, se muestra el flujo de ejecución a alto nivel del comando docker run
, que es el comando utilizado para crear y ejecutar un contenedor a partir de una imagen.
En este ejemplo, se realizan los siguientes pasos:
1. En primer lugar, el usuario ejecuta el comando docker run
desde la línea de comandos y el cliente Docker CLI se comunica con el servicio Docker daemon.
2. El servicio Docker daemon comprueba si la imagen que ha seleccionado el usuario para crear el contenedor se encuentra en el host de Docker. Si la imagen no estuviese en el host, entonces la descargaría automáticamente del Docker Registry.
3. Se crea un contenedor a partir de la imagen seleccionada y se inicia la ejecución.
Figura 1.4. Ejemplo del flujo de ejecución a alto nivel del comando docker run.
1.9.1. Docker CLI
Docker CLI es el cliente oficial de Docker. Es una interfaz de línea de comandos que permite a los usuarios interaccionar con el servicio Docker daemon. El comando base de esta aplicación es docker
.
El caso de uso más habitual de Docker CLI es cuando se quiere interactuar con un único contenedor, mientras que Docker Compose se suele utilizar para trabajar con aplicaciones que ejecutan varios contenedores a la vez.
En las distribuciones Linux, podemos instalar la versión Community Edition de Docker CLI con el paquete docker-ce-cli,
que es un paquete independiente de Docker Engine, mientras que, en los sistemas operativos Windows y Mac, viene incluido en la aplicación Docker Desktop, que incluye también Docker Engine, entre otros componentes.
1.9.2. Docker Compose
Docker Compose es una aplicación utilizada desde la línea de comandos y permite a los usuarios interaccionar con el servicio Docker daemon.
Esta aplicación permite definir y ejecutar aplicaciones con múltiples contenedores. Utiliza un archivo de configuración con formato YAML, para definir los servicios, las redes y los volúmenes de los que consta la aplicación que queremos ejecutar. Una de las ventajas que nos ofrece Docker Compose es que solo hay que ejecutar un comando para crear y ejecutar todos los servicios que se han definido en el archivo YAML de configuración.
Actualmente, existen dos versiones de Docker Compose. La versión v1 está desarrollada en Python y tiene que ser instalada como una herramienta adicional con el nombre de docker-compose
, mientras que la nueva versión v2 está desarrollada en Go e integra el comando compose
dentro del cliente oficial de Docker CLI. Por lo tanto, para utilizar la nueva versión, se utiliza el comando docker compose
.
En el momento de escribir este libro, la versión v2 de Docker Compose solo está incluida en la aplicación Docker Desktop para Windows y macOS. Se espera que, muy pronto, también estará disponible en el cliente oficial Docker CLI para Linux. De momento, se puede instalar de forma manual como un plugin de Docker CLI.
1.10. Docker Engine
Docker Engine es el componente principal de Docker, encargado de crear, ejecutar y gestionar contenedores. Tiene un diseño modular y está formado por varios componentes que cumplen los estándares abiertos de la Open Container Iniciative (OCI). Entre sus componentes, destacamos los siguientes:
El componente principal de Docker Engine es el Docker daemon, que es un proceso encargado de administrar las imágenes, contenedores, redes y volúmenes. En muchas ocasiones, cuando nos referimos a Docker Engine, nos estamos refiriendo realmente al proceso Docker daemon.
En las primeras versiones, al instalar Docker Engine, se incluía el cliente Docker CLI, el Docker daemon y el Container Runtime, pero, actualmente, son tres componentes independientes que se tienen que instalar en paquetes separados.
Docker Engine se ejecuta de forma nativa en los sistemas Linux y Windows Server. En el resto de los sistemas operativos Windows, que no sean Windows Server, y en los sistemas operativos Mac, no se ejecuta de forma nativa, sino que lo hace sobre una máquina virtual Linux.
En las distribuciones Linux, podemos instalar la versión Community Edition de Docker Engine con el paquete docker-ce,
mientras que, en los sistemas operativos Windows y Mac, viene incluido en la aplicación Docker Desktop.
Figura 1.5.