Lastbalans med Docker

Lastbalans med Docker

När du kör en webbapplikation vill du normalt få ut så mycket som möjligt av dina resurser utan att behöva konvertera din programvara till att använda multithreading eller komplexa händelseloopar. Docker erbjuder dock ett enkelt sätt för dig att lastbalansera din applikation internt för att få ut det mesta av serverresurserna. Den här artikeln kommer att visa dig hur du använder Nginx för att lastbalansera din webbapplikation med Docker på CentOS.

Steg 1: Skapa en enkel applikation

Vi kommer att använda rost för att bygga denna enkla applikation. Förutsatt att du har installerat rost, kör cargo new webapp –bin. Efter framgång kommer du att se en katalog som heter webapp. Inuti webappkommer du att se en fil som heter Cargo.toml. Lägg till följande rader till den:

[dependencies.iron]
version = "*"

Ta sedan src/main.rsbort allt inuti filen och fyll i den med följande:

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

Obs: Ändra inte IP-adressen i programmet. Detta är konfigurerat så att Docker kan lyssna på din applikation.

När du är klar kompilerar du programmet genom att köra cargo build –release. Beroende på din server kan det ta några minuter. Om det inte finns några fel, testa programmet genom att följa dessa steg:

  • Kör target/release/webapp.
  • Navigera till http://0.0.0.0:3000/i din webbläsare. Ersätt 0.0.0.0med din servers IP-adress.

Om allt fungerade korrekt kommer du att se "Hej Vultr :)" på sidan.

Steg 2: Skapa Docker-behållare

Skapa en Dockerfileoch fyll i den med följande:

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

Spara filen. Skapa sedan en fil som heter deploy.shoch fyll i den med följande:

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

När du kör det här skriptet kommer det att bygga bilden och distribuera behållaren baserat på mängden du har angett (standard är 5). Om behållaren finns kommer den att döda och ta bort den från registret innan den distribueras igen.

Steg 3: Konfigurera Nginx

Skapa nu en Nginx-konfigurationsfil och fyll i den med följande:

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

Ersätt 0.0.0.0med din servers IP-adress.

Starta om Nginx genom att göra systemctl restart nginx. Åtgärda eventuella fel och fortsätt sedan till nästa steg.

Steg 4: Implementera applikationen

Distribuera programmet genom att köra bash ./deploy.sh.

Du kan kontrollera statusen för din ansökan med docker ps- det kommer att skapas 5 bilder som börjar med webapp. Nu, navigera till http://0.0.0.0:3000/i din webbläsare, kommer du att se meddelandet "Hej, Vultr :)" igen.

Så, exakt vilken skillnad gör detta?

Om du kör ett benchmarktest mot belastningsbalanseringskonfigurationen, skulle du märka att fler av dina serverresurser används, vilket är vad du skulle vilja, speciellt om din applikation är byggd i språk som Node där den normalt skulle vara entrådad. Om du någonsin behöver uppgradera din applikation kan du göra det och köra om för deploy.shatt bygga om bilden och distribuera dina behållare.


Så här kollar du Hyper-V-behållare på Windows 10 Insider

Så här kollar du Hyper-V-behållare på Windows 10 Insider

Microsoft har i ett nytt blogginlägg förklarat hur Windows Insiders kan testa Hyper-V-behållare på Windows 10, en ny virtualiseringslösning för att tillåta applikationer att köras utan att påverka resten av ditt operativsystem.

Hur man installerar Harbor på CentOS 7

Hur man installerar Harbor på CentOS 7

Harbor är en registerserver i företagsklass med öppen källkod som lagrar och distribuerar Docker-avbildningar. Harbor utökar öppen källkod Docker Distribution b

Installera Rancher OS via iPXE

Installera Rancher OS via iPXE

Rancher OS är en mycket lätt Linux-distribution byggd kring Docker. Själva operativsystemet väger cirka 20 MB. Denna handledning kommer att få dig igång

På CoreOS, ställ in ditt eget Docker-register

På CoreOS, ställ in ditt eget Docker-register

Vi känner alla till och älskar Docker, en plattform för att skapa, hantera och distribuera applikationsbehållare över flera maskiner. Docker Inc. tillhandahåller en tjänst t

Installerar docker-compose på CoreOS

Installerar docker-compose på CoreOS

Den här artikeln förklarar hur du installerar docker-compose på CoreOS. I CoreOS är mappen /usr/ oföränderlig så standardsökvägen /usr/local/bin är inte tillgänglig för

Installera Rancher på CentOS 7

Installera Rancher på CentOS 7

Använder du ett annat system? Introduktion Rancher är en öppen källkodsplattform för att köra containrar och bygga en privat containertjänst. Rancher är basen

Installera Docker CE på Ubuntu 18.04

Installera Docker CE på Ubuntu 18.04

Introduktion Docker är en applikation som låter oss distribuera program som körs som behållare. Den skrevs på det populära programmeringsspråket Go

Skapa en Docker Swarm på Alpine Linux 3.9.0

Skapa en Docker Swarm på Alpine Linux 3.9.0

Inledning Den här guiden visar hur du skapar och konfigurerar en Docker-svärm med flera Alpine Linux 3.9.0-servrar och Portainer. Var medveten om att

Distribuera en PHP-applikation med Docker-compose

Distribuera en PHP-applikation med Docker-compose

PHP-applikationer är vanligtvis sammansatta av en webbserver, ett relationsdatabassystem och själva språktolken. I den här handledningen kommer vi att vara hävstångsmässigt

Lastbalans med Docker

Lastbalans med Docker

När du kör en webbapplikation vill du normalt få ut det mesta av dina resurser utan att behöva konvertera din programvara till att använda multithreading o

Distribuera en Node.js-applikation med Docker

Distribuera en Node.js-applikation med Docker

Den här artikeln visar dig hur du distribuerar din Node-applikation i en Docker-behållare. Obs: Denna handledning förutsätter att du har Docker installerat och läst

Installerar Docker CE på CentOS 7

Installerar Docker CE på CentOS 7

Docker containerteknik låter dig köra applikationer i en specifik och isolerad miljö. Docker Community Edition (CE) är det nya namnet på fre

Distribuera Kubernetes med Kubeadm på CentOS 7

Distribuera Kubernetes med Kubeadm på CentOS 7

Översikt Den här artikeln är tänkt att hjälpa dig få igång ett Kubernetes-kluster med kubeadm på nolltid. Den här guiden kommer att distribuera två servrar, på

Installera Docker på CentOS 7

Installera Docker på CentOS 7

Använder du ett annat system? Docker är en applikation som möjliggör distribution av programvara i virtuella behållare. Det skrevs i Go-programmet

Installerar Docker CE på Debian 9

Installerar Docker CE på Debian 9

Använder du ett annat system? Introduktion Docker är en applikation som möjliggör distribution av programvara i virtuella behållare. Det skrevs i G

Kom igång med SQL Server 2017 (MS-SQL) på CentOS 7 med Docker

Kom igång med SQL Server 2017 (MS-SQL) på CentOS 7 med Docker

Förutsättningar Docker-motor 1.8+. Minst 4 GB diskutrymme. Minst 4 GB RAM. Steg 1. Installera Docker För att installera SQL-Server måste Docker mus

Sticky Session With Docker Swarm (CE) på Debian 9

Sticky Session With Docker Swarm (CE) på Debian 9

Använder du ett annat system? Inledning Docker Swarm förvandlar dina individuella servrar till ett kluster av datorer; underlättar skalning, hög tillgänglighet och

Två Docker grafiska hanteringsverktyg: DockerUI och Shipyard

Två Docker grafiska hanteringsverktyg: DockerUI och Shipyard

Med hjälp av Vultr Docker-applikationen kan du enkelt distribuera Docker på din Vultr-serverinstans. Under tiden kan du underlätta Docker-hanteringsuppgiften

Installera Rancher Server på RancherOS

Installera Rancher Server på RancherOS

Översikt RancherOS är ett otroligt lätt operativsystem (endast cirka 60 MB) som kör en system Docker-demon som PID 0 för att köra systemtjänster

Komma igång med Kubernetes på CentOS 7

Komma igång med Kubernetes på CentOS 7

Kubernetes är en öppen källkodsplattform som utvecklats av Google för att hantera containeriserade applikationer över ett kluster av servrar. Den bygger på ett decennium och

The Rise of Machines: Real World Applications of AI

The Rise of Machines: Real World Applications of AI

Artificiell intelligens är inte i framtiden, det är här i nuet I den här bloggen Läs hur Artificiell intelligens-applikationer har påverkat olika sektorer.

DDOS-attacker: En kort översikt

DDOS-attacker: En kort översikt

Är du också ett offer för DDOS-attacker och förvirrad över de förebyggande metoderna? Läs den här artikeln för att lösa dina frågor.

Har du någonsin undrat hur hackare tjänar pengar?

Har du någonsin undrat hur hackare tjänar pengar?

Du kanske har hört att hackare tjänar mycket pengar, men har du någonsin undrat hur de tjänar den typen av pengar? låt oss diskutera.

Revolutionerande uppfinningar från Google som gör ditt liv lätt.

Revolutionerande uppfinningar från Google som gör ditt liv lätt.

Vill du se revolutionerande uppfinningar av Google och hur dessa uppfinningar förändrade livet för varje människa idag? Läs sedan till bloggen för att se uppfinningar av Google.

Fredag ​​Essential: Vad hände med AI-drivna bilar?

Fredag ​​Essential: Vad hände med AI-drivna bilar?

Konceptet med att självkörande bilar ska ut på vägarna med hjälp av artificiell intelligens är en dröm vi har ett tag nu. Men trots flera löften finns de ingenstans att se. Läs den här bloggen för att lära dig mer...

Technological Singularity: A Distant Future of Human Civilization?

Technological Singularity: A Distant Future of Human Civilization?

När vetenskapen utvecklas i snabb takt och tar över en hel del av våra ansträngningar, ökar också riskerna för att utsätta oss för en oförklarlig singularitet. Läs, vad singularitet kan betyda för oss.

Utveckling av datalagring – Infographic

Utveckling av datalagring – Infographic

Lagringsmetoderna för data har utvecklats kan vara sedan födelsen av data. Den här bloggen tar upp utvecklingen av datalagring på basis av en infografik.

Funktioner för Big Data Reference Architecture Layers

Funktioner för Big Data Reference Architecture Layers

Läs bloggen för att känna till olika lager i Big Data Architecture och deras funktionaliteter på enklaste sätt.

6 fantastiska fördelar med att ha smarta hemenheter i våra liv

6 fantastiska fördelar med att ha smarta hemenheter i våra liv

I denna digitala värld har smarta hemenheter blivit en avgörande del av livet. Här är några fantastiska fördelar med smarta hemenheter om hur de gör vårt liv värt att leva och enklare.

macOS Catalina 10.15.4 tilläggsuppdatering orsakar fler problem än att lösa

macOS Catalina 10.15.4 tilläggsuppdatering orsakar fler problem än att lösa

Nyligen släppte Apple macOS Catalina 10.15.4, en tilläggsuppdatering för att åtgärda problem, men det verkar som om uppdateringen orsakar fler problem som leder till att mac-datorer blir murade. Läs den här artikeln för att lära dig mer