Uravnoteženost obremenitve z Dockerjem

Uravnoteženost obremenitve z Dockerjem

Ko izvajate spletno aplikacijo, običajno želite kar najbolje izkoristiti svoje vire, ne da bi morali svojo programsko opremo pretvoriti v uporabo večnitne ali zapletene zanke dogodkov. Docker pa vam ponuja preprost način za interno uravnoteženje obremenitve aplikacije, da kar najbolje izkoristite strežniške vire. Ta članek vam bo pokazal, kako uporabiti Nginx za uravnoteženje obremenitve vaše spletne aplikacije z Dockerjem na CentOS.

1. korak: Ustvarite preprosto aplikacijo

Za izdelavo te preproste aplikacije bomo uporabili rust. Ob predpostavki, da imate nameščen rust, zaženite cargo new webapp –bin. Po uspehu boste videli imenik z imenom webapp. V notranjosti webappboste videli datoteko z imenom Cargo.toml. Dodajte mu naslednje vrstice:

[dependencies.iron]
version = "*"

Nato znotraj src/main.rsdatoteke odstranite vse in jo napolnite z naslednjim:

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

Opomba: IP-ja v aplikaciji ne spreminjajte. To je konfigurirano tako, da lahko Docker posluša vašo aplikacijo.

Ko končate, prevedite aplikacijo tako, da izvedete cargo build –release. Odvisno od vašega strežnika lahko traja nekaj minut. Če ni napak, preizkusite aplikacijo, tako da sledite tem korakom:

  • teci target/release/webapp.
  • http://0.0.0.0:3000/V brskalniku se pomaknite do . Zamenjajte 0.0.0.0z naslovom IP vašega strežnika.

Če je vse delovalo pravilno, boste na strani videli "Hello Vultr :)".

2. korak: ustvarite vsebnike Docker

Ustvarite Dockerfilein ga zapolnite z naslednjim:

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

Shranite datoteko. Nato ustvarite imenovano datoteko deploy.shin jo napolnite z naslednjim:

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

Ko zaženete ta skript, bo ustvaril sliko in razmestil vsebnik glede na količino, ki ste jo nastavili (privzeto je 5). Če vsebnik obstaja, ga bo ubil in odstranil iz registra, preden bo znova nameščen.

3. korak: Konfigurirajte Nginx

Zdaj ustvarite konfiguracijsko datoteko Nginx in jo napolnite z naslednjim:

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

Zamenjajte 0.0.0.0z naslovom IP vašega strežnika.

Znova zaženite Nginx tako, da naredite systemctl restart nginx. Odpravite morebitne napake, nato pa nadaljujte z naslednjim korakom.

4. korak: Namestite aplikacijo

Razmestite aplikacijo tako, da zaženete bash ./deploy.sh.

Stanje vaše aplikacije lahko preverite z docker ps- ustvarjenih bo 5 slik, ki se začnejo z webapp. Zdaj se http://0.0.0.0:3000/v brskalniku pomaknite na , in znova boste videli sporočilo »Pozdravljeni, Vultr :)«.

Torej, kakšna je razlika v tem?

Če zaženete preskus primerjalnih vrednosti s konfiguracijo izravnalnika obremenitve, bi opazili, da se uporablja več virov vašega strežnika, kar bi želeli, še posebej, če je vaša aplikacija zgrajena v jezikih, kot je Node, kjer bi bila običajno enonitna. Če boste morali kdaj nadgraditi svojo aplikacijo, lahko to storite in znova zaženete, deploy.shda znova zgradite sliko in razmestite svoje vsebnike.


Tukaj je opisano, kako preveriti vsebnike Hyper-V v sistemu Windows 10 Insider

Tukaj je opisano, kako preveriti vsebnike Hyper-V v sistemu Windows 10 Insider

Microsoft je v novi objavi v spletnem dnevniku pojasnil, kako lahko Windows Insiders testirajo vsebnike Hyper-V v sistemu Windows 10, novi virtualizacijski rešitvi, ki omogoča izvajanje aplikacij, ne da bi to vplivalo na preostali del vašega operacijskega sistema.

Kako namestiti Harbor na CentOS 7

Kako namestiti Harbor na CentOS 7

Harbor je odprtokodni registrski strežnik poslovnega razreda, ki shranjuje in distribuira slike Docker. Harbor razširi odprtokodno Docker Distribution b

Namestite Rancher OS prek iPXE

Namestite Rancher OS prek iPXE

Rancher OS je zelo lahka distribucija Linuxa, zgrajena okoli Dockerja. Sam OS tehta približno 20 MB. Ta vadnica vas bo pripravila na začetek

V CoreOS nastavite svoj lasten register Docker

V CoreOS nastavite svoj lasten register Docker

Vsi poznamo in imamo radi Docker, platformo za ustvarjanje, upravljanje in distribucijo aplikacijskih vsebnikov na več računalnikih. Docker Inc. ponuja storitev t

Namestitev docker-compose na CoreOS

Namestitev docker-compose na CoreOS

Ta članek pojasnjuje, kako namestiti docker-compose v CoreOS. V CoreOS-u je mapa /usr/ nespremenljiva, zato standardna pot /usr/local/bin ni na voljo za

Namesti Rancher na CentOS 7

Namesti Rancher na CentOS 7

Uporaba drugega sistema? Uvod Rancher je odprtokodna platforma za vodenje kontejnerjev in izgradnjo zasebne storitve kontejnerja. Rancher je osnova

Namestite Docker CE na Ubuntu 18.04

Namestite Docker CE na Ubuntu 18.04

Uvod Docker je aplikacija, ki nam omogoča uvajanje programov, ki se izvajajo kot vsebniki. Napisana je bila v priljubljenem programskem jeziku Go

Ustvarite Docker Swarm na Alpine Linux 3.9.0

Ustvarite Docker Swarm na Alpine Linux 3.9.0

Uvod Ta priročnik vam bo pokazal, kako ustvariti in konfigurirati Docker roj z uporabo več strežnikov Alpine Linux 3.9.0 in Portainerja. Prosimo, da se zavedate, da

Namestite aplikacijo PHP z uporabo Docker-compose

Namestite aplikacijo PHP z uporabo Docker-compose

PHP aplikacije običajno sestavljajo spletni strežnik, sistem relacijske baze podatkov in sam tolmač jezika. V tej vadnici bomo vzvod

Uravnoteženost obremenitve z Dockerjem

Uravnoteženost obremenitve z Dockerjem

Ko zaženete spletno aplikacijo, običajno želite kar najbolje izkoristiti svoje vire, ne da bi morali svojo programsko opremo pretvoriti v uporabo večnitnega o

Namestite aplikacijo Node.js z uporabo Dockerja

Namestite aplikacijo Node.js z uporabo Dockerja

Ta članek vam bo pokazal, kako namestiti aplikacijo Node v vsebniku Docker. Opomba: Ta vadnica predpostavlja, da imate nameščen in prebran Docker

Namestitev Docker CE na CentOS 7

Namestitev Docker CE na CentOS 7

Tehnologija vsebnika Docker vam omogoča zagon aplikacij v določenem in izoliranem okolju. Docker Community Edition (CE) je novo ime za fre

Namestite Kubernetes s Kubeadmom na CentOS 7

Namestite Kubernetes s Kubeadmom na CentOS 7

Pregled Namen tega članka je pomagati, da gručo Kubernetes zaženete in zaženete s kubeadmom. Ta vodnik bo namestil dva strežnika na

Namestitev Dockerja na CentOS 7

Namestitev Dockerja na CentOS 7

Uporaba drugega sistema? Docker je aplikacija, ki omogoča namestitev programske opreme znotraj virtualnih vsebnikov. Napisano je v programu Go

Namestitev Docker CE v Debian 9

Namestitev Docker CE v Debian 9

Uporaba drugega sistema? Uvod Docker je aplikacija, ki omogoča namestitev programske opreme znotraj virtualnih vsebnikov. Zapisano je bilo v G

Začnite uporabljati SQL Server 2017 (MS-SQL) na CentOS 7 z Dockerjem

Začnite uporabljati SQL Server 2017 (MS-SQL) na CentOS 7 z Dockerjem

Predpogoji Docker engine 1.8+. Najmanj 4 GB prostora na disku. Najmanj 4 GB RAM-a. 1. korak. Namestite Docker Za namestitev SQL-Serverja je potrebno Docker

Sticky Session with Docker Swarm (CE) na Debianu 9

Sticky Session with Docker Swarm (CE) na Debianu 9

Uporaba drugega sistema? Uvod Docker Swarm spremeni vaše posamezne strežnike v gručo računalnikov; olajšanje skaliranja, visoka razpoložljivost an

Dve Dockerjevi grafični orodji za upravljanje: DockerUI in ladjedelnica

Dve Dockerjevi grafični orodji za upravljanje: DockerUI in ladjedelnica

S pomočjo aplikacije Vultr Docker lahko preprosto namestite Docker na vaš primerek strežnika Vultr. Medtem lahko olajšate nalogo upravljanja Dockerja

Namesti Rancher Server na RancherOS

Namesti Rancher Server na RancherOS

Pregled RancherOS je neverjetno lahek operacijski sistem (le približno 60 MB), ki poganja sistemski demon Docker kot PID 0 za izvajanje sistemskih storitev

Kako začeti uporabljati Kubernetes na CentOS 7

Kako začeti uporabljati Kubernetes na CentOS 7

Kubernetes je odprtokodna platforma, ki jo je razvil Google za upravljanje kontejnerskih aplikacij v gruči strežnikov. Gradi na desetletju in

Vzpon strojev: aplikacije AI v resničnem svetu

Vzpon strojev: aplikacije AI v resničnem svetu

Umetna inteligenca ni v prihodnosti, tukaj je prav v sedanjosti. V tem blogu preberite, kako so aplikacije umetne inteligence vplivale na različne sektorje.

DDOS napadi: kratek pregled

DDOS napadi: kratek pregled

Ste tudi vi žrtev DDOS napadov in ste zmedeni glede načinov preprečevanja? Preberite ta članek, če želite rešiti svoja vprašanja.

Ste se kdaj vprašali, kako hekerji zaslužijo denar?

Ste se kdaj vprašali, kako hekerji zaslužijo denar?

Morda ste že slišali, da hekerji zaslužijo veliko denarja, a ste se kdaj vprašali, kako zaslužijo takšen denar? razpravljajmo.

Revolucionarni Googlovi izumi, ki vam bodo olajšali življenje.

Revolucionarni Googlovi izumi, ki vam bodo olajšali življenje.

Ali želite videti revolucionarne izume Googla in kako so ti izumi danes spremenili življenje vsakega človeka? Nato preberite v blogu in si oglejte Googlove izume.

Friday Essential: Kaj se je zgodilo z avtomobili, ki jih poganja umetna inteligenca?

Friday Essential: Kaj se je zgodilo z avtomobili, ki jih poganja umetna inteligenca?

Koncept samovozečih avtomobilov, ki zapeljejo na ceste s pomočjo umetne inteligence, so sanje, ki jih imamo že nekaj časa. A kljub številnim obljubam jih ni nikjer. Preberite ta blog, če želite izvedeti več…

Tehnološka singularnost: oddaljena prihodnost človeške civilizacije?

Tehnološka singularnost: oddaljena prihodnost človeške civilizacije?

Ker se znanost hitro razvija in prevzame veliko naših prizadevanj, se povečuje tudi tveganje, da se podvržemo nerazložljivi singularnosti. Preberite, kaj bi za nas lahko pomenila singularnost.

Razvoj shranjevanja podatkov – Infografika

Razvoj shranjevanja podatkov – Infografika

Metode shranjevanja podatkov so se lahko razvijale od rojstva podatkov. Ta blog pokriva razvoj shranjevanja podatkov na podlagi infografike.

Funkcionalnosti slojev referenčne arhitekture velikih podatkov

Funkcionalnosti slojev referenčne arhitekture velikih podatkov

Preberite blog, če želite na najpreprostejši način spoznati različne plasti v arhitekturi velikih podatkov in njihove funkcionalnosti.

6 neverjetnih prednosti pametnih naprav za dom v našem življenju

6 neverjetnih prednosti pametnih naprav za dom v našem življenju

V tem digitalno vodenem svetu so pametne naprave za dom postale ključni del življenja. Tukaj je nekaj neverjetnih prednosti pametnih naprav za dom o tem, kako naredijo naše življenje vredno življenja in poenostavijo.

Posodobitev dodatka macOS Catalina 10.15.4 povzroča več težav kot jih rešuje

Posodobitev dodatka macOS Catalina 10.15.4 povzroča več težav kot jih rešuje

Pred kratkim je Apple izdal macOS Catalina 10.15.4 dopolnilno posodobitev za odpravo težav, vendar se zdi, da posodobitev povzroča več težav, ki vodijo do opečenja računalnikov Mac. Preberite ta članek, če želite izvedeti več