Korak 1: Napravite jednostavnu aplikaciju
Korak 2: Stvorite Docker spremnike
Korak 3: Konfigurirajte Nginx
Korak 4: Postavite aplikaciju
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.
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.