Balance de carga con Docker

Al ejecutar una aplicación web, normalmente desea aprovechar al máximo sus recursos sin tener que convertir su software para usar bucles de eventos múltiples o complejos. Docker, sin embargo, proporciona una manera simple de cargar el equilibrio de su aplicación internamente para aprovechar al máximo los recursos del servidor. Este artículo le mostrará cómo usar Nginx para equilibrar la carga de su aplicación web con Docker en CentOS.

Paso 1: crea una aplicación simple

Usaremos óxido para construir esta sencilla aplicación. Asumiendo que tienes óxido instalado, corre cargo new webapp –bin. Una vez que tenga éxito, verá un directorio llamado webapp. Dentro de webapp, verá un archivo llamado Cargo.toml. Agregue las siguientes líneas:

[dependencies.iron]
version = "*"

Luego, dentro del src/main.rsarchivo, elimine todo y complételo con lo siguiente:

extern crate iron;

use iron::prelude::*;
use iron::status;

fn main() {
    Iron::new(|_: &mut Request| {
        Ok(Response::with((status::Ok, "Hello Vultr :)")))
    }).http("0.0.0.0:3000").unwrap();
}

Nota: No cambie la IP dentro de la aplicación. Esto está configurado para que Docker pueda escuchar su aplicación.

Una vez que haya terminado, compile la aplicación ejecutándola cargo build –release. Dependiendo de su servidor, puede tomar algunos minutos. Si no hay errores, pruebe la aplicación siguiendo estos pasos:

  • Ejecutar target/release/webapp.
  • Navega hasta http://0.0.0.0:3000/en tu navegador. Reemplace 0.0.0.0con la dirección IP de su servidor.

Si todo funcionó correctamente, verá "Hola Vultr :)" en la página.

Paso 2: crear contenedores Docker

Cree a Dockerfiley complételo con lo siguiente:

FROM centos:latest
MAINTAINER User <user@localhost>
RUN yum update -y
COPY ./webapp/target/release/webapp /opt/
EXPOSE 3000
WORKDIR /opt
CMD ./webapp

Guarda el archivo. Luego cree un archivo llamado deploy.shy complételo con lo siguiente:

DEFAULT_PORT=45710
APP_PORT=3000
DEPLOY=5
NAME="webapp"
docker build -t webapp:example . 

for ((i=0; i<DEPLOY; i++)); do
        docker kill $NAME$i ; docker rm $NAME$i
        docker run --name $NAME$i -p 127.0.0.1:$(((i * 1000) + DEFAULT_PORT)):$APP_PORT -d webapp:example
done

Cuando ejecute este script, generará la imagen e implementará el contenedor en función de la cantidad que haya establecido (el valor predeterminado es 5). Si el contenedor existe, lo matará y lo eliminará del registro antes de que se vuelva a implementar.

Paso 3: configurar Nginx

Ahora, cree un archivo de configuración de Nginx y complételo con lo siguiente:

upstream application {
    server localhost:45710;
    server localhost:46710;
    server localhost:47710;
    server localhost:48710;
    server localhost:49710;
}

server {
    listen 0.0.0.0:80;    
    location / {
    expires 1w;
        proxy_pass http://application;
        proxy_redirect off;
        proxy_http_version 1.1;
        proxy_set_header X-Forwarded-Host $host;
        proxy_set_header Host $host;
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
        proxy_set_header X-Real-IP $remote_addr;
    }
}

Reemplace 0.0.0.0con la dirección IP de su servidor.

Reinicie Nginx haciendo systemctl restart nginx. Resuelva cualquier error, luego continúe con el siguiente paso.

Paso 4: Implemente la aplicación

Implemente la aplicación ejecutando bash ./deploy.sh.

Puede verificar el estado de su aplicación con docker ps: habrá 5 imágenes creadas que comenzarán con webapp. Ahora, navegue hasta http://0.0.0.0:3000/en su navegador, verá nuevamente el mensaje "Hola, Vultr :)".

Entonces, ¿qué diferencia hace esto exactamente?

Si ejecuta una prueba de referencia con la configuración del equilibrador de carga, notará que se están utilizando más recursos de su servidor, que es lo que desearía, especialmente si su aplicación está construida en idiomas como Node, donde normalmente sería de un solo subproceso. Si alguna vez necesita actualizar su aplicación, puede hacerlo y volver deploy.sha ejecutarla para reconstruir la imagen e implementar sus contenedores.



Leave a Comment

ZPanel y Sentora en CentOS 6 x64

ZPanel y Sentora en CentOS 6 x64

ZPanel, un panel de control de alojamiento web popular, se bifurcó en 2014 a un nuevo proyecto llamado Sentora. Aprende a instalar Sentora en tu servidor con este tutorial.

Cómo instalar Vtiger CRM Open Source Edition en CentOS 7

Cómo instalar Vtiger CRM Open Source Edition en CentOS 7

Aprende cómo instalar Vtiger CRM, una aplicación de gestión de relaciones con el cliente, en CentOS 7 para aumentar tus ventas y mejorar el servicio al cliente.

Cómo instalar el servidor Counter-Strike 1.6 en Linux

Cómo instalar el servidor Counter-Strike 1.6 en Linux

Esta guía completa le mostrará cómo configurar un servidor Counter-Strike 1.6 en Linux, optimizando el rendimiento y la seguridad para el mejor juego. Aprende los pasos más recientes aquí.

¿Puede la IA luchar con un número cada vez mayor de ataques de ransomware?

¿Puede la IA luchar con un número cada vez mayor de ataques de ransomware?

Los ataques de ransomware van en aumento, pero ¿puede la IA ayudar a lidiar con el último virus informático? ¿Es la IA la respuesta? Lea aquí, sepa que la IA es una bendición o una perdición

ReactOS: ¿Es este el futuro de Windows?

ReactOS: ¿Es este el futuro de Windows?

ReactOS, un sistema operativo de código abierto y gratuito, está aquí con la última versión. ¿Puede satisfacer las necesidades de los usuarios de Windows de hoy en día y acabar con Microsoft? Averigüemos más sobre este estilo antiguo, pero una experiencia de sistema operativo más nueva.

Manténgase conectado a través de la aplicación de escritorio WhatsApp 24 * 7

Manténgase conectado a través de la aplicación de escritorio WhatsApp 24 * 7

Whatsapp finalmente lanzó la aplicación de escritorio para usuarios de Mac y Windows. Ahora puede acceder a Whatsapp desde Windows o Mac fácilmente. Disponible para Windows 8+ y Mac OS 10.9+

¿Cómo puede la IA llevar la automatización de procesos al siguiente nivel?

¿Cómo puede la IA llevar la automatización de procesos al siguiente nivel?

Lea esto para saber cómo la Inteligencia Artificial se está volviendo popular entre las empresas de pequeña escala y cómo está aumentando las probabilidades de hacerlas crecer y dar ventaja a sus competidores.

La actualización complementaria de macOS Catalina 10.15.4 está causando más problemas que resolver

La actualización complementaria de macOS Catalina 10.15.4 está causando más problemas que resolver

Recientemente, Apple lanzó macOS Catalina 10.15.4, una actualización complementaria para solucionar problemas, pero parece que la actualización está causando más problemas que conducen al bloqueo de las máquinas Mac. Lee este artículo para obtener más información

13 Herramientas comerciales de extracción de datos de Big Data

13 Herramientas comerciales de extracción de datos de Big Data

13 Herramientas comerciales de extracción de datos de Big Data

¿Qué es un sistema de archivos de diario y cómo funciona?

¿Qué es un sistema de archivos de diario y cómo funciona?

Nuestra computadora almacena todos los datos de una manera organizada conocida como sistema de archivos de diario. Es un método eficiente que permite a la computadora buscar y mostrar archivos tan pronto como presiona buscar.