Bilans obciążenia z dokerem

Podczas uruchamiania aplikacji sieciowej zwykle chcesz jak najlepiej wykorzystać swoje zasoby bez konieczności konwertowania oprogramowania do korzystania z wielowątkowości lub złożonych pętli zdarzeń. Docker zapewnia jednak prosty sposób wewnętrznego równoważenia obciążenia aplikacji, aby maksymalnie wykorzystać zasoby serwera. W tym artykule dowiesz się, jak używać Nginx do równoważenia obciążenia aplikacji internetowej za pomocą Dockera na CentOS.

Krok 1: Utwórz prostą aplikację

Będziemy używać rdzy do zbudowania tej prostej aplikacji. Zakładając, że masz zainstalowaną rdzę, uruchom cargo new webapp –bin. Po sukcesie zobaczysz katalog o nazwie webapp. Wewnątrz webappzobaczysz plik o nazwie Cargo.toml. Dodaj do niego następujące linie:

[dependencies.iron]
version = "*"

Następnie w src/main.rspliku usuń wszystko i wypełnij go:

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

Uwaga: Nie zmieniaj adresu IP w aplikacji. Jest to skonfigurowane tak, aby Docker mógł nasłuchiwać twojej aplikacji.

Po zakończeniu skompiluj aplikację, wykonując cargo build –release. W zależności od serwera może to potrwać kilka minut. Jeśli nie ma błędów, przetestuj aplikację, wykonując następujące kroki:

  • Uruchom target/release/webapp.
  • Przejdź do http://0.0.0.0:3000/w przeglądarce. Zastąp 0.0.0.0adres IP swojego serwera.

Jeśli wszystko działało poprawnie, na stronie pojawi się „Hello Vultr :)”.

Krok 2: Utwórz kontenery Docker

Utwórz a Dockerfilei wypełnij go:

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

Zapisz plik. Następnie utwórz plik o nazwie deploy.shi wypełnij go:

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

Po uruchomieniu tego skryptu zbuduje obraz i wdroży kontener na podstawie ustawionej kwoty (domyślnie jest to 5). Jeśli kontener istnieje, zabije go i usunie z rejestru przed jego ponownym wdrożeniem.

Krok 3: Skonfiguruj Nginx

Teraz utwórz plik konfiguracyjny Nginx i wypełnij go:

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

Zastąp 0.0.0.0adres IP swojego serwera.

Uruchom ponownie Nginx, wykonując systemctl restart nginx. Rozwiąż wszelkie błędy, a następnie przejdź do następnego kroku.

Krok 4: Wdróż aplikację

Wdróż aplikację, uruchamiając bash ./deploy.sh.

Możesz sprawdzić status swojej aplikacji za pomocą docker ps- powstanie 5 obrazów, które zaczynają się od webapp. Teraz przejdź do http://0.0.0.0:3000/przeglądarki, ponownie zobaczysz komunikat „Witaj, Vultr :)”.

Jaka to dokładnie różnica?

Jeśli uruchomisz test porównawczy z konfiguracją modułu równoważenia obciążenia, zauważysz, że zużywasz więcej zasobów serwera, co jest pożądane, zwłaszcza jeśli aplikacja jest zbudowana w językach takich jak Węzeł, gdzie normalnie byłaby to jednowątkowa. Jeśli kiedykolwiek będziesz musiał zaktualizować aplikację, możesz to zrobić i uruchomić ponownie, deploy.shaby odbudować obraz i wdrożyć kontenery.

Zostaw komentarz

Funkcjonalności warstw architektury referencyjnej Big Data

Funkcjonalności warstw architektury referencyjnej Big Data

Przeczytaj blog, aby w najprostszy sposób poznać różne warstwy w architekturze Big Data i ich funkcjonalności.

Rewolucyjne wynalazki Google, które ułatwią Twoje życie.

Rewolucyjne wynalazki Google, które ułatwią Twoje życie.

Chcesz zobaczyć rewolucyjne wynalazki Google i jak te wynalazki zmieniły życie każdego człowieka dzisiaj? Następnie czytaj na blogu, aby zobaczyć wynalazki Google.

13 komercyjnych narzędzi do ekstrakcji danych z Big Data

13 komercyjnych narzędzi do ekstrakcji danych z Big Data

13 komercyjnych narzędzi do ekstrakcji danych z Big Data

Pozostań w kontakcie dzięki aplikacji WhatsApp na komputer 24*7

Pozostań w kontakcie dzięki aplikacji WhatsApp na komputer 24*7

Whatsapp w końcu uruchomił aplikację Desktop dla użytkowników komputerów Mac i Windows. Teraz możesz łatwo uzyskać dostęp do Whatsapp z systemu Windows lub Mac. Dostępne dla Windows 8+ i Mac OS 10.9+

5 przykładów, które dowodzą, że energetyka jądrowa nie zawsze jest zła

5 przykładów, które dowodzą, że energetyka jądrowa nie zawsze jest zła

Energia jądrowa jest zawsze pogardzana, nigdy jej nie szanujemy z powodu przeszłych wydarzeń, ale nie zawsze jest zła. Przeczytaj post, aby dowiedzieć się więcej na ten temat.

Friday Essential: Co się stało z samochodami sterowanymi przez sztuczną inteligencję?

Friday Essential: Co się stało z samochodami sterowanymi przez sztuczną inteligencję?

Koncepcja autonomicznych samochodów, które wyjadą na drogi za pomocą sztucznej inteligencji, to marzenie, które mamy już od jakiegoś czasu. Ale pomimo kilku obietnic nigdzie ich nie widać. Przeczytaj ten blog, aby dowiedzieć się więcej…

5 przydatnych narzędzi sztucznej inteligencji, które uproszczą Twoje życie

5 przydatnych narzędzi sztucznej inteligencji, które uproszczą Twoje życie

Sztuczna inteligencja nie jest dla ludzi nową nazwą. Ponieważ sztuczna inteligencja jest włączona do każdego strumienia, jednym z nich jest opracowywanie narzędzi zwiększających ludzką wydajność i dokładność. Skorzystaj z tych niesamowitych narzędzi uczenia maszynowego i uprość swoje codzienne zadania.

Czy AI może walczyć z rosnącą liczbą ataków ransomware?

Czy AI może walczyć z rosnącą liczbą ataków ransomware?

Wzrasta liczba ataków ransomware, ale czy sztuczna inteligencja może pomóc w radzeniu sobie z najnowszym wirusem komputerowym? Czy AI jest odpowiedzią? Przeczytaj tutaj, wiedz, że sztuczna inteligencja jest zmorą lub zgubą

Wgląd w 26 technik analizy Big Data: część 2

Wgląd w 26 technik analizy Big Data: część 2

Zawsze potrzebujemy Big Data Analytics do efektywnego zarządzania danymi. W tym artykule omówiliśmy kilka technik analizy Big Data. Sprawdź ten artykuł.

Ataki DDOS: krótki przegląd

Ataki DDOS: krótki przegląd

Czy jesteś również ofiarą ataków DDOS i nie masz pewności co do metod zapobiegania? Przeczytaj ten artykuł, aby rozwiązać swoje pytania.