Lastausgleich mit Docker

Wenn Sie eine Webanwendung ausführen, möchten Sie normalerweise Ihre Ressourcen optimal nutzen, ohne Ihre Software für die Verwendung von Multithreading oder komplexen Ereignisschleifen konvertieren zu müssen. Docker bietet jedoch eine einfache Möglichkeit, den Lastenausgleich Ihrer Anwendung intern durchzuführen, um die Serverressourcen optimal zu nutzen. Dieser Artikel zeigt Ihnen, wie Sie Nginx verwenden, um Ihre Webanwendung mithilfe von Docker unter CentOS auszugleichen.

Schritt 1: Erstellen Sie eine einfache Anwendung

Wir werden Rost verwenden, um diese einfache Anwendung zu erstellen. Angenommen, Sie haben Rost installiert, laufen Sie cargo new webapp –bin. Nach Erfolg wird ein Verzeichnis mit dem Namen angezeigt webapp. Innerhalb von sehen webappSie eine Datei namens Cargo.toml. Fügen Sie die folgenden Zeilen hinzu:

[dependencies.iron]
version = "*"

src/main.rsEntfernen Sie als Nächstes in der Datei alles und füllen Sie es wie folgt aus:

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

Hinweis: Ändern Sie die IP-Adresse in der Anwendung nicht. Dies ist so konfiguriert, dass Docker Ihre Anwendung abhören kann.

Wenn Sie fertig sind, kompilieren Sie die Anwendung durch Ausführen cargo build –release. Abhängig von Ihrem Server kann dies einige Minuten dauern. Wenn keine Fehler vorliegen, testen Sie die Anwendung wie folgt:

  • Ausführen target/release/webapp.
  • Navigieren Sie http://0.0.0.0:3000/in Ihrem Browser zu. Ersetzen Sie 0.0.0.0durch die IP-Adresse Ihres Servers.

Wenn alles richtig funktioniert hat, sehen Sie "Hallo Vultr :)" auf der Seite.

Schritt 2: Erstellen Sie Docker-Container

Erstellen Sie ein Dockerfileund füllen Sie es mit Folgendem:

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

Speicher die Datei. Erstellen Sie dann eine Datei mit dem Namen deploy.shund füllen Sie sie mit Folgendem:

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

Wenn Sie dieses Skript ausführen, wird das Image erstellt und der Container basierend auf dem von Ihnen festgelegten Betrag bereitgestellt (Standard ist 5). Wenn der Container vorhanden ist, wird er beendet und aus der Registrierung entfernt, bevor er erneut bereitgestellt wird.

Schritt 3: Konfigurieren Sie Nginx

Erstellen Sie nun eine Nginx-Konfigurationsdatei und füllen Sie sie mit Folgendem:

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

Ersetzen Sie 0.0.0.0durch die IP-Adresse Ihres Servers.

Starten Sie Nginx neu systemctl restart nginx. Beheben Sie alle Fehler und fahren Sie mit dem nächsten Schritt fort.

Schritt 4: Anwendung bereitstellen

Stellen Sie die Anwendung durch Ausführen bereit bash ./deploy.sh.

Sie können den Status Ihrer Anwendung mit überprüfen docker ps- es werden 5 Bilder erstellt, die mit beginnen webapp. Navigieren Sie nun http://0.0.0.0:3000/in Ihrem Browser zu, und Sie sehen erneut die Meldung "Hallo, Vultr :)".

Welchen Unterschied macht das genau?

Wenn Sie einen Benchmark-Test für die Load-Balancer-Konfiguration durchführen, werden Sie feststellen, dass mehr Serverressourcen verwendet werden. Dies ist genau das, was Sie möchten, insbesondere wenn Ihre Anwendung in Sprachen wie Node erstellt wird, in denen es sich normalerweise um Single-Threaded handelt. Wenn Sie Ihre Anwendung jemals aktualisieren müssen, können Sie dies tun und erneut ausführen deploy.sh, um das Image neu zu erstellen und Ihre Container bereitzustellen.



Leave a Comment

Installieren von Docker unter Ubuntu 14.04

Installieren von Docker unter Ubuntu 14.04

Verwenden Sie ein anderes System? Docker ist eine Anwendung, mit der Programme bereitgestellt werden können, die als Container ausgeführt werden. Es wurde im beliebten Go-Programm geschrieben

Stellen Sie eine PHP-Anwendung mit Docker-compose bereit

Stellen Sie eine PHP-Anwendung mit Docker-compose bereit

PHP-Anwendungen bestehen normalerweise aus einem Webserver, einem relationalen Datenbanksystem und dem Sprachinterpreter selbst. In diesem Tutorial werden wir Hebel einsetzen

Installieren Sie Rancher Server unter RancherOS

Installieren Sie Rancher Server unter RancherOS

Übersicht RancherOS ist ein unglaublich leichtes Betriebssystem (nur ca. 60 MB), auf dem ein System-Docker-Daemon als PID 0 zum Ausführen von Systemdiensten ausgeführt wird

Sticky Session mit Docker Swarm (CE) auf Debian 9

Sticky Session mit Docker Swarm (CE) auf Debian 9

Verwenden Sie ein anderes System? Einführung Docker Swarm verwandelt Ihre einzelnen Server in einen Computercluster. Erleichterung der Skalierung, Hochverfügbarkeit an

Verwendung von Docker: Erstellen Ihres ersten Docker-Containers

Verwendung von Docker: Erstellen Ihres ersten Docker-Containers

In diesem Tutorial werden die Grundlagen für den Einstieg in Docker erläutert. Ich gehe davon aus, dass Sie Docker bereits installiert haben. Die Schritte in diesem Tutorial funktionieren an einem

Richten Sie unter CoreOS Ihre eigene Docker-Registrierung ein

Richten Sie unter CoreOS Ihre eigene Docker-Registrierung ein

Wir alle kennen und lieben Docker, eine Plattform zum Erstellen, Verwalten und Verteilen von Anwendungscontainern auf mehreren Computern. Docker Inc. bietet einen Service t

Stellen Sie eine Node.js-Anwendung mit Docker bereit

Stellen Sie eine Node.js-Anwendung mit Docker bereit

Dieser Artikel zeigt Ihnen, wie Sie Ihre Knotenanwendung in einem Docker-Container bereitstellen. Hinweis: In diesem Lernprogramm wird davon ausgegangen, dass Docker installiert und gelesen ist

Installieren von Docker unter CentOS 7

Installieren von Docker unter CentOS 7

Verwenden Sie ein anderes System? Docker ist eine Anwendung, die die Bereitstellung von Software in virtuellen Containern ermöglicht. Es wurde im Go-Programm geschrieben

Installieren Sie Rancher OS über iPXE

Installieren Sie Rancher OS über iPXE

Rancher OS ist eine sehr leichte Linux-Distribution, die auf Docker basiert. Das Betriebssystem selbst wiegt etwa 20 MB. Mit diesem Tutorial können Sie loslegen

Richten Sie Sentry über Docker unter Ubuntu 16.04 ein

Richten Sie Sentry über Docker unter Ubuntu 16.04 ein

Verwenden Sie ein anderes System? Einführung Sentry ist eine Open Source-Lösung für die Fehlerverfolgung. Sentry verfolgt Ausnahmen und andere nützliche Nachrichten

Stellen Sie Kubernetes mit Kubeadm unter CentOS 7 bereit

Stellen Sie Kubernetes mit Kubeadm unter CentOS 7 bereit

Übersicht Dieser Artikel soll Ihnen helfen, einen Kubernetes-Cluster in kürzester Zeit mit kubeadm zum Laufen zu bringen. In diesem Handbuch werden zwei Server bereitgestellt

Docker-Compose unter CoreOS installieren

Docker-Compose unter CoreOS installieren

Dieser Artikel erklärt, wie Docker-Compose unter CoreOS installiert wird. In CoreOS ist der Ordner / usr / unveränderlich, sodass der Standardpfad / usr / local / bin für nicht verfügbar ist

So installieren Sie Harbor unter CentOS 7

So installieren Sie Harbor unter CentOS 7

Harbor ist ein Open-Source-Registrierungsserver der Enterprise-Klasse, auf dem Docker-Images gespeichert und verteilt werden. Harbour erweitert die Open Source Docker Distribution b

Installieren Sie Docker CE unter Ubuntu 18.04

Installieren Sie Docker CE unter Ubuntu 18.04

Einführung Docker ist eine Anwendung, mit der wir Programme bereitstellen können, die als Container ausgeführt werden. Es wurde in der beliebten Programmiersprache Go geschrieben

Erste Schritte mit Kubernetes unter CentOS 7

Erste Schritte mit Kubernetes unter CentOS 7

Kubernetes ist eine Open-Source-Plattform, die von Google für die Verwaltung von Containeranwendungen auf einem Servercluster entwickelt wurde. Es baut auf einem Jahrzehnt auf und

Erste Schritte mit SQL Server 2017 (MS-SQL) unter CentOS 7 mit Docker

Erste Schritte mit SQL Server 2017 (MS-SQL) unter CentOS 7 mit Docker

Voraussetzungen Docker Engine 1.8+. Mindestens 4 GB Speicherplatz. Mindestens 4 GB RAM. Schritt 1. Docker installieren Um SQL-Server zu installieren, muss Docker mus

LXC-Container unter Ubuntu 14.04 sicher bereitstellen und verwalten

LXC-Container unter Ubuntu 14.04 sicher bereitstellen und verwalten

LXC-Container (Linux-Container) sind eine Betriebssystemfunktion unter Linux, mit der mehrere isolierte Linux-Systeme auf einem einzigen Host ausgeführt werden können. Thes

Installieren Sie Rancher unter Ubuntu 16.04

Installieren Sie Rancher unter Ubuntu 16.04

Verwenden Sie ein anderes System? Einführung Rancher ist eine Open Source-Plattform zum Ausführen von Containern und zum Erstellen eines privaten Containerservices. Rancher ist Basis

Erstellen Sie einen Docker Swarm unter Alpine Linux 3.9.0

Erstellen Sie einen Docker Swarm unter Alpine Linux 3.9.0

Einführung In diesem Handbuch erfahren Sie, wie Sie einen Docker-Schwarm mit mehreren Alpine Linux 3.9.0-Servern und Portainer erstellen und konfigurieren. Bitte beachten Sie, dass

Kann KI mit zunehmender Anzahl von Ransomware-Angriffen kämpfen?

Kann KI mit zunehmender Anzahl von Ransomware-Angriffen kämpfen?

Ransomware-Angriffe nehmen zu, aber kann KI helfen, den neuesten Computervirus zu bekämpfen? Ist KI die Antwort? Lesen Sie hier, ob KI boone oder bane ist

ReactOS: Ist das die Zukunft von Windows?

ReactOS: Ist das die Zukunft von Windows?

ReactOS, ein quelloffenes und kostenloses Betriebssystem, ist hier mit der neuesten Version. Kann es den Anforderungen moderner Windows-Benutzer genügen und Microsoft zu Fall bringen? Lassen Sie uns mehr über dieses alte, aber neuere Betriebssystem erfahren.

Bleiben Sie in Verbindung über die WhatsApp Desktop App 24*7

Bleiben Sie in Verbindung über die WhatsApp Desktop App 24*7

Whatsapp hat endlich die Desktop-App für Mac- und Windows-Benutzer auf den Markt gebracht. Jetzt können Sie ganz einfach von Windows oder Mac auf WhatsApp zugreifen. Verfügbar für Windows 8+ und Mac OS 10.9+

Wie kann KI die Prozessautomatisierung auf die nächste Stufe heben?

Wie kann KI die Prozessautomatisierung auf die nächste Stufe heben?

Lesen Sie dies, um zu erfahren, wie Künstliche Intelligenz bei kleinen Unternehmen beliebt wird und wie sie die Wahrscheinlichkeit erhöht, sie wachsen zu lassen und ihren Konkurrenten einen Vorsprung zu verschaffen.

macOS Catalina 10.15.4 Supplement Update verursacht mehr Probleme als sie zu lösen

macOS Catalina 10.15.4 Supplement Update verursacht mehr Probleme als sie zu lösen

Vor kurzem hat Apple macOS Catalina 10.15.4 als Ergänzungsupdate veröffentlicht, um Probleme zu beheben, aber es scheint, dass das Update mehr Probleme verursacht, die zum Bricking von Mac-Computern führen. Lesen Sie diesen Artikel, um mehr zu erfahren

13 Tools zur kommerziellen Datenextraktion von Big Data

13 Tools zur kommerziellen Datenextraktion von Big Data

13 Tools zur kommerziellen Datenextraktion von Big Data

Was ist ein Journaling-Dateisystem und wie funktioniert es?

Was ist ein Journaling-Dateisystem und wie funktioniert es?

Unser Computer speichert alle Daten in einer organisierten Weise, die als Journaling-Dateisystem bekannt ist. Es ist eine effiziente Methode, die es dem Computer ermöglicht, Dateien zu suchen und anzuzeigen, sobald Sie auf die Suche klicken.https://wethegeek.com/?p=94116&preview=true

Technologische Singularität: Eine ferne Zukunft der menschlichen Zivilisation?

Technologische Singularität: Eine ferne Zukunft der menschlichen Zivilisation?

Da sich die Wissenschaft schnell weiterentwickelt und einen Großteil unserer Bemühungen übernimmt, steigt auch das Risiko, uns einer unerklärlichen Singularität auszusetzen. Lesen Sie, was Singularität für uns bedeuten könnte.

Ein Einblick in 26 Big-Data-Analysetechniken: Teil 1

Ein Einblick in 26 Big-Data-Analysetechniken: Teil 1

Ein Einblick in 26 Big-Data-Analysetechniken: Teil 1

Der Einfluss künstlicher Intelligenz im Gesundheitswesen 2021

Der Einfluss künstlicher Intelligenz im Gesundheitswesen 2021

KI im Gesundheitswesen hat in den letzten Jahrzehnten große Fortschritte gemacht. Somit wächst die Zukunft der KI im Gesundheitswesen immer noch von Tag zu Tag.