Balans opterećenja s Dockerom

Balans opterećenja s Dockerom

Kada izvodite web-aplikaciju, obično želite maksimalno iskoristiti svoje resurse bez potrebe za konvertiranjem softvera za korištenje višenitnih ili složenih petlji događaja. Docker, međutim, pruža jednostavan način da interno uravnotežite svoju aplikaciju kako biste maksimalno iskoristili resurse poslužitelja. Ovaj članak će vam pokazati kako koristiti Nginx za balansiranje opterećenja vaše web aplikacije pomoću Dockera na CentOS-u.

Korak 1: Napravite jednostavnu aplikaciju

Za izradu ove jednostavne aplikacije koristit ćemo rust. Pod pretpostavkom da imate instaliran rust, pokrenite cargo new webapp –bin. Nakon uspjeha, vidjet ćete direktorij pod nazivom webapp. Unutar webapp, vidjet ćete datoteku pod nazivom Cargo.toml. Dodajte mu sljedeće retke:

[dependencies.iron]
version = "*"

Zatim, unutar src/main.rsdatoteke, uklonite sve i popunite je sljedećim:

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

Napomena: Nemojte mijenjati IP unutar aplikacije. Ovo je konfigurirano tako da Docker može slušati vašu aplikaciju.

Nakon što završite, sastavite aplikaciju izvršavanjem cargo build –release. Ovisno o vašem poslužitelju, može potrajati nekoliko minuta. Ako nema pogrešaka, testirajte aplikaciju slijedeći ove korake:

  • Trči target/release/webapp.
  • Dođite do http://0.0.0.0:3000/u svom pregledniku. Zamijenite 0.0.0.0IP adresom vašeg poslužitelja.

Ako je sve funkcioniralo kako treba, vidjet ćete "Hello Vultr :)" na stranici.

Korak 2: Stvorite Docker spremnike

Napravite Dockerfilei popunite ga sljedećim:

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

Spremite datoteku. Zatim stvorite datoteku pod nazivom deploy.shi popunite je sljedećim:

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

Kada pokrenete ovu skriptu, ona će izgraditi sliku i postaviti spremnik na temelju količine koju ste postavili (zadano je 5). Ako spremnik postoji, uništit će ga i ukloniti iz registra prije nego što se ponovno implementira.

Korak 3: Konfigurirajte Nginx

Sada stvorite Nginx konfiguracijsku datoteku i popunite je sljedećim:

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

Zamijenite 0.0.0.0IP adresom vašeg poslužitelja.

Ponovno pokrenite Nginx tako što ćete učiniti systemctl restart nginx. Riješite sve pogreške, a zatim nastavite na sljedeći korak.

Korak 4: Postavite aplikaciju

Pokrenite aplikaciju pokretanjem bash ./deploy.sh.

Status svoje aplikacije možete provjeriti pomoću docker ps- bit će kreirano 5 slika koje počinju s webapp. Sada, idite na http://0.0.0.0:3000/u svom pregledniku, ponovno ćete vidjeti poruku "Zdravo, Vultr :)".

Dakle, kakva je to razlika, točno?

Ako pokrenete benchmark test u odnosu na konfiguraciju balansiranja opterećenja, primijetit ćete da se koristi više resursa vašeg poslužitelja, što biste i željeli, pogotovo ako je vaša aplikacija izgrađena na jezicima kao što je Node gdje bi inače bila jednostruka. Ako ikada trebate nadograditi svoju aplikaciju, možete to učiniti i ponovno pokrenuti da deploy.shbiste ponovno izgradili sliku i postavili svoje spremnike.


Instalirajte Rancher OS putem iPXE

Instalirajte Rancher OS putem iPXE

Rancher OS je vrlo lagana distribucija Linuxa izgrađena oko Dockera. Sam OS teži oko 20MB. Ovaj vodič će vas pokrenuti i pokrenuti

Instalacija docker-compose na CoreOS

Instalacija docker-compose na CoreOS

Ovaj članak objašnjava kako instalirati docker-compose na CoreOS. U CoreOS-u, /usr/ mapa je nepromjenjiva pa je standardna /usr/local/bin putanja nedostupna za

Instalirajte Docker CE na Ubuntu 18.04

Instalirajte Docker CE na Ubuntu 18.04

Uvod Docker je aplikacija koja nam omogućuje implementaciju programa koji se pokreću kao spremnici. Napisana je u popularnom programskom jeziku Go

Stvorite Docker Swarm na Alpine Linuxu 3.9.0

Stvorite Docker Swarm na Alpine Linuxu 3.9.0

Uvod Ovaj vodič će vam pokazati kako stvoriti i konfigurirati Docker roj koristeći više Alpine Linux 3.9.0 poslužitelja i Portainera. Imajte na umu da

Postavite PHP aplikaciju pomoću Docker-compose

Postavite PHP aplikaciju pomoću Docker-compose

PHP aplikacije obično se sastoje od web poslužitelja, sustava relacijske baze podataka i samog tumača jezika. U ovom tutorialu bit ćemo poluga

Balans opterećenja s Dockerom

Balans opterećenja s Dockerom

Kada izvodite web-aplikaciju, obično želite maksimalno iskoristiti svoje resurse bez potrebe da konvertirate svoj softver za korištenje višenitnog rada o

Postavite Node.js aplikaciju pomoću Dockera

Postavite Node.js aplikaciju pomoću Dockera

Ovaj članak će vam pokazati kako implementirati svoju Node aplikaciju unutar Docker spremnika. Napomena: Ovaj vodič pretpostavlja da imate instaliran i pročitan Docker

Instaliranje Dockera na CentOS 7

Instaliranje Dockera na CentOS 7

Korištenje drugog sustava? Docker je aplikacija koja omogućuje implementaciju softvera unutar virtualnih spremnika. Napisano je u Go programu

Instalacija Docker CE na Debian 9

Instalacija Docker CE na Debian 9

Korištenje drugog sustava? Uvod Docker je aplikacija koja omogućuje implementaciju softvera unutar virtualnih spremnika. Napisano je u G

Započnite sa SQL Serverom 2017 (MS-SQL) na CentOS 7 uz Docker

Započnite sa SQL Serverom 2017 (MS-SQL) na CentOS 7 uz Docker

Preduvjeti Docker engine 1.8+. Najmanje 4 GB prostora na disku. Minimalno 4 GB RAM-a. Korak 1. Instalirajte Docker Da biste instalirali SQL-Server, potrebno je Docker

Sticky Session with Docker Swarm (CE) na Debianu 9

Sticky Session with Docker Swarm (CE) na Debianu 9

Korištenje drugog sustava? Uvod Docker Swarm pretvara vaše pojedinačne poslužitelje u klaster računala; olakšavanje skaliranja, visoka dostupnost an

Dva Docker grafička alata za upravljanje: DockerUI i Shipyard

Dva Docker grafička alata za upravljanje: DockerUI i Shipyard

Uz pomoć aplikacije Vultr Docker, možete jednostavno postaviti Docker na svoju instancu poslužitelja Vultr. U međuvremenu, možete olakšati zadatak upravljanja Dockerom

Instalirajte Rancher Server na RancherOS

Instalirajte Rancher Server na RancherOS

Pregled RancherOS je nevjerojatno lagan operativni sustav (samo oko 60 MB) koji pokreće sistemski Docker demon kao PID 0 za pokretanje sistemskih usluga

Instalirajte Rancher na Ubuntu 16.04

Instalirajte Rancher na Ubuntu 16.04

Korištenje drugog sustava? Uvod Rancher je platforma otvorenog koda za pokretanje kontejnera i izgradnju privatnog kontejnerskog servisa. Rančer je baza

Postavite Sentry putem Dockera na Ubuntu 16.04

Postavite Sentry putem Dockera na Ubuntu 16.04

Korištenje drugog sustava? Uvod Sentry je rješenje otvorenog koda za praćenje pogrešaka. Sentry prati iznimke i druge korisne poruke

Instaliranje Dockera na Ubuntu 14.04

Instaliranje Dockera na Ubuntu 14.04

Korištenje drugog sustava? Docker je aplikacija koja omogućuje implementaciju programa koji se pokreću kao kontejneri. Napisano je u popularnom Go programu

Sigurno implementirajte i upravljajte LXC spremnicima na Ubuntu 14.04

Sigurno implementirajte i upravljajte LXC spremnicima na Ubuntu 14.04

LXC spremnici (Linux spremnici) su značajka operacijskog sustava u Linuxu koja se može koristiti za pokretanje više izoliranih Linux sustava na jednom hostu. Thes

Uspon strojeva: primjene AI u stvarnom svijetu

Uspon strojeva: primjene AI u stvarnom svijetu

Umjetna inteligencija nije u budućnosti, ovdje je upravo u sadašnjosti. U ovom blogu Pročitajte kako su aplikacije umjetne inteligencije utjecale na različite sektore.

DDOS napadi: kratak pregled

DDOS napadi: kratak pregled

Jeste li i vi žrtva DDOS napada i zbunjeni ste metodama prevencije? Pročitajte ovaj članak kako biste riješili svoje upite.

Jeste li se ikada zapitali kako hakeri zarađuju novac?

Jeste li se ikada zapitali kako hakeri zarađuju novac?

Možda ste čuli da hakeri zarađuju mnogo novca, ali jeste li se ikada zapitali kako zarađuju toliki novac? raspravimo.

Revolucionarni Googleovi izumi koji će vam olakšati život.

Revolucionarni Googleovi izumi koji će vam olakšati život.

Želite li vidjeti revolucionarne izume Googlea i kako su ti izumi promijenili život svakog čovjeka danas? Zatim čitajte na blogu kako biste vidjeli Googleove izume.

Friday Essential: Što se dogodilo s automobilima s umjetnom inteligencijom?

Friday Essential: Što se dogodilo s automobilima s umjetnom inteligencijom?

Koncept samovozećih automobila koji će krenuti na ceste uz pomoć umjetne inteligencije san je koji već neko vrijeme imamo. No, unatoč nekoliko obećanja, nigdje ih nema. Pročitajte ovaj blog kako biste saznali više…

Tehnološka singularnost: daleka budućnost ljudske civilizacije?

Tehnološka singularnost: daleka budućnost ljudske civilizacije?

Kako se znanost razvija velikom brzinom, preuzimajući mnoge naše napore, raste i rizik da se podvrgnemo neobjašnjivoj Singularnosti. Pročitajte što bi za nas mogla značiti singularnost.

Evolucija pohrane podataka – Infografika

Evolucija pohrane podataka – Infografika

Metode pohrane podataka su se razvijale možda od rođenja podataka. Ovaj blog pokriva evoluciju pohrane podataka na temelju infografike.

Funkcionalnosti slojeva referentne arhitekture velikih podataka

Funkcionalnosti slojeva referentne arhitekture velikih podataka

Pročitajte blog kako biste na najjednostavniji način upoznali različite slojeve u arhitekturi velikih podataka i njihove funkcionalnosti.

6 nevjerojatnih prednosti posjedovanja pametnih kućnih uređaja u našim životima

6 nevjerojatnih prednosti posjedovanja pametnih kućnih uređaja u našim životima

U ovom digitalnom svijetu, pametni kućni uređaji postali su ključni dio života. Evo nekoliko nevjerojatnih prednosti pametnih kućnih uređaja o tome kako naš život čine vrijednim življenja i jednostavnijim.

Ažuriranje dodataka macOS Catalina 10.15.4 uzrokuje više problema nego što ih rješava

Ažuriranje dodataka macOS Catalina 10.15.4 uzrokuje više problema nego što ih rješava

Nedavno je Apple izdao macOS Catalina 10.15.4 dodatak ažuriranju kako bi riješio probleme, ali čini se da ažuriranje uzrokuje više problema koji dovode do zalijevanja mac strojeva. Pročitajte ovaj članak da biste saznali više