Instalación de Docker en Ubuntu 14.04
¿Usando un sistema diferente? Docker es una aplicación que permite implementar programas que se ejecutan como contenedores. Fue escrito en el popular programa Go
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.
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.rs
archivo, 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:
target/release/webapp
.http://0.0.0.0:3000/
en tu navegador. Reemplace 0.0.0.0
con la dirección IP de su servidor.Si todo funcionó correctamente, verá "Hola Vultr :)" en la página.
Cree a Dockerfile
y 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.sh
y 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.
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.0
con la dirección IP de su servidor.
Reinicie Nginx haciendo systemctl restart nginx
. Resuelva cualquier error, luego continúe con el siguiente paso.
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.sh
a ejecutarla para reconstruir la imagen e implementar sus contenedores.
¿Usando un sistema diferente? Docker es una aplicación que permite implementar programas que se ejecutan como contenedores. Fue escrito en el popular programa Go
Using a Different System? Introduction Sentry is an open source solution for error tracking. Sentry tracks exceptions and other useful messages fro
Descripción general RancherOS es un sistema operativo increíblemente liviano (solo unos 60 MB) que ejecuta un demonio Docker del sistema como PID 0 para ejecutar servicios del sistema
Este tutorial explica los conceptos básicos para comenzar a usar Docker. Supongo que ya tienes instalado Docker. Los pasos de este tutorial funcionarán en un
Todos conocemos y amamos Docker, una plataforma para crear, administrar y distribuir contenedores de aplicaciones en múltiples máquinas. Docker Inc. proporciona un servicio t
Introduction This guide will show you how to create and configure a Docker swarm using multiple Alpine Linux 3.9.0 servers and Portainer. Please be aware tha
Este artículo le mostrará cómo implementar su aplicación Node dentro de un contenedor Docker. Nota: Este tutorial asume que tienes Docker instalado y leído
Rancher OS es una distribución de Linux muy ligera construida alrededor de Docker. El sistema operativo en sí pesa alrededor de 20 MB. Este tutorial lo pondrá en funcionamiento con
Overview This article is meant to help you get a Kubernetes cluster up and running with kubeadm in no time. This guide will be deploying two servers, on
Este artículo explica cómo instalar docker-compose en CoreOS. En CoreOS, la carpeta / usr / es inmutable, por lo que la ruta estándar / usr / local / bin no está disponible para
Harbor es un servidor de registro de clase empresarial de código abierto que almacena y distribuye imágenes de Docker. Harbor extiende el código abierto Docker Distribution b
Introduction Docker is an application that allows us to deploy programs that are run as containers. It was written in the popular Go programming language
Requisitos previos Docker engine 1.8+. Mínimo de 4 GB de espacio en disco. Mínimo de 4 GB de RAM. Paso 1. Instalar Docker Para instalar SQL-Server, Docker mus
Kubernetes es una plataforma de código abierto desarrollada por Google para administrar aplicaciones en contenedores en un grupo de servidores. Se basa en una década y
Las aplicaciones PHP generalmente están compuestas por un servidor web, un sistema de base de datos relacional y el propio intérprete de idiomas. En este tutorial estaremos apalancando
¿Usando un sistema diferente? Introducción Rancher es una plataforma de código abierto para ejecutar contenedores y crear un servicio de contenedor privado. Ranchero es base
Using a Different System? Introduction Docker Swarm turns your individual servers into a cluster of computers; facilitating scaling, high-availability an
La tecnología de contenedores Docker le permite ejecutar aplicaciones en un entorno específico y aislado. Docker Community Edition (CE) es el nuevo nombre para el fre
¿Usando un sistema diferente? Introducción Docker es una aplicación que permite la implementación de software en contenedores virtuales. Fue escrito en el G
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, 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.
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+
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.
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
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.
A medida que la ciencia evoluciona a un ritmo rápido, asumiendo muchos de nuestros esfuerzos, también aumentan los riesgos de someternos a una singularidad inexplicable. Lea, lo que la singularidad podría significar para nosotros.
Una mirada a 26 técnicas analíticas de Big Data: Parte 1
La IA en la salud ha dado grandes pasos desde las últimas décadas. Por tanto, el futuro de la IA en el sector sanitario sigue creciendo día a día.