Vyvážení zatížení pomocí Dockeru

Vyvážení zatížení pomocí Dockeru

Když spouštíte webovou aplikaci, obvykle chcete ze svých zdrojů vytěžit maximum, aniž byste museli převádět software, aby používal vícevláknové zpracování nebo složité smyčky událostí. Docker však poskytuje jednoduchý způsob, jak interně vyvážit zatížení vaší aplikace, abyste co nejlépe využili prostředky serveru. Tento článek vám ukáže, jak používat Nginx k vyvážení zatížení vaší webové aplikace pomocí Dockeru na CentOS.

Krok 1: Vytvořte jednoduchou aplikaci

K vytvoření této jednoduché aplikace použijeme rez. Za předpokladu, že máte nainstalovanou rez, spusťte cargo new webapp –bin. Po úspěchu uvidíte adresář s názvem webapp. Uvnitř webappuvidíte soubor s názvem Cargo.toml. Připojte k němu následující řádky:

[dependencies.iron]
version = "*"

Dále uvnitř src/main.rssouboru odeberte vše a naplňte jej následujícím:

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();
}

Poznámka: Neměňte IP v rámci aplikace. To je nakonfigurováno tak, aby Docker mohl poslouchat vaši aplikaci.

Po dokončení zkompilujte aplikaci spuštěním cargo build –release. V závislosti na vašem serveru to může trvat několik minut. Pokud nejsou žádné chyby, otestujte aplikaci podle následujících kroků:

  • Spustit target/release/webapp.
  • Přejděte http://0.0.0.0:3000/ve svém prohlížeči na. Nahraďte 0.0.0.0ji IP adresou vašeho serveru.

Pokud vše fungovalo správně, uvidíte na stránce "Ahoj Vultr :)".

Krok 2: Vytvořte kontejnery Docker

Vytvořte Dockerfilea naplňte jej následujícím:

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

Uložte soubor. Poté vytvořte soubor s názvem deploy.sha naplňte jej následujícím způsobem:

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

Když spustíte tento skript, vytvoří obraz a nasadí kontejner na základě množství, které jste nastavili (výchozí je 5). Pokud kontejner existuje, před dalším nasazením jej ukončí a odebere z registru.

Krok 3: Nakonfigurujte Nginx

Nyní vytvořte konfigurační soubor Nginx a naplňte jej následujícím:

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;
    }
}

Nahraďte 0.0.0.0ji IP adresou vašeho serveru.

Restartujte Nginx provedením systemctl restart nginx. Vyřešte všechny chyby a pokračujte dalším krokem.

Krok 4: Nasazení aplikace

Nasaďte aplikaci spuštěním bash ./deploy.sh.

Stav své aplikace můžete zkontrolovat pomocí docker ps– bude vytvořeno 5 obrázků začínajících na webapp. Nyní přejděte http://0.0.0.0:3000/ve svém prohlížeči na, znovu se vám zobrazí zpráva „Ahoj, Vultr :)“.

Takže, jaký je v tom přesně rozdíl?

Pokud spustíte srovnávací test s konfigurací nástroje pro vyrovnávání zatížení, zjistíte, že se využívá více prostředků vašeho serveru, což byste chtěli, zvláště pokud je vaše aplikace postavena v jazycích, jako je Node, kde by normálně byla jednovláknová. Pokud budete někdy potřebovat upgradovat svou aplikaci, můžete to udělat a znovu spustit, deploy.shabyste znovu vytvořili bitovou kopii a nasadili své kontejnery.


Zde je návod, jak zkontrolovat kontejnery Hyper-V na Windows 10 Insider

Zde je návod, jak zkontrolovat kontejnery Hyper-V na Windows 10 Insider

Společnost Microsoft v novém příspěvku na blogu vysvětlila, jak mohou Windows Insiders testovat kontejnery Hyper-V na Windows 10, nové virtualizační řešení, které umožňuje běh aplikací bez ovlivnění zbytku operačního systému.

Jak nainstalovat Harbor na CentOS 7

Jak nainstalovat Harbor na CentOS 7

Harbor je open source server registru podnikové třídy, který ukládá a distribuuje obrazy Docker. Harbor rozšiřuje open source Docker Distribution b

Nainstalujte Rancher OS přes iPXE

Nainstalujte Rancher OS přes iPXE

Rancher OS je velmi lehká linuxová distribuce postavená na Dockeru. Samotný OS váží kolem 20 MB. Tento tutoriál vám pomůže začít

V systému CoreOS nastavte svůj vlastní registr Docker

V systému CoreOS nastavte svůj vlastní registr Docker

Všichni známe a milujeme Docker, platformu pro vytváření, správu a distribuci aplikačních kontejnerů na více počítačích. Společnost Docker Inc. poskytuje službu t

Instalace docker-compose na CoreOS

Instalace docker-compose na CoreOS

Tento článek vysvětluje, jak nainstalovat docker-compose na CoreOS. V CoreOS je složka /usr/ neměnná, takže standardní cesta /usr/local/bin není k dispozici pro

Nainstalujte Docker CE na Ubuntu 18.04

Nainstalujte Docker CE na Ubuntu 18.04

Úvod Docker je aplikace, která nám umožňuje nasazovat programy, které jsou spouštěny jako kontejnery. Byl napsán v populárním programovacím jazyce Go

Vytvořte Docker Swarm na Alpine Linux 3.9.0

Vytvořte Docker Swarm na Alpine Linux 3.9.0

Úvod Tato příručka vám ukáže, jak vytvořit a nakonfigurovat Docker swarm pomocí několika serverů Alpine Linux 3.9.0 a Porttaineru. Prosím, uvědomte si to

Nasaďte aplikaci PHP pomocí Docker-compose

Nasaďte aplikaci PHP pomocí Docker-compose

PHP aplikace jsou obvykle tvořeny webovým serverem, relačním databázovým systémem a samotným jazykovým interpretem. V tomto tutoriálu budeme využívat

Vyvážení zatížení pomocí Dockeru

Vyvážení zatížení pomocí Dockeru

Když spouštíte webovou aplikaci, obvykle chcete ze svých zdrojů vytěžit maximum, aniž byste museli převádět software, aby používal více vláken nebo

Nasaďte aplikaci Node.js pomocí Dockeru

Nasaďte aplikaci Node.js pomocí Dockeru

Tento článek vám ukáže, jak nasadit aplikaci Node v kontejneru Docker. Poznámka: Tento kurz předpokládá, že máte nainstalovaný a přečtený Docker

Instalace Docker CE na CentOS 7

Instalace Docker CE na CentOS 7

Technologie kontejnerů Docker umožňuje spouštět aplikace ve specifickém a izolovaném prostředí. Docker Community Edition (CE) je nový název pro free

Nasaďte Kubernetes s Kubeadm na CentOS 7

Nasaďte Kubernetes s Kubeadm na CentOS 7

Přehled Tento článek vám má pomoci během okamžiku zprovoznit a spustit cluster Kubernetes s kubeadm. Tato příručka bude nasazovat dva servery, na

Instalace Dockeru na CentOS 7

Instalace Dockeru na CentOS 7

Používáte jiný systém? Docker je aplikace, která umožňuje nasazení softwaru v rámci virtuálních kontejnerů. Bylo to napsáno v programu Go

Instalace Docker CE na Debian 9

Instalace Docker CE na Debian 9

Používáte jiný systém? Úvod Docker je aplikace, která umožňuje nasazení softwaru ve virtuálních kontejnerech. Bylo to napsáno v G

Sticky Session With Docker Swarm (CE) na Debianu 9

Sticky Session With Docker Swarm (CE) na Debianu 9

Používáte jiný systém? Úvod Docker Swarm promění vaše jednotlivé servery na shluk počítačů; usnadnění škálování, vysoká dostupnost an

Dva nástroje pro správu grafiky Docker: DockerUI a Shipyard

Dva nástroje pro správu grafiky Docker: DockerUI a Shipyard

Pomocí aplikace Vultr Docker můžete snadno nasadit Docker na instanci serveru Vultr. Mezitím můžete usnadnit správu Dockeru

Nainstalujte Rancher Server na RancherOS

Nainstalujte Rancher Server na RancherOS

Přehled RancherOS je neuvěřitelně lehký operační systém (jen asi 60 MB), který spouští systémového démona Docker jako PID 0 pro spouštění systémových služeb.

Začínáme s Kubernetes na CentOS 7

Začínáme s Kubernetes na CentOS 7

Kubernetes je platforma s otevřeným zdrojovým kódem vyvinutá společností Google pro správu kontejnerových aplikací napříč clusterem serverů. Staví na desetiletí a

Nastavte Sentry přes Docker na Ubuntu 16.04

Nastavte Sentry přes Docker na Ubuntu 16.04

Používáte jiný systém? Úvod Sentry je open source řešení pro sledování chyb. Sentry sleduje výjimky a další užitečné zprávy

Sticky Session With Docker Swarm (CE) na CentOS 7

Sticky Session With Docker Swarm (CE) na CentOS 7

Používáte jiný systém? Úvod Docker Swarm promění vaše jednotlivé servery na shluk počítačů, což usnadňuje škálování, vysokou dostupnost a

The Rise of Machines: Real World Applications of AI

The Rise of Machines: Real World Applications of AI

Umělá inteligence není v budoucnosti, je zde přímo v současnosti V tomto blogu si přečtěte, jak aplikace umělé inteligence ovlivnily různé sektory.

Útoky DDOS: Stručný přehled

Útoky DDOS: Stručný přehled

Jste také obětí DDOS útoků a nemáte jasno v metodách prevence? Chcete-li vyřešit své dotazy, přečtěte si tento článek.

Přemýšleli jste někdy, jak hackeři vydělávají peníze?

Přemýšleli jste někdy, jak hackeři vydělávají peníze?

Možná jste slyšeli, že hackeři vydělávají spoustu peněz, ale napadlo vás někdy, jak takové peníze vydělávají? Pojďme diskutovat.

Revoluční vynálezy od Googlu, které vám usnadní život.

Revoluční vynálezy od Googlu, které vám usnadní život.

Chcete vidět revoluční vynálezy Google a jak tyto vynálezy změnily život každého dnešního člověka? Pak si přečtěte na blogu a podívejte se na vynálezy od Googlu.

Friday Essential: Co se stalo s auty řízenými umělou inteligencí?

Friday Essential: Co se stalo s auty řízenými umělou inteligencí?

Koncept aut s vlastním pohonem, která vyrazí na silnice s pomocí umělé inteligence, je snem, který už nějakou dobu máme. Ale přes několik slibů nejsou nikde vidět. Přečtěte si tento blog a dozvíte se více…

Technologická singularita: vzdálená budoucnost lidské civilizace?

Technologická singularita: vzdálená budoucnost lidské civilizace?

Jak se věda vyvíjí rychlým tempem a přebírá mnoho našeho úsilí, stoupá také riziko, že se vystavíme nevysvětlitelné singularitě. Přečtěte si, co pro nás může znamenat singularita.

Evoluce ukládání dat – Infografika

Evoluce ukládání dat – Infografika

Způsoby ukládání dat se mohou vyvíjet od narození dat. Tento blog se zabývá vývojem ukládání dat na základě infografiky.

Funkcionality vrstev referenční architektury velkých dat

Funkcionality vrstev referenční architektury velkých dat

Přečtěte si blog, abyste co nejjednodušším způsobem poznali různé vrstvy v architektuře velkých dat a jejich funkce.

6 úžasných výhod toho, že máme v životě zařízení pro chytrou domácnost

6 úžasných výhod toho, že máme v životě zařízení pro chytrou domácnost

V tomto digitálním světě se chytrá domácí zařízení stala klíčovou součástí života. Zde je několik úžasných výhod chytrých domácích zařízení o tom, jak náš život stojí za to žít a zjednodušit jej.

Aktualizace doplňku macOS Catalina 10.15.4 způsobuje více problémů než řešení

Aktualizace doplňku macOS Catalina 10.15.4 způsobuje více problémů než řešení

Apple nedávno vydal doplňkovou aktualizaci macOS Catalina 10.15.4, která opravuje problémy, ale zdá se, že aktualizace způsobuje další problémy, které vedou k zablokování počítačů mac. Přečtěte si tento článek a dozvíte se více