Vyváženie zaťaženia pomocou Docker

Pri spustení webovej aplikácie zvyčajne chcete vyťažiť maximum zo svojich zdrojov bez toho, aby ste museli konvertovať softvér na používanie viacerých vlákien alebo zložitých cyklov udalostí. Docker však poskytuje jednoduchý spôsob, ako interne vyvážiť zaťaženie vašej aplikácie, aby ste čo najlepšie využili prostriedky servera. Tento článok vám ukáže, ako používať Nginx na vyrovnávanie zaťaženia vašej webovej aplikácie pomocou Docker na CentOS.

Krok 1: Vytvorte jednoduchú aplikáciu

Na vytvorenie tejto jednoduchej aplikácie použijeme hrdzu. Za predpokladu, že máte nainštalovanú hrdzu, spustite cargo new webapp –bin. Po úspechu uvidíte adresár s názvom webapp. Vo vnútri webappuvidíte súbor s názvom Cargo.toml. Pripojte k nemu nasledujúce riadky:

[dependencies.iron]
version = "*"

Ďalej v src/main.rssúbore odstráňte všetko a naplňte ho nasledujúcim:

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: Nemeňte IP v rámci aplikácie. Toto je nakonfigurované tak, aby Docker mohol počúvať vašu aplikáciu.

Po dokončení skompilujte aplikáciu spustením cargo build –release. V závislosti od vášho servera to môže trvať niekoľko minút. Ak sa nevyskytnú žiadne chyby, otestujte aplikáciu podľa týchto krokov:

  • Bežať target/release/webapp.
  • http://0.0.0.0:3000/Vo svojom prehliadači prejdite na . Nahraďte 0.0.0.0adresu IP vášho servera.

Ak všetko fungovalo správne, na stránke uvidíte „Ahoj Vultr :)“.

Krok 2: Vytvorte kontajnery Docker

Vytvorte a Dockerfilea naplňte ho nasledujúcim:

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 súbor. Potom vytvorte súbor s názvom deploy.sha naplňte ho nasledujúcim:

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

Keď spustíte tento skript, vytvorí obrázok a nasadí kontajner na základe množstva, ktoré ste nastavili (predvolená hodnota je 5). Ak kontajner existuje, pred opätovným nasadením ho zabije a odstráni z registra.

Krok 3: Nakonfigurujte Nginx

Teraz vytvorte konfiguračný súbor Nginx a naplňte ho nasledujúcim:

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.0adresu IP vášho servera.

Reštartujte Nginx vykonaním systemctl restart nginx. Vyriešte všetky chyby a potom pokračujte ďalším krokom.

Krok 4: Nasaďte aplikáciu

Nasaďte aplikáciu spustením bash ./deploy.sh.

Stav svojej aplikácie môžete skontrolovať pomocou docker ps– vytvorí sa 5 obrázkov, ktoré začínajú na webapp. Teraz prejdite na http://0.0.0.0:3000/vo svojom prehliadači a znova sa vám zobrazí správa „Ahoj, Vultr :)“.

Takže, aký je v tom presne rozdiel?

Ak spustíte benchmarkový test s konfiguráciou nástroja na vyrovnávanie zaťaženia, všimli by ste si, že sa používa viac zdrojov vášho servera, čo by ste chceli, najmä ak je vaša aplikácia postavená v jazykoch, ako je Node, kde by bola normálne jednovláknová. Ak budete niekedy potrebovať inovovať svoju aplikáciu, môžete to urobiť a znova spustiť, deploy.shaby ste znova vytvorili obraz a nasadili svoje kontajnery.

Zanechať komentár

The Rise of Machines: Real World Applications of AI

The Rise of Machines: Real World Applications of AI

Umelá inteligencia nie je v budúcnosti, je tu priamo v súčasnosti V tomto blogu si prečítajte, ako aplikácie umelej inteligencie ovplyvnili rôzne sektory.

Útoky DDOS: Stručný prehľad

Útoky DDOS: Stručný prehľad

Ste aj vy obeťou DDOS útokov a máte zmätok ohľadom metód prevencie? Ak chcete vyriešiť svoje otázky, prečítajte si tento článok.

Zaujímalo vás niekedy, ako hackeri zarábajú peniaze?

Zaujímalo vás niekedy, ako hackeri zarábajú peniaze?

Možno ste už počuli, že hackeri zarábajú veľa peňazí, ale premýšľali ste niekedy nad tým, ako môžu zarábať také peniaze? poďme diskutovať.

Revolučné vynálezy od spoločnosti Google, ktoré vám uľahčia život.

Revolučné vynálezy od spoločnosti Google, ktoré vám uľahčia život.

Chcete vidieť revolučné vynálezy od Google a ako tieto vynálezy zmenili život každého dnešného človeka? Potom si prečítajte na blogu a pozrite si vynálezy spoločnosti Google.

Piatok Essential: Čo sa stalo s autami poháňanými AI?

Piatok Essential: Čo sa stalo s autami poháňanými AI?

Koncept samoriadených áut vyraziť na cesty s pomocou umelej inteligencie je snom, ktorý máme už nejaký čas. Ale napriek niekoľkým prísľubom ich nikde nevidno. Prečítajte si tento blog a dozviete sa viac…

Technologická singularita: vzdialená budúcnosť ľudskej civilizácie?

Technologická singularita: vzdialená budúcnosť ľudskej civilizácie?

Ako sa veda vyvíja rýchlym tempom a preberá veľa nášho úsilia, zvyšuje sa aj riziko, že sa vystavíme nevysvetliteľnej singularite. Prečítajte si, čo pre nás môže znamenať singularita.

Funkcionality vrstiev referenčnej architektúry veľkých dát

Funkcionality vrstiev referenčnej architektúry veľkých dát

Prečítajte si blog, aby ste čo najjednoduchším spôsobom spoznali rôzne vrstvy architektúry veľkých dát a ich funkcie.

Vývoj ukladania dát – Infografika

Vývoj ukladania dát – Infografika

Spôsoby ukladania údajov sa môžu vyvíjať už od zrodu údajov. Tento blog sa zaoberá vývojom ukladania údajov na základe infografiky.

6 úžasných výhod toho, že máme v živote inteligentné domáce zariadenia

6 úžasných výhod toho, že máme v živote inteligentné domáce zariadenia

V tomto digitálnom svete sa inteligentné domáce zariadenia stali kľúčovou súčasťou života. Tu je niekoľko úžasných výhod inteligentných domácich zariadení o tom, ako robia náš život, ktorý stojí za to žiť, a ktorý zjednodušujú.

Aktualizácia doplnku macOS Catalina 10.15.4 spôsobuje viac problémov, ako ich rieši

Aktualizácia doplnku macOS Catalina 10.15.4 spôsobuje viac problémov, ako ich rieši

Spoločnosť Apple nedávno vydala doplnkovú aktualizáciu macOS Catalina 10.15.4 na opravu problémov, ale zdá sa, že táto aktualizácia spôsobuje ďalšie problémy, ktoré vedú k blokovaniu počítačov Mac. Prečítajte si tento článok a dozviete sa viac