Creación de Dockerfiles, Dockerignore y Docker Compose

OUna de las mejores formas de automatizar Docker para crear imágenes automáticamente es utilizando un Dockerfile. Un Dockerfile es un documento de texto simple que contiene todos los comandos que un usuario puede llamar en la línea de comandos para ensamblar una imagen.

En este tutorial, le mostraremos un proceso paso a paso para crear un Dockerfile para la aplicación nodeJS, crear Dockerignore y docker-compose.

Índice

Creación de un Dockerfile, Dockerignore y Docker Compose

1. Dockerfile

Crearemos el Dockerfile dentro del directorio fuente.

vim Dockerfile

En primer lugar, definamos a partir de qué imagen queremos iniciar la construcción. Aquí he agregado mi imagen de la ventana acoplable de Linux alpine, que incluye nodejs10 y NPM. Siga nuestra imagen de Docker y la guía del concentrador de la ventana acoplable para crear imágenes de la ventana acoplable y llevarlas al concentrador de la ventana acoplable.

FROM ddarshana/alpinenode10

El comando MAINTAINER muestra el autor de las imágenes generadas.

MAINTAINER darshana (D.Darshana@fosslinux.com)

El comando RUN se utiliza para ejecutar cualquier comando. Aquí instalamos un paquete curl en Alpine Linux.

RUN apk add --update curl && rm -rf /var/cache/apk/*

Cree un nuevo directorio llamado Aplicación que va a contener el código de la aplicación dentro de la imagen.

RUN mkdir /app

La directiva WORKDIR se utiliza para establecer dónde se ejecutará el comando definido con CMD.

WORKDIR /app

Copie el archivo package.json.

COPY package.json .

Instale la aplicación y las dependencias de nodeJS.

RUN npm install

Fuente de la aplicación del paquete.

COPY . .

Descargue el archivo de variables de entorno. En nuestro caso, tenemos una ubicación separada para almacenar configuraciones globales.

RUN curl -O https://demofiles.fosslinux/nodejs/.env

Ejecute la aplicación y se iniciará en el puerto 3000 predeterminado.

CMD ["npm", "start"]

Aquí está nuestro Dockerfile completo.

FROM ddarshana/alpinenode10

MAINTAINER darshana (D.Darshana@fosslinux.com)

# Install "curl" package
RUN apk add --update curl && rm -rf /var/cache/apk/*

# Create app directory
RUN mkdir /app

WORKDIR /app

# copy package.json

COPY package.json .

# Install app dependencies
RUN npm install

# Bundle app source
COPY . .

# Download environment variable file from our network location

RUN curl -O https://demofiles.fosslinux/nodejs/.env

# Run APP
CMD ["npm", "start"]

Guardar y salir del archivo. Aquí está mi directorio de códigos de aplicaciones NodeJs.

Código de aplicación de Nodejs
Código de aplicación de Nodejs

2. Creación de un archivo Dockerignore

El uso del archivo "dockerignore" evita que nuestros módulos locales y otros archivos no deseados se copien en la imagen de Docker y la posibilidad de sobrescribir los módulos instalados dentro de su imagen. Le recomendamos encarecidamente que lo utilice junto con Dockerfiles.

El archivo Dockerignore debe estar en el mismo directorio que Dockerfile.

vim .dockerignore

Aquí agregamos los siguientes contenidos:

.env
Dockerfile
node_modules
test
.vscode
.eslintrc.js

Guardar y salir del archivo.

Crea una imagen de Docker

docker build . -t fosslinuxdemo/nodejsapp

Crear imagen
Crear imagen

Debería llevar algún tiempo completar el proceso. Por favor sea paciente.

Imagen creada
Imagen creada

Lista de imágenes de Docker

Ejecute el siguiente comando para listar imágenes:

docker images

Lista de imágenes
Lista de imágenes

Ejecutar imagen de Docker

docker run -itd -p 3000:3000 fosslinuxdemo/nodejsapp

-itd: - ejecuta el contenedor en segundo plano

-p: - flag redirige un puerto público a un puerto privado dentro del contenedor

4. Docker Compose

Compose es una herramienta para definir y ejecutar aplicaciones Docker de varios contenedores. Con Compose, usaremos un archivo YAML para configurar los servicios de la aplicación. Posteriormente, con un solo comando, crearemos e iniciaremos todos los servicios desde nuestra configuración.

Instalar Redactar

Antes de instalar el compositor, primero debe instalar Docker.

Ejecute este comando para descargar la versión estable actual de Docker Compose:

curl -L "https://github.com/docker/compose/releases/download/1.25.0/docker-compose-$(uname -s)-$(uname -m)" -o /usr/local/bin/docker-compose

Aplicar permisos ejecutables al binario:

chmod +x /usr/local/bin/docker-compose

Prueba la instalación:

docker-compose --version

Instalación de Docker Composer
Instalación de Docker Composer

5. Instalación de WordPress y MySQL con Docker Compose

Crea una carpeta para tu proyecto:

mkdir /opt/fosslinuxdemo

Vaya al directorio creado:

cd /opt/fosslinuxdemo

Aquí crearemos directorios de datos para nuestro contenedor MySQL y nuestro contenedor de WordPress.

mkdir data
mkdir html

Montaremos los directorios anteriores en nuestros contenedores.

Crea un archivo de redacción:

vim docker-compose.yml

Aquí está nuestro archivo docker-compose. Copie el siguiente contenido en su archivo.

version: '3.7'
services:
db:
container_name: fosslinux-mysql
restart: always
image: mysql:5.7
volumes:
- /opt/fosslinuxdemo/data:/var/lib/mysql
command: --default-authentication-plugin=mysql_native_password
environment:
MYSQL_ROOT_PASSWORD: 123456
MYSQL_DATABASE: wordpress
MYSQL_USER: wordpress
MYSQL_PASSWORD: wordpress
ports:
- "3306:3306"
networks:
- fosslinux_net

wp:
container_name: fosslinux-wp
restart: always
volumes:
- "/opt/fosslinuxdemo/html:/var/www/html"
depends_on:
- db
image: wordpress
ports:
- "80:80"
environment:
WORDPRESS_DB_HOST: db:3306
WORDPRESS_DB_USER: wordpress
WORDPRESS_DB_PASSWORD: wordpress
networks:
- fosslinux_net
networks:
fosslinux_net:


Crear archivo y directorios
Crear archivo y directorios

Anote el número de versión. Más detalles sobre el control de versiones de la versión del archivo @ composer.

version: '3.7'
services:
db:

Un servicio en Compose es un contenedor en ejecución y las definiciones de servicio especifican información sobre cómo se ejecutará cada contenedor. Nuestra definición de servicio "db" tiene varias opciones.

container_name: fosslinux-mysql
  • Especifica un nombre para el contenedor.
restart: always
  • Define la política de reinicio del contenedor
image: mysql:5.7
volumes:https://hub.docker.com/_/mysql
- /opt/fosslinuxdemo/data:/var/lib/mysql

Aquí montamos el volumen "/ opt / fosslinuxdemo / data" en el directorio "/ var / lib / mysql" del contenedor. Generalmente, es el directorio de datos estándar para MySQL en la mayoría de las distribuciones.

command: --default-authentication-plugin=mysql_native_password

Esta opción especifica un comando para anular la instrucción CMD predeterminada para la imagen.

environment:

Defina variables de entorno. Aquí configuramos las variables de MySQL.

 ports:
- "3306:3306"
networks:
- fosslinux_net
  • Define una red para el contenedor.
depends_on:
- db

Esto representa que nuestros contenedores comenzarán en orden de dependencia, con el contenedor "wp" comenzando después del contenedor "db".

Ahora podemos crear nuestro entorno.

 docker-compose up -d

-d bandera, que ejecutará contenedores en segundo plano.

Creando Ambiente
Creando Ambiente

Enumere los contenedores de Docker:

docker ps -a

Contenedores creados
Contenedores creados

Verifique los registros del contenedor de WordPress:

docker logs -f fosslinux-wp

Ahora vaya al navegador web y escriba su IP para obtener la ventana de instalación de WordPress.

Instalación de WordPress
Instalación de WordPress

Proceda a hacer clic en, continúe y complete el proceso de instalación de WordPress.

Se trata de trabajar con Dockerfiles y Docker Compose. Espero que hayas disfrutado el artículo.

Deja una respuesta

Tu dirección de correo electrónico no será publicada. Los campos obligatorios están marcados con *

Subir