Kuormituksen tasapaino Dockerin kanssa

Kun käytät verkkosovellusta, haluat yleensä saada kaiken irti resursseistasi ilman, että sinun tarvitsee muuntaa ohjelmistoasi monisäikeisten tai monimutkaisten tapahtumasilmukoiden käyttöön. Docker tarjoaa kuitenkin yksinkertaisen tavan tasapainottaa sovelluksesi sisäisesti, jotta saat parhaan hyödyn palvelinresursseista. Tämä artikkeli näyttää, kuinka Nginxiä käytetään verkkosovelluksesi kuormituksen tasapainottamiseen käyttämällä Dockeria CentOS:ssä.

Vaihe 1: Luo yksinkertainen sovellus

Käytämme ruostetta rakentaaksemme tämän yksinkertaisen sovelluksen. Olettaen, että ruoste on asennettu, suorita cargo new webapp –bin. Onnistuessasi näet hakemiston nimeltä webapp. Sisällä webapp, näet tiedoston nimeltä Cargo.toml. Liitä siihen seuraavat rivit:

[dependencies.iron]
version = "*"

src/main.rsPoista seuraavaksi tiedoston sisältä kaikki ja täytä se seuraavilla:

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

Huomautus: Älä muuta IP-osoitetta sovelluksen sisällä. Tämä on määritetty niin, että Docker voi kuunnella sovellustasi.

Kun olet valmis, käännä sovellus suorittamalla cargo build –release. Palvelimestasi riippuen se voi kestää muutaman minuutin. Jos virheitä ei ole, testaa sovellus seuraavasti:

  • Juokse target/release/webapp.
  • Siirry http://0.0.0.0:3000/selaimessasi kohtaan. Korvaa 0.0.0.0palvelimesi IP-osoite.

Jos kaikki toimi oikein, näet sivulla "Hei Vultr :)".

Vaihe 2: Luo Docker-säiliöt

Luo Dockerfileja täytä se seuraavilla:

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

Tallenna tiedosto. Luo sitten tiedosto nimeltä deploy.shja täytä se seuraavalla:

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

Kun suoritat tämän skriptin, se rakentaa kuvan ja ottaa käyttöön säilön määrittämäsi määrän perusteella (oletus on 5). Jos säilö on olemassa, se tappaa ja poistaa sen rekisteristä ennen kuin se otetaan uudelleen käyttöön.

Vaihe 3: Määritä Nginx

Luo nyt Nginx-määritystiedosto ja täytä se seuraavilla:

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

Korvaa 0.0.0.0palvelimesi IP-osoite.

Käynnistä Nginx uudelleen tekemällä systemctl restart nginx. Korjaa mahdolliset virheet ja siirry sitten seuraavaan vaiheeseen.

Vaihe 4: Ota sovellus käyttöön

Ota sovellus käyttöön suorittamalla bash ./deploy.sh.

Voit tarkistaa sovelluksesi tilan painamalla docker ps- luodaan 5 kuvaa, jotka alkavat webapp. Nyt siirtymällä http://0.0.0.0:3000/selaimessasi, näet "Hei, Vultr :)" viesti uudelleen.

Eli mitä eroa tällä tarkalleen ottaen on?

Jos suoritat benchmark-testin kuormituksen tasapainottimen kokoonpanoa vastaan, huomaat, että enemmän palvelinresurssejasi käytetään, mikä on mitä haluat, varsinkin jos sovelluksesi on rakennettu kielille, kuten Node, jossa se tavallisesti olisi yksisäikeinen. Jos joudut joskus päivittämään sovelluksesi, voit tehdä sen ja suorittaa deploy.shsen uudelleen rakentaaksesi kuvan uudelleen ja ottaaksesi säilösi käyttöön.

Jätä kommentti

Koneiden nousu: tekoälyn todelliset sovellukset

Koneiden nousu: tekoälyn todelliset sovellukset

Tekoäly ei ole tulevaisuudessa, se tässä nykyisyydessä Tässä blogissa Lue kuinka tekoälysovellukset ovat vaikuttaneet eri sektoreihin.

DDOS-hyökkäykset: lyhyt katsaus

DDOS-hyökkäykset: lyhyt katsaus

Oletko myös DDOS-hyökkäysten uhri ja hämmentynyt ehkäisymenetelmistä? Lue tämä artikkeli ratkaistaksesi kysymyksesi.

Oletko koskaan miettinyt, kuinka hakkerit ansaitsevat rahaa?

Oletko koskaan miettinyt, kuinka hakkerit ansaitsevat rahaa?

Olet ehkä kuullut, että hakkerit ansaitsevat paljon rahaa, mutta oletko koskaan miettinyt, kuinka he ansaitsevat tuollaista rahaa? keskustellaan.

Googlen vallankumouksellisia keksintöjä, jotka helpottavat elämääsi.

Googlen vallankumouksellisia keksintöjä, jotka helpottavat elämääsi.

Haluatko nähdä Googlen vallankumouksellisia keksintöjä ja kuinka nämä keksinnöt muuttivat jokaisen ihmisen elämää nykyään? Lue sitten blogia nähdäksesi Googlen keksinnöt.

Essential perjantai: Mitä tekoäly-ohjatuille autoille tapahtui?

Essential perjantai: Mitä tekoäly-ohjatuille autoille tapahtui?

Konsepti itseohjautuvista autoista lähteä tielle tekoälyn avulla on ollut haaveena jo jonkin aikaa. Mutta useista lupauksista huolimatta niitä ei näy missään. Lue tämä blogi saadaksesi lisätietoja…

Teknologinen singulaarisuus: ihmissivilisaation kaukainen tulevaisuus?

Teknologinen singulaarisuus: ihmissivilisaation kaukainen tulevaisuus?

Kun tiede kehittyy nopeasti ja ottaa haltuunsa suuren osan ponnisteluistamme, myös riskit altistaa itsemme selittämättömälle singulariteetille kasvavat. Lue, mitä singulaarisuus voisi tarkoittaa meille.

Big Datan referenssiarkkitehtuurikerrosten toiminnot

Big Datan referenssiarkkitehtuurikerrosten toiminnot

Blogista saat tietää Big Data -arkkitehtuurin eri kerroksista ja niiden toiminnoista yksinkertaisimmalla tavalla.

Tietojen tallennuksen evoluutio – Infografiikka

Tietojen tallennuksen evoluutio – Infografiikka

Tietojen säilytystavat ovat kehittyneet mahdollisesti Datan syntymästä lähtien. Tämä blogi käsittelee tiedon tallennuksen kehitystä infografian pohjalta.

6 uskomatonta etua älykkäiden kotilaitteiden käyttämisestä elämässämme

6 uskomatonta etua älykkäiden kotilaitteiden käyttämisestä elämässämme

Tässä digitaalisessa maailmassa kodin älylaitteista on tullut tärkeä osa elämää. Tässä on muutamia älykkäiden kodin laitteiden hämmästyttäviä etuja, joiden avulla ne tekevät elämästämme elämisen arvoista ja yksinkertaisempaa.

macOS Catalina 10.15.4 -täydennyspäivitys aiheuttaa enemmän ongelmia kuin ratkaiseminen

macOS Catalina 10.15.4 -täydennyspäivitys aiheuttaa enemmän ongelmia kuin ratkaiseminen

Apple julkaisi äskettäin macOS Catalina 10.15.4 -lisäpäivityksen ongelmien korjaamiseksi, mutta näyttää siltä, ​​että päivitys aiheuttaa lisää ongelmia, jotka johtavat mac-koneiden tiilikaamiseen. Lue tämä artikkeli saadaksesi lisätietoja