Docker - Guía rápida
Docker es un servicio de gestión de contenedores. Las palabras clave de Docker sondevelop, ship y runen cualquier sitio. La idea general de Docker es que los desarrolladores desarrollen aplicaciones fácilmente, las envíen a contenedores que luego se pueden implementar en cualquier lugar.
El lanzamiento inicial de Docker fue en marzo de 2013 y, desde entonces, se ha convertido en la palabra de moda para el desarrollo del mundo moderno, especialmente frente a los proyectos basados en Agile.
Características de Docker
Docker tiene la capacidad de reducir el tamaño del desarrollo al proporcionar una huella más pequeña del sistema operativo a través de contenedores.
Con los contenedores, es más fácil para los equipos de diferentes unidades, como desarrollo, control de calidad y operaciones, trabajar sin problemas en todas las aplicaciones.
Puede implementar contenedores Docker en cualquier lugar, en cualquier máquina física y virtual e incluso en la nube.
Dado que los contenedores Docker son bastante livianos, son muy fácilmente escalables.
Componentes de Docker
Docker tiene los siguientes componentes
Docker for Mac - Le permite ejecutar contenedores Docker en Mac OS.
Docker for Linux - Le permite ejecutar contenedores Docker en el sistema operativo Linux.
Docker for Windows - Le permite ejecutar contenedores Docker en el sistema operativo Windows.
Docker Engine - Se utiliza para crear imágenes de Docker y crear contenedores de Docker.
Docker Hub - Este es el registro que se utiliza para alojar varias imágenes de Docker.
Docker Compose - Esto se usa para definir aplicaciones usando múltiples contenedores Docker.
Discutiremos todos estos componentes en detalle en los capítulos siguientes.
El sitio oficial de Docker es https://www.docker.com/El sitio tiene toda la información y documentación sobre el software Docker. También tiene los enlaces de descarga para varios sistemas operativos.
Para iniciar la instalación de Docker, usaremos una instancia de Ubuntu. Puede usar Oracle Virtual Box para configurar una instancia virtual de Linux, en caso de que aún no la tenga.
La siguiente captura de pantalla muestra un servidor Ubuntu simple que se ha instalado en Oracle Virtual Box. Hay un usuario de SO llamadodemo que se ha definido en el sistema que tiene acceso de root completo al servidor.
Para instalar Docker, debemos seguir los pasos que se indican a continuación.
Step 1- Antes de instalar Docker, primero debe asegurarse de tener la versión correcta del kernel de Linux en ejecución. Docker solo está diseñado para ejecutarse en la versión 3.8 y posteriores del kernel de Linux. Podemos hacer esto ejecutando el siguiente comando.
tu nombre
Este método devuelve la información del sistema sobre el sistema Linux.
Sintaxis
uname -a
Opciones
a - Esto se utiliza para garantizar que se devuelva la información del sistema.
Valor devuelto
Este método devuelve la siguiente información sobre el sistema Linux:
- nombre del kernel
- nombre del nodo
- lanzamiento del kernel
- versión del núcleo
- machine
- processor
- plataforma de hardware
- sistema operativo
Ejemplo
uname –a
Salida
Cuando ejecutamos el comando anterior, obtendremos el siguiente resultado:
En el resultado, podemos ver que la versión del kernel de Linux es 4.2.0-27, que es superior a la versión 3.8, por lo que estamos listos para comenzar.
Step 2 - Debe actualizar el sistema operativo con los paquetes más recientes, lo que se puede hacer a través del siguiente comando -
apt-get
Este método instala paquetes de Internet en el sistema Linux.
Sintaxis
sudo apt-get update
Opciones
sudo - el sudo El comando se utiliza para garantizar que el comando se ejecute con acceso de root.
update - el update se utiliza la opción para asegurarse de que todos los paquetes estén actualizados en el sistema Linux.
Valor devuelto
Ninguna
Ejemplo
sudo apt-get update
Salida
Cuando ejecutamos el comando anterior, obtendremos el siguiente resultado:
Este comando se conectará a Internet y descargará los últimos paquetes del sistema para Ubuntu.
Step 3- El siguiente paso es instalar los certificados necesarios que serán necesarios para trabajar con el sitio de Docker más adelante para descargar los paquetes de Docker necesarios. Se puede hacer con el siguiente comando.
sudo apt-get install apt-transport-https ca-certificates
Step 4- El siguiente paso es agregar la nueva clave GPG. Esta clave es necesaria para garantizar que todos los datos estén encriptados al descargar los paquetes necesarios para Docker.
El siguiente comando descargará la clave con el ID 58118E89F3A912897C070ADBF76221572C52609D del keyserver hkp: //ha.pool.sks-keyservers.net: 80 y lo agrega al advllavero. Tenga en cuenta que esta clave en particular es necesaria para descargar los paquetes de Docker necesarios.
Step 5 - A continuación, dependiendo de la versión de Ubuntu que tenga, deberá agregar el sitio relevante al docker.list Para el apt package manager, para que pueda detectar los paquetes de Docker desde el sitio de Docker y descargarlos en consecuencia.
Preciso 12.04 (LTS) ─ deb https://apt.dockerproject.org/repoubuntu-precisa principal
Trusty 14.04 (LTS) ─ deb https://apt.dockerproject.org/repo/ ubuntu-trusty principal
Wily 15.10 ─ deb https://apt.dockerproject.org/repo ubuntu-wily principal
Xenial 16.04 (LTS) - https://apt.dockerproject.org/repo ubuntu-xenial principal
Dado que nuestro sistema operativo es Ubuntu 14.04, usaremos el nombre del repositorio como "deb https://apt.dockerproject.org/repoubuntu-trusty main ”.
Y luego, necesitaremos agregar este repositorio a la docker.list como se ha mencionado más arriba.
echo "deb https://apt.dockerproject.org/repo ubuntu-trusty main”
| sudo tee /etc/apt/sources.list.d/docker.list
Step 6 - A continuación, emitimos el apt-get update command para actualizar los paquetes en el sistema Ubuntu.
Step 7 - Si desea verificar que el administrador de paquetes apunta al repositorio correcto, puede hacerlo emitiendo el apt-cache command.
apt-cache policy docker-engine
En la salida, obtendrá el enlace a https://apt.dockerproject.org/repo/
Step 8 - Emita el apt-get update command para asegurarse de que todos los paquetes del sistema local estén actualizados.
Step 9 - Para Ubuntu Trusty, Wily y Xenial, tenemos que instalar los paquetes del kernel linux-image-extra- *, lo que permite usar el aufs storage driver. Este controlador lo utilizan las versiones más recientes de Docker.
Se puede hacer usando el siguiente comando.
sudo apt-get install linux-image-extra-$(uname -r)
linux-image-extra-virtual
Step 10 - El paso final es instalar Docker y podemos hacerlo con el siguiente comando -
sudo apt-get install –y docker-engine
Aquí, apt-get utiliza la opción de instalación para descargar la imagen del motor de Docker desde el sitio web de Docker y obtener la instalación de Docker.
El motor Docker es el paquete oficial de Docker Corporation para sistemas basados en Ubuntu.
En la siguiente sección, veremos cómo verificar la versión de Docker que se instaló.
Versión de Docker
Para ver la versión de Docker en ejecución, puede ejecutar el siguiente comando:
Sintaxis
docker version
Opciones
version - Se utiliza para garantizar que el comando Docker devuelva la versión de Docker instalada.
Valor devuelto
La salida proporcionará los diversos detalles de la versión de Docker instalada en el sistema.
Ejemplo
sudo docker version
Salida
Cuando ejecutamos el programa anterior, obtendremos el siguiente resultado:
Información de Docker
Para ver más información sobre Docker ejecutándose en el sistema, puede ejecutar el siguiente comando:
Sintaxis
docker info
Opciones
info - Se utiliza para garantizar que el comando Docker devuelva la información detallada sobre el servicio Docker instalado.
Valor devuelto
La salida proporcionará los diversos detalles del Docker instalado en el sistema, como:
- Numero de contenedores
- Numero de imagenes
- El controlador de almacenamiento utilizado por Docker
- El directorio raíz que usa Docker
- El controlador de ejecución utilizado por Docker
Ejemplo
sudo docker info
Salida
Cuando ejecutamos el comando anterior, obtendremos el siguiente resultado:
Docker para Windows
Docker tiene soporte listo para usar para Windows, pero necesita tener la siguiente configuración para instalar Docker para Windows.
Requisitos del sistema
SO Windows | Windows 10 de 64 bits |
Memoria | 2 GB de RAM (recomendado) |
Puede descargar Docker para Windows desde: https://docs.docker.com/docker-for-windows/
Caja de herramientas de Docker
Docker ToolBox se ha diseñado para versiones anteriores de Windows, como Windows 8.1 y Windows 7. Debe tener la siguiente configuración para instalar Docker para Windows.
Requisitos del sistema
SO Windows | Windows 7, 8, 8.1 |
Memoria | 2 GB de RAM (recomendado) |
Virtualización | Esto debería estar habilitado. |
Puede descargar Docker ToolBox desde - https://www.docker.com/products/docker-toolbox
Repasemos la instalación de cada producto.
Docker para Windows
Una vez que se haya descargado el instalador, haga doble clic en él para iniciar el instalador y luego siga los pasos que se indican a continuación.
Step 1 - Haga clic en los términos del acuerdo y luego en el botón Instalar para continuar con la instalación.
Step 2 - Una vez completado, haga clic en el botón Finalizar para completar la instalación.
Caja de herramientas de Docker
Una vez que se haya descargado el instalador, haga doble clic en él para iniciar el instalador y luego siga los pasos que se indican a continuación.
Step 1 - Haga clic en el botón Siguiente en la pantalla de inicio.
Step 2 - Mantenga la ubicación predeterminada en la siguiente pantalla y haga clic en el botón Siguiente.
Step 3 - Mantenga los componentes predeterminados y haga clic en el botón Siguiente para continuar.
Step 4 - Mantenga las Tareas adicionales como están y luego haga clic en el botón Siguiente.
Step 5 - En la pantalla final, haga clic en el botón Instalar.
Trabajar con Docker Toolbox
Veamos ahora cómo se puede usar Docker Toolbox para trabajar con contenedores Docker en Windows. El primer paso es iniciar la aplicación Docker Toolbox para la que se crea el acceso directo en el escritorio cuando se lleva a cabo la instalación de Docker Toolbox.
A continuación, verá la configuración que se lleva a cabo cuando se inicia la caja de herramientas de Docker.
Una vez hecho esto, verá Docker configurado e iniciado. Obtendrá un shell interactivo para Docker.
Para probar que Docker se ejecuta correctamente, podemos usar Docker run command para descargar y ejecutar un sencillo HelloWorld Docker container.
El funcionamiento del Docker run command se da a continuación -
docker run
Este comando se usa para ejecutar un comando en un contenedor Docker.
Sintaxis
docker run image
Opciones
Image - Este es el nombre de la imagen que se utiliza para ejecutar el contenedor.
Valor devuelto
La salida ejecutará el comando en el contenedor deseado.
Ejemplo
sudo docker run hello-world
Este comando descargará el hello-world imagen, si aún no está presente, y ejecute el hello-world como contenedor.
Salida
Cuando ejecutamos el comando anterior, obtendremos el siguiente resultado:
Si desea ejecutar el sistema operativo Ubuntu en Windows, puede descargar la imagen de Ubuntu usando el siguiente comando:
Docker run –it ubuntu bash
Aquí le está diciendo a Docker que ejecute el comando en el modo interactivo a través del –it opción.
En el resultado, puede ver que la imagen de Ubuntu se descarga y se ejecuta y luego iniciará sesión como usuario root en el contenedor de Ubuntu.
Docker Hub es un servicio de registro en la nube que le permite descargar imágenes de Docker creadas por otras comunidades. También puede cargar sus propias imágenes creadas por Docker en Docker Hub. En este capítulo, veremos cómo descargar y usar la imagen de Jenkins Docker desde Docker Hub.
El sitio oficial de Docker Hub es: https://www.docker.com/community-edition#/add_ons
Step 1 - Primero, debe realizar un registro simple en Docker Hub.
Step 2 - Una vez que se haya registrado, iniciará sesión en Docker Hub.
Step 3 - A continuación, busquemos y busquemos la imagen de Jenkins.
Step 4 - Si se desplaza hacia abajo en la misma página, puede ver el Docker pullmando. Esto se utilizará para descargar la imagen de Jenkins en el servidor Ubuntu local.
Step 5 - Ahora, vaya al servidor de Ubuntu y ejecute el siguiente comando -
sudo docker pull jenkins
Para ejecutar Jenkins, debe ejecutar el siguiente comando:
sudo docker run -p 8080:8080 -p 50000:50000 jenkins
Tenga en cuenta los siguientes puntos sobre lo anterior sudo comando -
Estamos usando el sudo comando para asegurarse de que se ejecuta con acceso de root.
Aquí, jenkins es el nombre de la imagen que queremos descargar desde Docker hub e instalar en nuestra máquina Ubuntu.
-p se utiliza para asignar el número de puerto de la imagen interna de Docker a nuestro servidor principal de Ubuntu para que podamos acceder al contenedor en consecuencia.
Entonces, Jenkins se ejecutará correctamente como contenedor en la máquina Ubuntu.
En Docker, todo se basa en imágenes. Una imagen es una combinación de un sistema de archivos y parámetros. Tomemos un ejemplo del siguiente comando en Docker.
docker run hello-world
El comando Docker es específico y le dice al programa Docker en el sistema operativo que se debe hacer algo.
los run El comando se usa para mencionar que queremos crear una instancia de una imagen, que luego se llama container.
Finalmente, "hello-world" representa la imagen a partir de la cual está hecho el contenedor.
Ahora veamos cómo podemos usar la imagen de CentOS disponible en Docker Hub para ejecutar CentOS en nuestra máquina Ubuntu. Podemos hacer esto ejecutando el siguiente comando en nuestra máquina Ubuntu:
sudo docker run centos –it /bin/bash
Tenga en cuenta los siguientes puntos sobre lo anterior sudo comando -
Estamos usando el sudo comando para asegurarse de que se ejecuta con root acceso.
Aquí, centos es el nombre de la imagen que queremos descargar de Docker Hub e instalar en nuestra máquina Ubuntu.
─it se usa para mencionar que queremos correr en interactive mode.
/bin/bash se usa para ejecutar el shell bash una vez que CentOS está en funcionamiento.
Visualización de imágenes de Docker
Para ver la lista de imágenes de Docker en el sistema, puede ejecutar el siguiente comando.
docker images
Este comando se utiliza para mostrar todas las imágenes instaladas actualmente en el sistema.
Sintaxis
docker images
Opciones
Ninguna
Valor devuelto
La salida proporcionará la lista de imágenes en el sistema.
Ejemplo
sudo docker images
Salida
Cuando ejecutamos el comando anterior, producirá el siguiente resultado:
En la salida anterior, puede ver que el servidor tiene tres imágenes: centos, newcentos, y jenkins. Cada imagen tiene los siguientes atributos:
TAG - Se utiliza para etiquetar imágenes de forma lógica.
Image ID - Se utiliza para identificar de forma única la imagen.
Created - El número de días desde que se creó la imagen.
Virtual Size - El tamaño de la imagen.
Descarga de imágenes de Docker
Las imágenes se pueden descargar desde Docker Hub usando Docker runmando. Veamos en detalle cómo podemos hacer esto.
Sintaxis
La siguiente sintaxis se usa para ejecutar un comando en un contenedor Docker.
docker run image
Opciones
Image - Este es el nombre de la imagen que se utiliza para ejecutar el contenedor.
Valor devuelto
La salida ejecutará el comando en el contenedor deseado.
Ejemplo
sudo docker run centos
Este comando descargará el centos image, si aún no está presente, y ejecute el sistema operativo como un contenedor.
Salida
Cuando ejecutamos el comando anterior, obtendremos el siguiente resultado:
Ahora verá la imagen de CentOS Docker descargada. Ahora, si ejecutamos el Dockerimages comando para ver la lista de imágenes en el sistema, deberíamos poder ver el centos imagen también.
Eliminación de imágenes de Docker
Las imágenes de Docker en el sistema se pueden eliminar a través del docker rmimando. Veamos este comando con más detalle.
docker rmi
Este comando se usa para eliminar imágenes de Docker.
Sintaxis
docker rmi ImageID
Opciones
ImageID - Este es el ID de la imagen que debe eliminarse.
Valor devuelto
La salida proporcionará el ID de imagen de la imagen eliminada.
Ejemplo
sudo docker rmi 7a86f8ffcb25
Aquí, 7a86f8ffcb25 es el ID de imagen del newcentos imagen.
Salida
Cuando ejecutamos el comando anterior, producirá el siguiente resultado:
Veamos algunos comandos más de Docker en imágenes.
imágenes de docker -q
Este comando se usa para devolver solo los ID de imagen de las imágenes.
Sintaxis
docker images
Opciones
q - Le dice al comando Docker que devuelva solo los ID de imagen.
Valor devuelto
La salida mostrará solo los ID de imagen de las imágenes en el host de Docker.
Ejemplo
sudo docker images -q
Salida
Cuando ejecutamos el comando anterior, producirá el siguiente resultado:
Docker inspeccionar
Este comando se usa para ver los detalles de una imagen o contenedor.
Sintaxis
docker inspect Repository
Opciones
Repository - Este es el nombre de la imagen.
Valor devuelto
La salida mostrará información detallada sobre la imagen.
Ejemplo
sudo docker inspect jenkins
Salida
Cuando ejecutamos el comando anterior, producirá el siguiente resultado:
Los contenedores son instancias de imágenes de Docker que se pueden ejecutar mediante el comando de ejecución de Docker. El propósito básico de Docker es ejecutar contenedores. Analicemos cómo trabajar con contenedores.
Ejecutando un contenedor
La ejecución de contenedores se gestiona con Docker runmando. Para ejecutar un contenedor en modo interactivo, primero inicie el contenedor Docker.
sudo docker run –it centos /bin/bash
Luego presione Crtl + py volverá al shell de su sistema operativo.
A continuación, se ejecutará en la instancia del sistema CentOS en el servidor Ubuntu.
Listado de contenedores
Se pueden enumerar todos los contenedores de la máquina a través del docker psmando. Este comando se usa para devolver los contenedores que se están ejecutando actualmente.
docker ps
Sintaxis
docker ps
Opciones
Ninguna
Valor devuelto
La salida mostrará los contenedores que se están ejecutando actualmente.
Ejemplo
sudo docker ps
Salida
Cuando ejecutamos el comando anterior, producirá el siguiente resultado:
Veamos algunas variaciones más del docker ps mando.
docker ps -a
Este comando se usa para listar todos los contenedores en el sistema
Sintaxis
docker ps -a
Opciones
─a - Le dice al docker ps comando para listar todos los contenedores en el sistema.
Valor devuelto
La salida mostrará todos los contenedores.
Ejemplo
sudo docker ps -a
Salida
Cuando ejecutamos el comando anterior, producirá el siguiente resultado:
historial de docker
Con este comando, puede ver todos los comandos que se ejecutaron con una imagen a través de un contenedor.
Sintaxis
docker history ImageID
Opciones
ImageID - Este es el ID de imagen para el que desea ver todos los comandos que se ejecutaron en él.
Valor devuelto
La salida mostrará todos los comandos que se ejecutan en esa imagen.
Ejemplo
sudo docker history centos
El comando anterior mostrará todos los comandos que se ejecutaron contra el centos imagen.
Salida
Cuando ejecutamos el comando anterior, producirá el siguiente resultado:
En este capítulo, exploraremos en detalle qué podemos hacer con los contenedores.
parte superior de la ventana acoplable
Con este comando, puede ver los procesos principales dentro de un contenedor.
Sintaxis
docker top ContainerID
Opciones
ContainerID - Este es el ID de contenedor para el que desea ver los procesos principales.
Valor devuelto
La salida mostrará los procesos de nivel superior dentro de un contenedor.
Ejemplo
sudo docker top 9f215ed0b0d3
El comando anterior mostrará los procesos de nivel superior dentro de un contenedor.
Salida
Cuando ejecutamos el comando anterior, producirá el siguiente resultado:
parada del acoplador
Este comando se usa para detener un contenedor en ejecución.
Sintaxis
docker stop ContainerID
Opciones
ContainerID - Este es el ID del contenedor que debe detenerse.
Valor devuelto
La salida dará el ID del contenedor detenido.
Ejemplo
sudo docker stop 9f215ed0b0d3
El comando anterior detendrá el contenedor Docker 9f215ed0b0d3.
Salida
Cuando ejecutamos el comando anterior, producirá el siguiente resultado:
docker rm
Este comando se usa para eliminar un contenedor.
Sintaxis
docker rm ContainerID
Opciones
ContainerID - Este es el ID del contenedor que debe eliminarse.
Valor devuelto
La salida dará el ID del contenedor eliminado.
Ejemplo
sudo docker rm 9f215ed0b0d3
El comando anterior eliminará el contenedor Docker 9f215ed0b0d3.
Salida
Cuando ejecutamos el comando anterior, producirá el siguiente resultado:
estadísticas de Docker
Este comando se utiliza para proporcionar las estadísticas de un contenedor en ejecución.
Sintaxis
docker stats ContainerID
Opciones
ContainerID - Este es el ID de contenedor para el que se deben proporcionar las estadísticas.
Valor devuelto
La salida mostrará la utilización de CPU y memoria del contenedor.
Ejemplo
sudo docker stats 9f215ed0b0d3
El comando anterior proporcionará la utilización de la CPU y la memoria del contenedor 9f215ed0b0d3.
Salida
Cuando ejecutamos el comando anterior, producirá el siguiente resultado:
docker adjuntar
Este comando se usa para adjuntar a un contenedor en ejecución.
Sintaxis
docker attach ContainerID
Opciones
ContainerID - Este es el ID de contenedor al que debe adjuntar.
Valor devuelto
Ninguna
Ejemplo
sudo docker attach 07b0b6f434fe
El comando anterior se adjuntará al contenedor Docker 07b0b6f434fe.
Salida
Cuando ejecutamos el comando anterior, producirá el siguiente resultado:
Una vez que se haya adjuntado al contenedor de Docker, puede ejecutar el comando anterior para ver la utilización del proceso en ese contenedor de Docker.
pausa del acoplador
Este comando se usa para pausar los procesos en un contenedor en ejecución.
Sintaxis
docker pause ContainerID
Opciones
ContainerID - Este es el ID de contenedor en el que necesita pausar los procesos en el contenedor.
Valor devuelto
ContainerID del contenedor en pausa.
Ejemplo
sudo docker pause 07b0b6f434fe
El comando anterior pausará los procesos en un contenedor en ejecución 07b0b6f434fe.
Salida
Cuando ejecutamos el comando anterior, producirá el siguiente resultado:
Docker unpause
Este comando se usa para unpause los procesos en un contenedor en ejecución.
Sintaxis
docker unpause ContainerID
Opciones
ContainerID - Este es el ID de contenedor en el que debe reanudar los procesos en el contenedor.
Valor devuelto
ContainerID del contenedor en ejecución.
Ejemplo
sudo docker unpause 07b0b6f434fe
El comando anterior reanudará los procesos en un contenedor en ejecución: 07b0b6f434fe
Salida
Cuando ejecutamos el comando anterior, producirá el siguiente resultado:
Docker matar
Este comando se usa para matar los procesos en un contenedor en ejecución.
Sintaxis
docker kill ContainerID
Opciones
ContainerID - Este es el ID de contenedor al que debe matar los procesos en el contenedor.
Valor devuelto
ContainerID del contenedor en ejecución.
Ejemplo
sudo docker kill 07b0b6f434fe
El comando anterior matará los procesos en el contenedor en ejecución 07b0b6f434fe.
Salida
Cuando ejecutamos el comando anterior, producirá el siguiente resultado:
Docker: ciclo de vida del contenedor
La siguiente ilustración explica el ciclo de vida completo de un contenedor Docker.
Inicialmente, el contenedor Docker estará en el created estado.
Luego, el contenedor Docker entra en estado de ejecución cuando el Docker run se utiliza el comando.
El Docker kill El comando se usa para matar un contenedor Docker existente.
El Docker pause El comando se usa para pausar un contenedor Docker existente.
El Docker stop El comando se usa para pausar un contenedor Docker existente.
El Docker run El comando se usa para devolver un contenedor de un stopped estado a un running estado.
La siguiente imagen muestra la arquitectura estándar y tradicional de virtualization.
El servidor es el servidor físico que se utiliza para alojar varias máquinas virtuales.
El sistema operativo host es la máquina base, como Linux o Windows.
El hipervisor es VMWare o Windows Hyper V que se utiliza para alojar máquinas virtuales.
Luego, instalaría varios sistemas operativos como máquinas virtuales sobre el hipervisor existente como SO invitado.
Luego, alojaría sus aplicaciones en la parte superior de cada sistema operativo invitado.
La siguiente imagen muestra la nueva generación de virtualización habilitada a través de Dockers. Echemos un vistazo a las distintas capas.
El servidor es el servidor físico que se utiliza para alojar varias máquinas virtuales. Entonces esta capa sigue siendo la misma.
El sistema operativo host es la máquina base, como Linux o Windows. Entonces esta capa sigue siendo la misma.
Ahora llega la nueva generación que es el motor Docker. Esto se usa para ejecutar el sistema operativo que anteriormente solía ser máquinas virtuales como contenedores Docker.
Todas las aplicaciones ahora se ejecutan como contenedores de Docker.
La clara ventaja de esta arquitectura es que no es necesario tener hardware adicional para el sistema operativo invitado. Todo funciona como contenedores Docker.
Lo bueno del motor Docker es que está diseñado para funcionar en varios sistemas operativos. Ya hemos visto la instalación en Windows y hemos visto todos los comandos de Docker en sistemas Linux. Ahora veamos los diversos comandos de Docker en el sistema operativo Windows.
Imágenes de Docker
Ejecutemos el Docker images comando en el host de Windows.
Desde aquí, podemos ver que tenemos dos imágenes: ubuntu y hello-world.
Ejecutando un contenedor
Ahora ejecutemos un contenedor en el host de Windows Docker.
Podemos ver que al ejecutar el contenedor, ahora podemos ejecutar el contenedor de Ubuntu en un host de Windows.
Listado de todos los contenedores
Hagamos una lista de todos los contenedores en el host de Windows.
Detener un contenedor
Detengamos ahora un contenedor en ejecución en el host de Windows.
Entonces, puede ver que el motor Docker es bastante consistente cuando se trata de diferentes hosts Docker y funciona en Windows de la misma manera que funciona en Linux.
En este capítulo, veremos las diferentes opciones para configurar Docker.
servicio de parada de docker
Este comando se usa para detener el Docker daemon proceso.
Sintaxis
service docker stop
Opciones
Ninguna
Valor devuelto
Un mensaje que muestra que el proceso de Docker se ha detenido.
Ejemplo
sudo service docker stop
Salida
Cuando ejecutamos el comando anterior, producirá el siguiente resultado:
service docker start
Este comando se utiliza para iniciar el proceso del demonio de Docker.
Sintaxis
service docker start
Opciones
Ninguna
Valor devuelto
Un mensaje que muestra que el proceso de Docker ha comenzado.
Ejemplo
sudo service docker start
Salida
Cuando ejecutamos el comando anterior, producirá el siguiente resultado:
De forma predeterminada, cuando lanza un contenedor, también utilizará un shell commandmientras lanza el contenedor como se muestra a continuación. Esto es lo que hemos visto en los capítulos anteriores cuando trabajábamos con contenedores.
En la captura de pantalla anterior, puede observar que hemos emitido el siguiente comando:
sudo docker run –it centos /bin/bash
Usamos este comando para crear un nuevo contenedor y luego usamos el comando Ctrl + P + Q para salir del contenedor. Asegura que el contenedor siga existiendo incluso después de que salgamos del contenedor.
Podemos verificar que el contenedor todavía existe con el Docker. psmando. Si tuviéramos que salir del contenedor directamente, entonces el contenedor mismo se destruiría.
Ahora hay una manera más fácil de sujetar los contenedores y sacarlos limpiamente sin necesidad de destruirlos. Una forma de lograr esto es utilizando elnsenter mando.
Antes de ejecutar el nsenter comando, primero debe instalar el nsenterimagen. Se puede hacer usando el siguiente comando:
docker run --rm -v /usr/local/bin:/target jpetazzo/nsenter
Antes de usar el nsenter comando, necesitamos obtener el ID de proceso del contenedor, porque esto es requerido por el nsentermando. Podemos obtener el ID del proceso a través de Dockerinspect command y filtrarlo a través del Pid.
Como se ve en la captura de pantalla anterior, primero usamos el docker pscomando para ver los contenedores en ejecución. Podemos ver que hay un contenedor en ejecución con el ID de ef42a4c5e663.
Luego usamos el Docker inspect comando para inspeccionar la configuración de este contenedor y luego usar el grepcomando para filtrar el ID del proceso. Y en la salida, podemos ver que el ID de proceso es 2978.
Ahora que tenemos el ID del proceso, podemos continuar y usar el nsenter comando para adjuntar al contenedor Docker.
nsenter
Este método permite que uno se adhiera a un contenedor sin salir del contenedor.
Sintaxis
nsenter –m –u –n –p –i –t comando containerID
Opciones
-u se usa para mencionar el Uts namespace
-m se usa para mencionar el mount namespace
-n se usa para mencionar el network namespace
-p se usa para mencionar el process namespace
-i s para que el contenedor se ejecute en modo interactivo.
-t se utiliza para conectar los flujos de E / S del contenedor al sistema operativo host.
containerID - Este es el ID del contenedor.
Command - Este es el comando para ejecutar dentro del contenedor.
Valor devuelto
Ninguna
Ejemplo
sudo nsenter –m –u –n –p –i –t 2978 /bin/bash
Salida
De la salida, podemos observar los siguientes puntos:
El mensaje cambia al bash shell directamente cuando emitimos el nsenter mando.
Luego emitimos el exitmando. Ahora, normalmente, si no usó elnsentercomando, el contenedor sería destruido. Pero notarías que cuando ejecutamos elnsenter comando, el contenedor todavía está en funcionamiento.
En los capítulos anteriores, hemos visto varios archivos de imagen, como Centos, que se descargan de Docker hubdesde el cual puede girar contenedores. A continuación se muestra de nuevo un ejemplo.
Si usamos el Docker imagescomando, podemos ver las imágenes existentes en nuestro sistema. En la captura de pantalla anterior, podemos ver que hay dos imágenes:centos y nsenter.
Pero Docker también le brinda la capacidad de crear sus propias imágenes de Docker, y puede hacerlo con la ayuda de Docker Files. Un archivo Docker es un archivo de texto simple con instrucciones sobre cómo crear sus imágenes.
Los siguientes pasos explican cómo debe crear un archivo Docker.
Step 1 - Crea un archivo llamado Docker File y editarlo usando vim. Tenga en cuenta que el nombre del archivo debe ser "Dockerfile" con "D" como mayúscula.
Step 2 - Cree su archivo Docker siguiendo las siguientes instrucciones.
#This is a sample Image
FROM ubuntu
MAINTAINER [email protected]
RUN apt-get update
RUN apt-get install –y nginx
CMD [“echo”,”Image created”]
Los siguientes puntos deben tenerse en cuenta sobre el archivo anterior:
La primera línea "# Esta es una imagen de muestra" es un comentario. Puede agregar comentarios al archivo Docker con la ayuda del# mando
La siguiente línea debe comenzar con el FROMpalabra clave. Le dice a Docker, desde qué imagen base desea basar su imagen. En nuestro ejemplo, estamos creando una imagen a partir delubuntu imagen.
El siguiente comando es la persona que va a mantener esta imagen. Aquí especificas elMAINTAINER palabra clave y solo mencione el ID de correo electrónico.
los RUNEl comando se usa para ejecutar instrucciones en la imagen. En nuestro caso, primero actualizamos nuestro sistema Ubuntu y luego instalamos el servidor nginx en nuestroubuntu imagen.
El último comando se utiliza para mostrar un mensaje al usuario.
Step 3- Guarde el archivo. En el próximo capítulo, discutiremos cómo construir la imagen.
Creamos nuestro archivo Docker en el último capítulo. Ahora es el momento de crear el archivo Docker. El archivo Docker se puede compilar con el siguiente comando:
docker build
Aprendamos más sobre este comando.
compilación de docker
Este método permite a los usuarios crear sus propias imágenes de Docker.
Sintaxis
docker build -t ImageName:TagName dir
Opciones
-t - es mencionar una etiqueta a la imagen
ImageName - Este es el nombre que le quieres dar a tu imagen.
TagName - Esta es la etiqueta que quieres darle a tu imagen.
Dir - El directorio donde está presente el archivo Docker.
Valor devuelto
Ninguna
Ejemplo
sudo docker build –t myimage:0.1.
Aquí, myimage es el nombre que le estamos dando a la Imagen y 0.1 es el número de etiqueta que le estamos dando a nuestra imagen.
Dado que el archivo Docker está en el directorio de trabajo actual, usamos "." al final del comando para indicar el directorio de trabajo actual.
Salida
Desde el resultado, primero verá que la imagen de Ubuntu se descargará desde Docker Hub, porque no hay una imagen disponible localmente en la máquina.
Finalmente, cuando la compilación esté completa, todos los comandos necesarios se habrán ejecutado en la imagen.
A continuación, verá el mensaje creado correctamente y el ID de la nueva imagen. Cuando ejecutas el Dockerimages command, entonces podrá ver su nueva imagen.
Ahora puede crear contenedores a partir de su nueva imagen.
Los repositorios públicos se pueden usar para alojar imágenes de Docker que todos los demás pueden usar. Un ejemplo son las imágenes que están disponibles en Docker Hub. La mayoría de las imágenes como Centos, Ubuntu y Jenkins están disponibles públicamente para todos. También podemos hacer que nuestras imágenes estén disponibles publicándolas en el repositorio público de Docker Hub.
Para nuestro ejemplo, usaremos el myimagerepositorio integrado en el capítulo "Creación de archivos de Docker" y cargue esa imagen en Docker Hub. Primero revisemos las imágenes en nuestro host de Docker para ver qué podemos enviar al registro de Docker.
Aquí tenemos nuestro myimage:0.1imagen que se creó como parte del capítulo "Creación de archivos de Docker". Usemos esto para subir al repositorio público de Docker.
Los siguientes pasos explican cómo puede cargar una imagen en un repositorio público.
Step 1- Inicie sesión en Docker Hub y cree su repositorio. Este es el repositorio donde se almacenará su imagen. Irhttps://hub.docker.com/ e inicie sesión con sus credenciales.
Step 2 - Haga clic en el botón "Crear repositorio" en la pantalla de arriba y cree un repositorio con el nombre demorep. Asegúrese de que la visibilidad del repositorio sea pública.
Una vez que se crea el repositorio, tome nota del pull comando que está adjunto al repositorio.
los pull El comando que se utilizará en nuestro repositorio es el siguiente:
docker pull demousr/demorep
Step 3- Ahora vuelva al Docker Host. Aquí tenemos que etiquetar nuestromyimageal nuevo repositorio creado en Docker Hub. Podemos hacer esto a través de Dockertag command.
Aprenderemos más sobre esto tag command más adelante en este capítulo.
Step 4- Emita el comando de inicio de sesión de Docker para iniciar sesión en el repositorio de Docker Hub desde el símbolo del sistema. El comando de inicio de sesión de Docker le solicitará el nombre de usuario y la contraseña del repositorio de Docker Hub.
Step 5- Una vez que se haya etiquetado la imagen, ahora es el momento de enviar la imagen al repositorio de Docker Hub. Podemos hacer esto a través de Dockerpushmando. Aprenderemos más sobre este comando más adelante en este capítulo.
etiqueta acoplable
Este método permite etiquetar una imagen en el repositorio correspondiente.
Sintaxis
docker tag imageID Repositoryname
Opciones
imageID - Este es el ImageID que debe etiquetarse en el repositorio.
Repositoryname - Este es el nombre del repositorio al que se debe etiquetar ImageID.
Valor devuelto
Ninguna
Ejemplo
sudo docker tag ab0c1d3744dd demousr/demorep:1.0
Salida
A continuación se proporciona un resultado de muestra del ejemplo anterior.
empuje del acoplador
Este método permite enviar imágenes al Docker Hub.
Sintaxis
docker push Repositoryname
Opciones
Repositoryname - Este es el nombre del repositorio que debe enviarse al Docker Hub.
Valor devuelto
El ID largo del repositorio enviado a Docker Hub.
Ejemplo
sudo docker push demousr/demorep:1.0
Salida
Si regresa a la página de Docker Hub y va a su repositorio, verá el nombre de la etiqueta en el repositorio.
Ahora intentemos extraer el repositorio que cargamos en nuestro host de Docker. Primero borremos las imágenes,myimage:0.1 y demousr/demorep:1.0, desde el host local de Docker. Usemos el Dockerpull command para extraer el repositorio de Docker Hub.
En la captura de pantalla anterior, puede ver que Docker pull command ha tomado nuestro nuevo repositorio del Docker Hub y lo ha colocado en nuestra máquina.
En Docker, los propios contenedores pueden tener aplicaciones ejecutándose en puertos. Cuando ejecuta un contenedor, si desea acceder a la aplicación en el contenedor a través de un número de puerto, debe asignar el número de puerto del contenedor al número de puerto del host de Docker. Veamos un ejemplo de cómo se puede lograr esto.
En nuestro ejemplo, vamos a descargar el contenedor Jenkins de Docker Hub. Luego, asignaremos el número de puerto de Jenkins al número de puerto en el host de Docker.
Step 1 - En primer lugar, debe realizar un registro simple en Docker Hub.
Step 2 - Una vez que se haya registrado, iniciará sesión en Docker Hub.
Step 3 - A continuación, busquemos y busquemos la imagen de Jenkins.
Step 4 - Si se desplaza hacia abajo en la misma página, puede ver el Docker pullmando. Esto se utilizará para descargar la imagen de Jenkins en el servidor Ubuntu local.
Step 5 - Ahora ve al servidor de Ubuntu y ejecuta el comando -
sudo docker pull jenkins
Step 6 - Para comprender qué puertos están expuestos por el contenedor, debe usar el Docker inspect command para inspeccionar la imagen.
Aprendamos ahora más sobre esto inspect mando.
Docker inspeccionar
Este método permite devolver información de bajo nivel sobre el contenedor o la imagen.
Sintaxis
docker inspect Container/Image
Opciones
Container/Image - El contenedor o imagen a inspeccionar
Valor devuelto
La información de bajo nivel de la imagen o contenedor en formato JSON.
Ejemplo
sudo docker inspect jenkins
Salida
La salida del inspectEl comando da una salida JSON. Si observamos la salida, podemos ver que hay una sección de "ExposedPorts" y vemos que hay dos puertos mencionados. Uno es eldata port de 8080 y el otro es el control port de 50000.
Para ejecutar Jenkins y mapear los puertos, debe cambiar el Docker runcomando y agregue la opción 'p' que especifica la asignación de puertos. Entonces, necesitas ejecutar el siguiente comando:
sudo docker run -p 8080:8080 -p 50000:50000 jenkins
El lado izquierdo de la asignación del número de puerto es el puerto de host de Docker al que se debe asignar y el lado derecho es el número de puerto del contenedor Docker.
Cuando abra el navegador y navegue hasta el host de Docker en el puerto 8080, verá Jenkins en funcionamiento.
Es posible que tenga la necesidad de tener sus propios repositorios privados. Es posible que no desee alojar los repositorios en Docker Hub. Para ello, existe un contenedor de repositorio propio de Docker. Veamos cómo podemos descargar y usar el contenedor para el registro.
Step 1 - Usa el Docker runcomando para descargar el registro privado. Esto se puede hacer usando el siguiente comando.
sudo docker run –d –p 5000:5000 –-name registry registry:2
Los siguientes puntos deben tenerse en cuenta sobre el comando anterior:
Registry es el contenedor administrado por Docker que se puede utilizar para alojar repositorios privados.
El número de puerto expuesto por el contenedor es 5000. Por lo tanto, con el –p command, estamos asignando el mismo número de puerto al número de puerto 5000 en nuestro host local.
Simplemente etiquetamos el contenedor de registro como "2", para diferenciarlo en el host de Docker.
los –dLa opción se usa para ejecutar el contenedor en modo separado. Esto es para que el contenedor pueda ejecutarse en segundo plano.
Step 2 - Hagamos un docker ps para ver que el contenedor de registro se está ejecutando.
Ahora hemos confirmado que el contenedor de registro se está ejecutando.
Step 3- Ahora etiquetemos una de nuestras imágenes existentes para que podamos enviarla a nuestro repositorio local. En nuestro ejemplo, dado que tenemoscentos imagen disponible localmente, vamos a etiquetarla en nuestro repositorio privado y agregar un nombre de etiqueta de centos.
sudo docker tag 67591570dd29 localhost:5000/centos
Los siguientes puntos deben tenerse en cuenta sobre el comando anterior:
67591570dd29 hace referencia al ID de imagen de la centos imagen.
localhost:5000 es la ubicación de nuestro repositorio privado.
Estamos etiquetando el nombre del repositorio como centos en nuestro repositorio privado.
Step 4 - Ahora usemos el Docker push comando para enviar el repositorio a nuestro repositorio privado.
sudo docker push localhost:5000/centos
Aquí, estamos presionando centos imagen al repositorio privado alojado en localhost:5000.
Step 5 - Ahora borremos las imágenes locales que tenemos para centos utilizando el docker rmicomandos. Luego podemos descargar elcentos imagen de nuestro repositorio privado.
sudo docker rmi centos:latest
sudo docker rmi 67591570dd29
Step 6 - Ahora que no tenemos centos imágenes en nuestra máquina local, ahora podemos usar el siguiente Docker pull comando para tirar del centos imagen de nuestro repositorio privado.
sudo docker pull localhost:5000/centos
Aquí, estamos tirando del centos imagen al repositorio privado alojado en localhost:5000.
Si ahora ve las imágenes en su sistema, verá el centos imagen también.
Ya hemos aprendido a usar Docker File para crear nuestras propias imágenes personalizadas. Ahora veamos cómo podemos construir una imagen de servidor web que se pueda usar para construir contenedores.
En nuestro ejemplo, usaremos el servidor web Apache en Ubuntu para construir nuestra imagen. Sigamos los pasos que se indican a continuación para crear nuestro archivo Docker de servidor web.
Step 1- El primer paso es construir nuestro Docker File. Usemosvim y cree un archivo Docker con la siguiente información.
FROM ubuntu
RUN apt-get update
RUN apt-get install –y apache2
RUN apt-get install –y apache2-utils
RUN apt-get clean
EXPOSE 80 CMD [“apache2ctl”, “-D”, “FOREGROUND”]
Los siguientes puntos deben tenerse en cuenta sobre las declaraciones anteriores:
Primero estamos creando nuestra imagen a partir de la imagen base de Ubuntu.
A continuación, usaremos el comando RUN para actualizar todos los paquetes en el sistema Ubuntu.
A continuación, usamos el comando RUN para instalar apache2 en nuestra imagen.
A continuación, usamos el comando RUN para instalar los paquetes de la utilidad apache2 necesarios en nuestra imagen.
A continuación, usamos el comando EJECUTAR para limpiar cualquier archivo innecesario del sistema.
El comando EXPOSE se usa para exponer el puerto 80 de Apache en el contenedor al host de Docker.
Finalmente, el comando CMD se usa para ejecutar apache2 en segundo plano.
Ahora que se han ingresado los detalles del archivo, simplemente guarde el archivo.
Step 2 - Ejecuta el Docker buildcomando para compilar el archivo Docker. Se puede hacer usando el siguiente comando:
sudo docker build –t=”mywebserver” .
Estamos etiquetando nuestra imagen como mywebserver. Una vez que se crea la imagen, recibirá un mensaje exitoso de que el archivo se ha creado.
Step 3- Ahora que se ha creado el archivo del servidor web, es el momento de crear un contenedor a partir de la imagen. Podemos hacer esto con el Dockerrun mando.
sudo docker run –d –p 80:80 mywebserver
Los siguientes puntos deben tenerse en cuenta sobre el comando anterior:
El número de puerto expuesto por el contenedor es 80. Por lo tanto, con el –p comando, estamos mapeando el mismo número de puerto al número de puerto 80 en nuestro localhost.
los –dLa opción se usa para ejecutar el contenedor en modo separado. Esto es para que el contenedor pueda ejecutarse en segundo plano.
Si va al puerto 80 del host de Docker en su navegador web, ahora verá que Apache está en funcionamiento.
Docker tiene una gran cantidad de comandos de instrucción. Estos son comandos que se colocan en el archivo Docker. Veamos los que están disponibles.
Instrucción CMD
Este comando se utiliza para ejecutar un comando en tiempo de ejecución cuando se ejecuta el contenedor.
Sintaxis
CMD command param1
Opciones
command - Este es el comando que se ejecuta cuando se lanza el contenedor.
param1 - Este es el parámetro ingresado al comando.
Valor devuelto
El comando se ejecutará en consecuencia.
Ejemplo
En nuestro ejemplo, ingresaremos un simple Hello World echo en nuestro Docker File y crea una imagen y lanza un contenedor desde ella.
Step 1 - Cree el archivo Docker con los siguientes comandos -
FROM ubuntu
MAINTAINER [email protected]
CMD [“echo” , “hello world”]
Aquí, el CMD solo se usa para imprimir hello world.
Step 2 - Construye la imagen usando el Docker build mando.
Step 3 - Ejecutar un contenedor desde la imagen.
PUNTO DE ENTRADA
Este comando también se puede utilizar para ejecutar comandos en tiempo de ejecución para el contenedor. Pero podemos ser más flexibles con el comando ENTRYPOINT.
Sintaxis
ENTRYPOINT command param1
Opciones
command - Este es el comando que se ejecuta cuando se lanza el contenedor.
param1 - Este es el parámetro ingresado en el comando.
Valor devuelto
El comando se ejecutará en consecuencia.
Ejemplo
Echemos un vistazo a un ejemplo para comprender más sobre ENTRYPOINT. En nuestro ejemplo, ingresaremos un simpleecho comando en nuestro archivo Docker y cree una imagen y lance un contenedor desde ella.
Step 1 - Cree el archivo Docker con los siguientes comandos -
FROM ubuntu
MAINTAINER [email protected]
ENTRYPOINT [“echo”]
Step 2 - Construye la imagen usando el Docker build mando.
Step 3 - Ejecutar un contenedor desde la imagen.
ENV
Este comando se utiliza para establecer variables de entorno en el contenedor.
Sintaxis
ENV key value
Opciones
Key - Esta es la clave para la variable de entorno.
value - Este es el valor de la variable de entorno.
Valor devuelto
El comando se ejecutará en consecuencia.
Ejemplo
En nuestro ejemplo, ingresaremos un simple echo comando en nuestro archivo Docker y cree una imagen y lance un contenedor desde ella.
Step 1 - Cree el archivo Docker con los siguientes comandos -
FROM ubuntu
MAINTAINER [email protected]
ENV var1=Tutorial var2=point
Step 2 - Construye la imagen usando el Docker build mando.
Step 3 - Ejecutar un contenedor desde la imagen.
Step 4 - Finalmente, ejecute el env comando para ver las variables de entorno.
WORKDIR
Este comando se usa para configurar el directorio de trabajo del contenedor.
Sintaxis
WORKDIR dirname
Opciones
dirname- El nuevo directorio de trabajo. Si el directorio no existe, se agregará.
Valor devuelto
El comando se ejecutará en consecuencia.
Ejemplo
En nuestro ejemplo, ingresaremos un simple echo comando en nuestro archivo Docker y cree una imagen y lance un contenedor desde ella.
Step 1 - Cree el archivo Docker con los siguientes comandos -
FROM ubuntu
MAINTAINER [email protected]
WORKDIR /newtemp
CMD pwd
Step 2 - Construye la imagen usando el Docker build mando.
Step 3 - Ejecutar un contenedor desde la imagen.
La vinculación de contenedores permite que varios contenedores se vinculen entre sí. Es una mejor opción que exponer puertos. Vayamos paso a paso y aprendamos cómo funciona.
Step 1 - Descargue la imagen de Jenkins, si aún no está presente, usando Jenkins pull mando.
Step 2 - Una vez que la imagen esté disponible, ejecute el contenedor, pero esta vez, puede especificar un nombre para el contenedor usando el –-nameopción. Este sera nuestrosource container.
Step 3- A continuación, es hora de lanzar el contenedor de destino, pero esta vez, lo vincularemos con nuestro contenedor de origen. Para nuestro contenedor de destino, usaremos la imagen estándar de Ubuntu.
Cuando haces un docker ps, verá ambos contenedores en ejecución.
Step 4 - Ahora, adjúntelo al contenedor receptor.
Entonces ejecuta el envmando. Notará nuevas variables para vincular con el contenedor de origen.
Controladores de almacenamiento
Docker tiene varios controladores de almacenamiento que permiten trabajar con los dispositivos de almacenamiento subyacentes. La siguiente tabla muestra los diferentes controladores de almacenamiento junto con la tecnología utilizada para los controladores de almacenamiento.
Tecnología | Controlador de almacenamiento |
---|---|
OverlayFS | superposición o superposición2 |
AUFS | aufs |
Btrfs | brtfs |
Administrador de dispositivos | administrador de dispositivos |
VFS | vfs |
ZFS | zfs |
Analicemos ahora algunos de los casos en los que utilizaría los distintos controladores de almacenamiento:
AUFS
Este es un controlador estable; se puede utilizar para aplicaciones listas para producción.
Tiene un buen uso de la memoria y es bueno para garantizar una experiencia fluida de Docker para los contenedores.
Hay una actividad de alta escritura asociada con este controlador que debe tenerse en cuenta.
Es bueno para los sistemas que son del tipo Plataforma como servicio.
Devicemapper
Este es un controlador estable; asegura una experiencia fluida en Docker.
Este controlador es bueno para probar aplicaciones en el laboratorio.
Este controlador está en línea con la funcionalidad principal del kernel de Linux.
Btrfs
Este controlador está en línea con la funcionalidad principal del kernel de Linux.
Hay una actividad de alta escritura asociada con este controlador que debe tenerse en cuenta.
Este controlador es bueno para los casos en los que mantiene varios grupos de compilación.
Ovelay
Este es un controlador estable y está en línea con la funcionalidad principal del kernel de Linux.
Tiene un buen uso de memoria.
Este controlador es bueno para probar aplicaciones en el laboratorio.
ZFS
Este es un controlador estable y es bueno para probar aplicaciones en el laboratorio.
Es bueno para los sistemas que funcionan como plataforma como servicio.
Para ver el controlador de almacenamiento que se está utilizando, emita el docker info mando.
Sintaxis
docker info
Opciones
Ninguna
Valor devuelto
El comando proporcionará toda la información relativa sobre el componente de Docker instalado en el host de Docker.
Ejemplo
sudo docker info
Salida
El siguiente resultado muestra que el controlador principal utilizado es el aufs controlador y que el directorio raíz se almacena en /var/lib/docker/aufs.
Volúmenes de datos
En Docker, tiene un volumen separado que se puede compartir entre contenedores. Estos se conocen comodata volumes. Algunas de las características del volumen de datos son:
- Se inicializan cuando se crea el contenedor.
- Se pueden compartir y también reutilizar entre muchos contenedores.
- Cualquier cambio en el volumen en sí se puede realizar directamente.
- Existen incluso después de eliminar el contenedor.
Veamos nuestro contenedor Jenkins. Hagamos undocker inspectpara ver los detalles de esta imagen. Podemos emitir el siguiente comando para escribir la salida deldocker inspect comando a un archivo de texto y luego visualice el archivo en consecuencia.
sudo docker inspect Jenkins > tmp.txt
Cuando ve el archivo de texto con el more command, verá una entrada como JENKINS_HOME=/var/Jenkins_home.
Este es el mapeo que se realiza dentro del contenedor a través de la imagen de Jenkins.
Ahora suponga que desea mapear el volumen en el contenedor a un volumen local, luego necesita especificar la opción –v al iniciar el contenedor. A continuación se muestra un ejemplo:
sudo docker run –d –v /home/demo:/var/jenkins_home –p 8080:8080 –p 50000:50000 jenkins
La opción –v se usa para mapear el volumen en el contenedor que es /var/jenkins_home a una ubicación en nuestro Docker Host que es /home/demo.
Ahora si vas a la /home/demo ubicación en su host de Docker después de iniciar su contenedor, verá todos los archivos de contenedor presentes allí.
Cambio del controlador de almacenamiento de un contenedor
Si desea cambiar al controlador de almacenamiento utilizado para un contenedor, puede hacerlo al iniciar el contenedor. Esto se puede hacer usando el–volume-driver parámetro cuando se utiliza el docker runmando. A continuación se da un ejemplo:
sudo docker run –d --volume-driver=flocker
–v /home/demo:/var/jenkins_home –p 8080:8080 –p 50000:50000 jenkins
los –volume-driver La opción se utiliza para especificar otro controlador de almacenamiento para el contenedor.
Para confirmar que se ha cambiado el controlador, primero usemos el docker pscomando para ver los contenedores en ejecución y obtener el ID del contenedor. Entonces, emita el siguiente comando primero:
sudo docker ps
Entonces emita un docker inspect contra el contenedor y coloque la salida en un archivo de texto usando el comando.
sudo docker inspect 9bffb1bfebee > temp.txt
Si navega por el archivo de texto y va a la línea que dice VolumeDriver, verá que se ha cambiado el nombre del controlador.
Crear un volumen
Se puede crear un volumen de antemano utilizando el dockermando. Aprendamos más sobre este comando.
Sintaxis
docker volume create –-name=volumename –-opt options
Opciones
name - Este es el nombre del volumen que debe crearse.
opt - Estas son opciones que puede proporcionar mientras crea el volumen.
Valor devuelto
El comando generará el nombre del volumen creado.
Ejemplo
sudo docker volume create –-name = demo –opt o = size = 100m
En el comando anterior, estamos creando un volumen de tamaño de 100 MB y con un nombre de demostración.
Salida
La salida del comando anterior se muestra a continuación:
Listado de todos los volúmenes
También puede enumerar todos los docker volumes en un docker host. A continuación se ofrecen más detalles sobre este comando:
Sintaxis
docker volume ls
Opciones
Ninguna
Valor devuelto
El comando generará todos los volúmenes en el docker host.
Ejemplo
sudo docker volume ls
Salida
La salida del comando anterior se muestra a continuación:
Docker se encarga de los aspectos de red para que los contenedores puedan comunicarse con otros contenedores y también con el Docker Host. Si haces unifconfigen el host de Docker, verá el adaptador Ethernet de Docker. Este adaptador se crea cuando Docker se instala en el host de Docker.
Este es un puente entre Docker Host y Linux Host. Ahora veamos algunos comandos asociados con las redes en Docker.
Listado de todas las redes Docker
Este comando se puede utilizar para enumerar todas las redes asociadas con Docker en el host.
Sintaxis
docker network ls
Opciones
Ninguna
Valor devuelto
El comando generará todas las redes en el host de Docker.
Ejemplo
sudo docker network ls
Salida
La salida del comando anterior se muestra a continuación
Inspeccionando una red Docker
Si desea ver más detalles sobre la red asociada con Docker, puede usar Docker network inspect mando.
Sintaxis
docker network inspect networkname
Opciones
networkname - Este es el nombre de la red que necesita inspeccionar.
Valor devuelto
El comando mostrará todos los detalles sobre la red.
Ejemplo
sudo docker network inspect bridge
Salida
La salida del comando anterior se muestra a continuación:
Ahora ejecutemos un contenedor y veamos qué sucede cuando volvemos a inspeccionar la red. Hagamos girar un contenedor de Ubuntu con el siguiente comando:
sudo docker run –it ubuntu:latest /bin/bash
Ahora, si inspeccionamos el nombre de nuestra red a través del siguiente comando, verá que el contenedor está adjunto al puente.
sudo docker network inspect bridge
Creando su propia red nueva
Se puede crear una red en Docker antes de lanzar contenedores. Esto se puede hacer con el siguiente comando:
Sintaxis
docker network create –-driver drivername name
Opciones
drivername - Este es el nombre que se utiliza para el controlador de red.
name - Este es el nombre que se le da a la red.
Valor devuelto
El comando generará el ID largo para la nueva red.
Ejemplo
sudo docker network create –-driver bridge new_nw
Salida
La salida del comando anterior se muestra a continuación:
Ahora puede adjuntar la nueva red al iniciar el contenedor. Entonces, hagamos girar un contenedor de Ubuntu con el siguiente comando:
sudo docker run –it –network=new_nw ubuntu:latest /bin/bash
Y ahora, cuando inspeccione la red mediante el siguiente comando, verá el contenedor adjunto a la red.
sudo docker network inspect new_nw
Node.js es un marco de JavaScript que se utiliza para desarrollar aplicaciones del lado del servidor. Es un marco de código abierto que está desarrollado para ejecutarse en una variedad de sistemas operativos. Dado que Node.js es un marco de trabajo popular para el desarrollo, Docker también se ha asegurado de que tenga soporte para aplicaciones Node.js.
Ahora veremos los distintos pasos para poner en funcionamiento el contenedor Docker para Node.js.
Step 1- El primer paso es extraer la imagen de Docker Hub. Cuando inicie sesión en Docker Hub, podrá buscar y ver la imagen de Node.js como se muestra a continuación. Simplemente escriba Nodo en el cuadro de búsqueda y haga clic en el enlace del nodo (oficial) que aparece en los resultados de búsqueda.
Step 2 - Verás que el Docker pull comando para nodo en los detalles del repositorio en Docker Hub.
Step 3 - En el host de Docker, use el Docker pull comando como se muestra arriba para descargar la última imagen de nodo de Docker Hub.
Una vez el pull está completo, podemos continuar con el siguiente paso.
Step 4 - En el host de Docker, usemos el vimeditor y cree un archivo de ejemplo Node.js. En este archivo, agregaremos un comando simple para mostrar "HelloWorld" en el símbolo del sistema.
En el archivo Node.js, agreguemos la siguiente declaración:
Console.log(‘Hello World’);
Esto generará la frase "Hola mundo" cuando la ejecutemos a través de Node.js.
Asegúrese de guardar el archivo y luego continúe con el siguiente paso.
Step 5 - Para ejecutar nuestro script Node.js usando el contenedor Node Docker, necesitamos ejecutar la siguiente declaración -
sudo docker run –it –rm –name = HelloWorld –v “$PWD”:/usr/src/app
–w /usr/src/app node node HelloWorld.js
Los siguientes puntos deben tenerse en cuenta sobre el comando anterior:
los –rm La opción se utiliza para eliminar el contenedor después de ejecutarlo.
Le estamos dando un nombre al contenedor llamado "HelloWorld".
Mencionamos para mapear el volumen en el contenedor que es /usr/src/appa nuestro directorio de trabajo actual actual. Esto se hace para que el contenedor de nodos recoja nuestro script HelloWorld.js que está presente en nuestro directorio de trabajo en el host de Docker.
los –w La opción se usa para especificar el directorio de trabajo usado por Node.js.
La primera opción de nodo se utiliza para especificar la ejecución de la imagen de nodo.
La segunda opción de nodo se utiliza para mencionar la ejecución del comando de nodo en el contenedor de nodo.
Y finalmente mencionamos el nombre de nuestro guión.
Entonces obtendremos el siguiente resultado. Y a partir de la salida, podemos ver claramente que el contenedor Node se ejecutó como un contenedor y ejecutó el script HelloWorld.js.
MongoDB es una famosa base de datos orientada a documentos que utilizan muchas aplicaciones web modernas. Dado que MongoDB es una base de datos popular para el desarrollo, Docker también se ha asegurado de que tenga soporte para MongoDB.
Ahora veremos los distintos pasos para poner en funcionamiento el contenedor Docker para MongoDB.
Step 1- El primer paso es extraer la imagen de Docker Hub. Cuando inicie sesión en Docker Hub, podrá buscar y ver la imagen de Mongo como se muestra a continuación. Simplemente escriba Mongo en el cuadro de búsqueda y haga clic en el enlace de Mongo (oficial) que aparece en los resultados de búsqueda.
Step 2 - Verás que el Docker pull comando para Mongo en los detalles del repositorio en Docker Hub.
Step 3 - En el host de Docker, use el Docker pull comando como se muestra arriba para descargar la última imagen de Mongo desde Docker Hub.
Step 4- Ahora que tenemos la imagen para Mongo, primero ejecutemos un contenedor MongoDB que será nuestra instancia para MongoDB. Para ello, emitiremos el siguiente comando:
sudo docker run -it -d mongo
Se pueden señalar los siguientes puntos sobre el comando anterior:
los –it La opción se utiliza para ejecutar el contenedor en modo interactivo.
los –d La opción se usa para ejecutar el contenedor como un proceso demonio.
Y finalmente estamos creando un contenedor a partir de la imagen de Mongo.
A continuación, puede emitir el docker ps comando para ver los contenedores en ejecución -
Tome nota de los siguientes puntos:
El nombre del contenedor es tender_poitras. Este nombre será diferente ya que el nombre de los contenedores sigue cambiando cuando gira un contenedor. Pero solo tome nota del contenedor que ha lanzado.
A continuación, observe también el número de puerto en el que se está ejecutando. Está escuchando en el puerto TCP de 27017.
Step 5- Ahora, hagamos girar otro contenedor que actuará como nuestro cliente y que se utilizará para conectarse a la base de datos MongoDB. Emitamos el siguiente comando para esto:
sudo docker run –it –link=tender_poitras:mongo mongo /bin/bash
Se pueden señalar los siguientes puntos sobre el comando anterior:
los –it La opción se utiliza para ejecutar el contenedor en modo interactivo.
Ahora estamos vinculando nuestro nuevo contenedor al contenedor del servidor MongoDB ya lanzado. Aquí, debe mencionar el nombre del contenedor ya lanzado.
Luego, especificamos que queremos lanzar el contenedor Mongo como nuestro cliente y luego ejecutar el bin/bash shell en nuestro nuevo contenedor.
Ahora estará en el nuevo contenedor.
Step 6 - Ejecute el env comando en el nuevo contenedor para ver los detalles de cómo conectarse al contenedor del servidor MongoDB.
Step 6- Ahora es el momento de conectarse al servidor MongoDB desde el contenedor del cliente. Podemos hacer esto a través del siguiente comando:
mongo 172.17.0.2:27017
Los siguientes puntos deben tenerse en cuenta sobre el comando anterior
los mongo el comando es el cliente mongo comando que se utiliza para conectarse a una base de datos MongoDB.
La IP y el número de puerto es lo que obtiene cuando usa el env mando.
Una vez que ejecute el comando, estará conectado a la base de datos de MongoDB.
Luego puede ejecutar cualquier comando de MongoDB en el símbolo del sistema. En nuestro ejemplo, estamos ejecutando el siguiente comando:
use demo
Este comando es un comando de MongoDB que se usa para cambiar a un nombre de base de datos demo. Si la base de datos no está disponible, se creará.
Ahora ha creado con éxito un contenedor MongoDB de cliente y servidor.
NGINX es una popular aplicación web ligera que se utiliza para desarrollar aplicaciones del lado del servidor. Es un servidor web de código abierto que está desarrollado para ejecutarse en una variedad de sistemas operativos. Ya quenginx es un servidor web popular para el desarrollo, Docker se ha asegurado de que tenga soporte para nginx.
Ahora veremos los distintos pasos para obtener el contenedor Docker para nginx en funcionamiento.
Step 1- El primer paso es extraer la imagen de Docker Hub. Cuando inicie sesión en Docker Hub, podrá buscar y ver la imagen denginxComo se muestra abajo. Simplemente escriba nginx en el cuadro de búsqueda y haga clic en elnginx enlace (oficial) que aparece en los resultados de búsqueda.
Step 2 - Verás que el Docker pull comando para nginx en los detalles del repositorio en Docker Hub.
Step 3 - En el host de Docker, use el Docker pull comando como se muestra arriba para descargar la última imagen nginx de Docker Hub.
Step 4 - Ahora ejecutemos el nginx contenedor a través del siguiente comando.
sudo docker run –p 8080:80 –d nginx
Estamos exponiendo el puerto en el nginx servidor que es el puerto 80 al puerto 8080 en Docker Host.
Una vez que ejecute el comando, obtendrá el siguiente resultado si navega a la URL http://dockerhost:8080. Esto muestra que elnginx contenedor está en funcionamiento.
Step 5 - Veamos otro ejemplo en el que podemos alojar una página web simple en nuestro ngnixenvase. En nuestro ejemplo, crearemos un sencilloHelloWorld.html archivarlo y alojarlo en nuestro nginx envase.
Primero creemos un archivo HTML llamado HelloWorld.html
Agreguemos una línea simple de Hello World en el archivo HTML.
Entonces, ejecutemos el siguiente comando de Docker.
sudo docker run –p 8080:80 –v
“$PWD”:/usr/share/nginx/html:ro –d nginx
Los siguientes puntos deben tenerse en cuenta sobre el comando anterior:
Estamos exponiendo el puerto en el nginx servidor que es el puerto 80 al puerto 8080 en Docker Host.
A continuación, adjuntamos el volumen en el contenedor que es /usr/share/nginx/htmla nuestro directorio de trabajo actual. Aquí es donde se almacena nuestro archivo HelloWorld.html.
Ahora, si navegamos a la URL http://dockerhost:8080/HelloWorld.html obtendremos la siguiente salida como se esperaba:
En los capítulos introductorios, hemos visto la instalación de la caja de herramientas de Docker en Windows. La caja de herramientas de Docker está desarrollada para que los contenedores de Docker se puedan ejecutar en Windows y MacOS. El sitio de Toolbox en Windows eshttps://docs.docker.com/docker-for-windows/
Para Windows, debe tener Windows 10 o Windows Server 2016 con Hyper-V habilitado.
La caja de herramientas consta de los siguientes componentes:
Docker Engine - Se utiliza como motor base o demonio de Docker que se utiliza para ejecutar contenedores de Docker.
Docker Machine - para ejecutar comandos de la máquina Docker.
Docker Compose para ejecutar comandos de composición de Docker.
Kinematic - Esta es la GUI de Docker creada para Windows y Mac OS.
Oracle virtualbox
Analicemos ahora los diferentes tipos de actividades que son posibles con la caja de herramientas de Docker.
Ejecutando en Powershell
Con la caja de herramientas de Docker en Windows 10, ahora puede ejecutar los comandos de Docker powershell. Si abre powershell en Windows y escribe el comando de la versión de Docker, obtendrá todos los detalles necesarios sobre la versión de Docker instalada.
Extracción de imágenes y ejecución de contenedores
Ahora también puede extraer imágenes de Docker Hub y ejecutar contenedores en PowerShell como lo haría en Linux. El siguiente ejemplo mostrará brevemente la descarga de la imagen de Ubuntu y la ejecución del contenedor fuera de la imagen.
El primer paso es usar Docker pull comando para extraer la imagen de Ubuntu de Docker Hub.
El siguiente paso es ejecutar la imagen de Docker usando lo siguiente run comando -
docker run –it ubuntu /bin/bash
Notará que el comando es el mismo que en Linux.
Kitematic
Este es el equivalente en GUI de Docker en Windows. Para abrir esta GUI, vaya a la barra de tareas y en el icono de Docker, haga clic con el botón derecho y elija abrir Kitematic.
Le pedirá que descargue Kitematic GUI. Una vez descargado, simplemente descomprima el contenido. Habrá un archivo llamadoKitematic.exe. Haga doble clic en este archivo exe para abrir la interfaz GUI.
Luego se le pedirá que inicie sesión en Docker Hub, ingrese a través de la GUI. Simplemente ingrese el nombre de usuario y la contraseña requeridos y luego haga clic en el botón Iniciar sesión.
Una vez que haya iniciado sesión, podrá ver todas las imágenes descargadas en el sistema en el lado izquierdo de la interfaz.
En el lado derecho, encontrará todas las imágenes disponibles en Docker Hub.
Tomemos un ejemplo para entender cómo descargar la imagen de Nodo desde Docker Hub usando Kitematic.
Step 1 - Introduzca la palabra clave del nodo en los criterios de búsqueda.
Step 2 - Haga clic en el createbotón en la imagen oficial del nodo. Luego verá la imagen que se está descargando.
Una vez que se haya descargado la imagen, comenzará a ejecutar el contenedor Node.
Step 3 - Si vas al settings pestaña, puede desglosar más opciones de configuración, como se muestra a continuación.
General settings - En esta pestaña, puede nombrar el contenedor, cambiar la configuración de la ruta y eliminar el contenedor.
Ports- Aquí puede ver las diferentes asignaciones de puertos. Si lo desea, puede crear sus propias asignaciones de puertos.
Volumes - Aquí puede ver las diferentes asignaciones de volumen.
Advanced - Contiene la configuración avanzada del contenedor.
ASP.Net es el marco de desarrollo web estándar proporcionado por Microsoft para desarrollar aplicaciones del lado del servidor. Dado que ASP.Net ha existido durante bastante tiempo para el desarrollo, Docker se ha asegurado de que tenga soporte para ASP.Net.
En este capítulo, veremos los distintos pasos para poner en funcionamiento el contenedor Docker para ASP.Net.
Prerrequisitos
Los siguientes pasos deben realizarse primero para ejecutar ASP.Net.
Step 1 - Dado que esto solo se puede ejecutar en sistemas Windows, primero debe asegurarse de tener Windows 10 o Windows Server 2016.
Step 2- A continuación, asegúrese de que Hyper-V y los contenedores estén instalados en el sistema Windows. Para instalar Hyper – V y contenedores, puede ir a Activar o desactivar las características de Windows. Luego, asegúrese de que la opción Hyper-V y los contenedores estén marcados y haga clic en el botón Aceptar.
Es posible que sea necesario reiniciar el sistema después de esta operación.
Step 3 - A continuación, debe utilizar el siguiente comando de Powershell para instalar el 1.13.0rc4versión de Docker. El siguiente comando descargará esto y lo almacenará en la ubicación temporal.
Invoke-WebRequest "https://test.docker.com/builds/Windows/x86_64/docker-1.13.0-
rc4.zip" -OutFile "$env:TEMP\docker-1.13.0-rc4.zip" –UseBasicParsing
Step 4 - A continuación, debe expandir el archivo usando lo siguiente powershell mando.
Expand-Archive -Path "$env:TEMP\docker-1.13.0-rc4.zip" -DestinationPath $env:ProgramFiles
Step 5 - A continuación, debe agregar los archivos Docker a la variable de entorno usando lo siguiente powershell mando.
$env:path += ";$env:ProgramFiles\Docker"
Step 6 - A continuación, debe registrar el servicio Docker Daemon utilizando lo siguiente powershell mando.
dockerd --register-service
Step 7 - Finalmente, puede iniciar el docker daemon usando el siguiente comando.
Start-Service Docker
Utilizar el docker version comando en powershell para verificar que el docker daemon está trabajando
Instalación del contenedor ASP.Net
Veamos cómo instalar el contenedor ASP.Net.
Step 1- El primer paso es extraer la imagen de Docker Hub. Cuando inicie sesión en Docker Hub, podrá buscar y ver la imagen deMicrosoft/aspnetComo se muestra abajo. Solo escribeasp en el cuadro de búsqueda y haga clic en el enlace Microsoft / aspnet que aparece en los resultados de búsqueda.
Step 2 - Verás que el Docker pull comando para ASP.Net en los detalles del repositorio en Docker Hub.
Step 3 - Vaya a Docker Host y ejecute Docker pullcomando para la imagen de microsoft / aspnet. Tenga en cuenta que la imagen es bastante grande, cerca de 4,2 GB.
Step 4 - Ahora ve a la siguiente ubicación https://github.com/Microsoft/aspnet-docker y descarga todo el repositorio de Git.
Step 5 - Crea una carpeta llamada Appen su disco C. Luego copie el contenido del4.6.2/samplecarpeta a su unidad C. Vaya al archivo Docker en el directorio de muestra y ejecute el siguiente comando:
docker build –t aspnet-site-new –build-arg site_root=/
Los siguientes puntos deben tenerse en cuenta sobre el comando anterior:
- Crea una nueva imagen llamada aspnet-site-new desde el archivo Docker.
- La ruta raíz se establece en la carpeta ruta local.
Step 6- Ahora es el momento de ejecutar el contenedor. Se puede hacer usando el siguiente comando:
docker run –d –p 8000:80 –name my-running-site-new aspnet-site-new
Step 7- Ahora tendrá IIS ejecutándose en el contenedor Docker. Para encontrar la dirección IP del contenedor Docker, puede emitir el Dockerinspect comando como se muestra a continuación.
Docker Cloud es un servicio prestado por Docker en el que puede realizar las siguientes operaciones:
Nodes - Puede conectar Docker Cloud a sus proveedores de nube existentes, como Azure y AWS, para poner en marcha contenedores en estos entornos.
Cloud Repository - Proporciona un lugar donde puede almacenar sus propios repositorios.
Continuous Integration - Conectarse con Github y construir una tubería de integración continua.
Application Deployment - Implementar y escalar infraestructura y contenedores.
Continuous Deployment - Puede automatizar implementaciones.
Empezando
Puede ir al siguiente enlace para comenzar con Docker Cloud: https://cloud.docker.com/
Una vez que haya iniciado sesión, se le proporcionará la siguiente interfaz básica:
Conexión al proveedor de la nube
El primer paso es conectarse a un proveedor de nube existente. Los siguientes pasos le mostrarán cómo conectarse con un proveedor de Amazon Cloud.
Step 1- El primer paso es asegurarse de tener las claves de AWS correctas. Esto se puede tomar delawsconsola. Inicie sesión en suaws cuenta usando el siguiente enlace -
Step 2- Una vez que haya iniciado sesión, vaya a la sección Credenciales de seguridad. Anote las claves de acceso que se utilizarán desde Docker Hub.
Step 3 - A continuación, debe crear una política en awsque permitirá a Docker ver instancias EC2. Ir a la sección de perfiles enaws. Haga clic en elCreate Policy botón.
Step 4 - Haga clic en 'Crear su propia política' y proporcione el nombre de la política como dockercloudpolicy y la definición de política que se muestra a continuación.
{
"Version": "2012-10-17",
"Statement": [ {
"Action": [
"ec2:*",
"iam:ListInstanceProfiles"
],
"Effect": "Allow",
"Resource": "*"
} ]
}
A continuación, haga clic en el Create Policy botón
Step 5 - A continuación, debe crear un roleque será utilizado por Docker para activar los nodos en AWS. Para esto, vaya alRoles sección en AWS y haga clic en el Create New Role opción.
Step 6 - Dar el nombre del rol como dockercloud-role.
Step 7 - En la siguiente pantalla, vaya a "Función para el acceso de cuentas cruzadas" y seleccione "Proporcionar acceso entre su cuenta y una cuenta de AWS de terceros".
Step 8 - En la siguiente pantalla, ingrese los siguientes detalles -
- En el campo ID de cuenta, ingrese el ID para el servicio Docker Cloud: 689684103426.
- En el campo ID externo, ingrese su nombre de usuario de Docker Cloud.
Step 9 - Luego, haga clic en el Next Step y en la siguiente pantalla, adjunte la política que se creó en el paso anterior.
Step 10 - Finalmente, en la última pantalla cuando se crea el rol, asegúrese de copiar el arn papel que se crea.
arn:aws:iam::085363624145:role/dockercloud-role
Step 11 - Ahora vuelve a Docker Cloud, Seleccione Cloud Providersy haga clic en el plug symbol junto a Amazon Web Services.
Introducir el arn rol y haga clic en el Save botón.
Una vez guardado, la integración con AWS estaría completa.
Configurar nodos
Una vez que se completa la integración con AWS, el siguiente paso es configurar un nodo. Vaya a la sección Nodos en Docker Cloud. Tenga en cuenta que la configuración de nodos configurará automáticamente un clúster de nodos primero.
Step 1 - Vaya a la sección Nodos en Docker Cloud.
Step 2 - A continuación, puede dar los detalles de los nodos que se configurarán en AWS.
Luego, puede hacer clic en el clúster Launch Node que estará presente en la parte inferior de la pantalla. Una vez que se implemente el nodo, recibirá la notificación en la pantalla Clúster de nodos.
Implementar un servicio
El siguiente paso después de implementar un nodo es implementar un servicio. Para hacer esto, necesitamos realizar los siguientes pasos.
Step 1 - Ir al Services Sectionen Docker Cloud. Haga clic en elCreate botón
Step 2- Elija el Servicio que se requiere. En nuestro caso, elijamosmongo.
Step 3 - En la siguiente pantalla, elija el Create & Deployopción. Esto comenzará a implementar elMongo contenedor en su clúster de nodos.
Una vez implementado, podrá ver el contenedor en estado de ejecución.
Docker cuenta con mecanismos de registro que se pueden usar para depurar problemas a medida que ocurren. Hay registro en eldaemon level y en el container level. Veamos los diferentes niveles de registro.
Registro de demonios
En el nivel de registro del demonio, hay cuatro niveles de registro disponibles:
Debug - Detalla toda la información posible que maneja el proceso daemon.
Info - Detalla todos los errores + Información manejada por el proceso daemon.
Errors - Detalla todos los errores manejados por el proceso daemon.
Fatal - Solo detalla todos los errores fatales manejados por el proceso daemon.
Siga los siguientes pasos para aprender a habilitar el registro.
Step 1 - Primero, tenemos que detener el docker daemon process, si ya se está ejecutando. Se puede hacer usando el siguiente comando:
sudo service docker stop
Step 2 - Ahora tenemos que empezar docker daemon process. Pero esta vez, necesitamos agregar el–lparámetro para especificar la opción de registro. Así que emitamos el siguiente comando al iniciar eldocker daemon process.
sudo dockerd –l debug &
Los siguientes puntos deben tenerse en cuenta sobre el comando anterior:
dockerd es el ejecutable para el docker daemon process.
los –lLa opción se utiliza para especificar el nivel de registro. En nuestro caso, estamos poniendo esto como debug
& se utiliza para volver al símbolo del sistema después de que se haya habilitado el registro.
Una vez que inicie el proceso de Docker con el registro, también verá el Debug Logs siendo enviado a la consola.
Ahora, si ejecuta cualquier comando de Docker como docker images, la información de depuración también se enviará a la consola.
Registro de contenedores
El registro también está disponible a nivel de contenedor. Entonces, en nuestro ejemplo, primero hagamos girar un contenedor de Ubuntu. Podemos hacerlo usando el siguiente comando.
sudo docker run –it ubuntu /bin/bash
Ahora, podemos usar el docker log command para ver los registros del contenedor.
Sintaxis
Docker logs containerID
Parámetros
containerID - Este es el ID del contenedor para el que necesita ver los registros.
Ejemplo
En nuestro host de Docker, emita el siguiente comando. Antes de eso, puede emitir algunos comandos mientras está en el contenedor.
sudo docker logs 6bfb1271fcdd
Salida
En la salida, puede ver que los comandos ejecutados en el contenedor se muestran en los registros.
Docker Composese utiliza para ejecutar varios contenedores como un solo servicio. Por ejemplo, suponga que tiene una aplicación que requiere NGNIX y MySQL, puede crear un archivo que inicie ambos contenedores como un servicio sin la necesidad de iniciar cada uno por separado.
En este capítulo, veremos cómo comenzar con Docker Compose. Luego, veremos cómo obtener un servicio simple con MySQL y NGNIX en funcionamiento usando Docker Compose.
Docker Compose ─ Instalación
Se deben seguir los siguientes pasos para que Docker Compose esté en funcionamiento.
Step 1 - Descarga los archivos necesarios de github usando el siguiente comando -
curl -L "https://github.com/docker/compose/releases/download/1.10.0-rc2/dockercompose
-$(uname -s) -$(uname -m)" -o /home/demo/docker-compose
El comando anterior descargará la última versión de Docker Compose que en el momento de escribir este artículo es 1.10.0-rc2. Luego lo almacenará en el directorio/home/demo/.
Step 2 - A continuación, debemos proporcionar execute privileges al archivo Docker Compose descargado, usando el siguiente comando:
chmod +x /home/demo/docker-compose
Luego podemos usar el siguiente comando para ver el compose versión.
Sintaxis
docker-compose version
Parámetros
version - Esto se usa para especificar que queremos los detalles de la versión de Docker Compose.
Salida
Se mostrarán los detalles de la versión de Docker Compose.
Ejemplo
El siguiente ejemplo muestra cómo obtener el docker-compose versión.
sudo ./docker-compose -version
Salida
Luego obtendrá el siguiente resultado:
Creación de su primer archivo Docker-Compose
Ahora sigamos adelante y creemos nuestro primer archivo de Docker Compose. Todos los archivos de Docker Compose son archivos YAML. Puede crear uno usando el editor vim. Entonces ejecute el siguiente comando para crear elcompose archivo -
sudo vim docker-compose.yml
Echemos un vistazo de cerca a los diversos detalles de este archivo:
los database y webLa palabra clave se utiliza para definir dos servicios separados. Uno estará ejecutando nuestromysql base de datos y el otro será nuestro nginx Servidor web.
los image La palabra clave se utiliza para especificar la imagen de dockerhub para nuestro mysql y nginx contenedores
Para la base de datos, usamos la palabra clave ports para mencionar los puertos que necesitan ser expuestos para mysql.
Y luego, también especificamos las variables de entorno para mysql que son necesarios para ejecutar mysql.
Ahora ejecutemos nuestro archivo Docker Compose usando el siguiente comando:
sudo ./docker-compose up
Este comando tomará el docker-compose.yml archivo en su directorio local y comience a construir los contenedores.
Una vez ejecutadas, todas las imágenes comenzarán a descargarse y los contenedores se iniciarán automáticamente.
Y cuando haces un docker ps, puede ver que los contenedores están realmente en funcionamiento.
Docker tiene integraciones con muchas herramientas de integración continua, que también incluye la popular herramienta CI conocida como Jenkins. Dentro de Jenkins, tiene complementos disponibles que se pueden usar para trabajar con contenedores. Así que veamos rápidamente un complemento de Docker disponible para la herramienta Jenkins.
Vayamos paso a paso y veamos qué está disponible en Jenkins para contenedores Docker.
Step 1 - Vaya a su panel de Jenkins y haga clic en Manage Jenkins.
Step 2 - Ir a Manage Plugins.
Step 3- Busque complementos de Docker. Elija el complemento Docker y haga clic en elInstall without restart botón.
Step 4- Una vez que se complete la instalación, vaya a su trabajo en el panel de Jenkins. En nuestro ejemplo, tenemos un trabajo llamadoDemo.
Step 5 - En el trabajo, cuando vaya al paso Crear, ahora puede ver la opción para iniciar y detener contenedores.
Step 6- Como ejemplo simple, puede elegir la opción adicional para detener contenedores cuando se completa la compilación. Luego, haga clic en elSave botón.
Ahora, ejecute su trabajo en Jenkins. En la salida de la consola, ahora podrá ver que se ha ejecutado el comando para detener todos los contenedores.
Kubernetes es un marco de orquestación para contenedores Docker que ayuda a exponer los contenedores como servicios al mundo exterior. Por ejemplo, puede tener dos servicios: un servicio contendríanginx y mongoDB, y otro servicio contendría nginx y redis. Cada servicio puede tener una IP o un punto de servicio que se puede conectar mediante otras aplicaciones. Luego, Kubernetes se utiliza para administrar estos servicios.
El siguiente diagrama muestra en un formato simplista cómo funciona Kubernetes desde el punto de vista de la arquitectura.
los miniones el nodo en el que se ejecutan todos los servicios. Puede tener muchos minions corriendo en un momento dado. Cada minion albergará uno o más POD. CadaPODes como alojar un servicio. Cada POD luego contiene los contenedores Docker. Cada POD puede alojar un conjunto diferente de contenedores Docker. Luego, el proxy se utiliza para controlar la exposición de estos servicios al mundo exterior.
Kubernetes tiene varios componentes en su arquitectura. La función de cada componente se explica a continuación & mius;
etcd - Este componente es de alta disponibilidad key-value tienda que se utiliza para almacenar shared configuration y service discovery. Aquí las diversas aplicaciones podrán conectarse a los servicios a través deldiscovery service.
Flannel - Esta es una red de backend que se requiere para los contenedores.
kube-apiserver - Esta es una API que se puede utilizar para organizar los contenedores de Docker.
kube-controller-manager - Esto se usa para controlar el Kubernetes services.
kube-scheduler - Esto se usa para programar los contenedores en los hosts.
Kubelet - Se utiliza para controlar el lanzamiento de contenedores a través de manifest files.
kube-proxy - Se utiliza para proporcionar servicios de proxy de red al mundo exterior.
En este capítulo, veremos cómo instalar Kubenetes vía kubeadm. Esta es una herramienta que ayuda en la instalación de Kubernetes. Vayamos paso a paso y aprendamos a instalar Kubernetes.
Step 1 - Asegúrese de que Ubuntu server version estás trabajando es 16.04.
Step 2 - Asegúrese de generar un ssh clave que se puede utilizar para sshiniciar sesión. Puede hacer esto usando el siguiente comando.
ssh-keygen
Esto generará una clave en su home folder Como se muestra abajo.
Step 3 - A continuación, dependiendo de la versión de Ubuntu que tenga, deberá agregar el sitio relevante al docker.list Para el apt package manager, para que pueda detectar el Kubernetes packages desde el kubernetes sitio y descárguelos en consecuencia.
Podemos hacerlo usando los siguientes comandos.
curl -s https://packages.cloud.google.com/apt/doc/apt-key.gpg | apt-key add -
echo "deb http://apt.kubernetes.io/ kubernetes-xenial main” | sudo tee /etc/apt/sources.list.d/docker.list
Step 4 - Luego emitimos una actualización apt-get para asegurarnos de que todos los paquetes se descarguen en el servidor de Ubuntu.
Step 5 - Instale el paquete Docker como se detalla en los capítulos anteriores.
Step 6 - Ahora es el momento de instalar kubernetes instalando los siguientes paquetes:
apt-get install –y kubelet kubeadm kubectl kubernetes-cni
Step 7 - Una vez todo kubernetes los paquetes se descargan, es hora de iniciar el controlador de kubernetes con el siguiente comando:
kubeadm init
Una vez hecho esto, recibirá un mensaje exitoso de que el maestro está en funcionamiento y los nodos ahora pueden unirse al clúster.