HintergrundIn Docker werden vier Container mit demselben Image erstellt. Das Netzwerk befindet sich im Bridge-Modus. Dienst A verwendet in allen vier Containern dieselbe Portnummer (6000). Um die Anzahl der nach außen zugänglichen Ports zu reduzieren, wird nginx als Proxy für die vier Dienstinstanzen verwendet. Die vier Dienstinstanzen gehören zu vier Upstreams, und für den Zugriff auf die vier Instanzen werden Pfade wie /service1 und /service2 verwendet. Wenn Sie zu diesem Zeitpunkt lokal auf einen Dienst zugreifen, wird ein rätselhafter 502-Fehler gemeldet.
Datei erstellen Version: '2' Netzwerke: nn: Treiber: Brücke Leistungen: Dienst-1: Containername: Dienst-1 Bild: foo Netzwerke: -nn Bände: - ./logs/1:/apps/aaa/bbb-logs - ./common:/apps/aaa/bbb - ./xxx/1.xml:/ccc/targets.xml Einstiegspunkt: foo.sh Befehl: starte App=foo Port=6000 Dienst-2: Containername: Service-2 Bild: foo Netzwerke: -nn Bände: - ./logs/2:/apps/aaa/bbb-logs - ./common:/apps/aaa/bbb - ./xxx/2.xml:/ccc/targets.xml Einstiegspunkt: foo.sh Befehl: starte App=foo Port=6000 Dienst-3: Containername: Service-3 Bild: foo Netzwerke: -nn Bände: - ./logs/3:/apps/aaa/bbb-logs - ./common:/apps/aaa/bbb - ./xxx/3.xml:/ccc/targets.xml Einstiegspunkt: foo.sh Befehl: starte App=foo Port=6000 Dienst-4: Containername: Service-4 Bild: foo Netzwerke: -nn Bände: - ./logs/4:/apps/aaa/bbb-logs - ./common:/apps/aaa/bbb - ./xxx/4.xml:/ccc/targets.xml Einstiegspunkt: foo.sh Befehl: starte App=foo Port=6000 nginx: Containername: nginx Bild: nginx:1.15-alpine Häfen: 6001:6001 Netzwerke: -nn Bände: - ./nginx/nginx.conf:/etc/nginx/nginx.conf - ./logs/nginx:/var/log/nginx nginx.conf Arbeitsprozesse 8; worker_rlimit_nofile 65535; Ereignisse { verwenden Sie epoll; Arbeiterverbindungen 65535; } http { mime.types einschließen; Standardtyp Anwendung/Oktett-Stream; sendfile an; log_format main '[$time_local]$remote_addr-$upstream_addr "$request" $status $body_bytes_sent'; Upstream service1.local { Serverdienst-1:6000; } Upstream service2.local { Serverdienst-2:6000; } Upstream service3.local { Serverdienst-3:6000; } Upstream service4.local { Serverdienst-4:6000; } Server { hören Sie 6001; Maximale Client-Body-Größe: 100 M; Proxy_set_header Host $host:$server_port; Proxy_Set_Header X-Real-IP $Remote_Addr; proxy_set_header X-Weitergeleitet-Für $proxy_add_x_forwarded_for; Standort /service1/ { Proxy-Passwort http://service1.local/; } Standort /service2/ { Proxy-Passwort http://service2.local/; } Standort /service3/ { Proxy-Passwort http://service3.local/; } Standort /service4/ { Proxy-Passwort http://service4.local/; } Standort /nginx_status { stub_status ein; Zugriff_Abmeldung; } } } Zu diesem Zeitpunkt meldet curl localhost:6001/service1/api/v1/.... den oben genannten Fehler 502. Es liegt auf der Hand, dass jeder Container seine eigene Netzwerkkarte hat und die Portnummern verschiedener Container nicht in Konflikt geraten sollten. LösungDa es derzeit keine bessere Lösung gibt, können wir nur unterschiedliche Portnummern für die vier Dienste verwenden und nginx entsprechend ändern. Ergänzung: Mehrere Docker-Container auf demselben Server bereitstellen, Problem mit der Portumleitung Stellen Sie in der Produktionsumgebung mehrere Container bereit und greifen Sie auf mehrere Ports zu. Beispiel: -p 80:80 -p 81:81 Wenn Adresse 81 existiert, greifen Sie direkt auf die Adresse von Port 80 zu. Missverständnis: Ich dachte zunächst, es handele sich um ein Cookie-Problem, weil ich das Cookie aktualisiert hatte (Cookies unterscheiden nicht zwischen Portnummern). Endlich den Grund gefunden: Umleitungsproblem, da die Abmeldung auf die Anmeldeseite umleitet Lösung: Konfigurieren Sie die Nginx-Parameter
Denn egal was passiert, der Anforderungsparameter enthält die Portnummer. Es gibt eine andere Methode im Internet: Ändern Sie den Proxy_Redirect-Parameter (aber nach dem Ausprobieren hat es nicht funktioniert). Das Obige ist meine persönliche Erfahrung. Ich hoffe, es kann Ihnen als Referenz dienen. Ich hoffe auch, dass Sie 123WORDPRESS.COM unterstützen werden. Sollten dennoch Fehler oder unvollständige Überlegungen vorliegen, freue ich mich über eine Korrektur. Das könnte Sie auch interessieren:
|
<<: Detaillierte Analyse des MySQL 8.0-Redo-Logs
Inhaltsverzeichnis 1. Nachfragehintergrund 2. Opt...
Vorwort Bezüglich der HugePages- und Oracle-Daten...
MySQL-Replikation - ausführliche Erklärung und ei...
Verwenden Sie einen JS-Timer, um ein Element zu e...
1. Absoluter Pfad Zunächst einmal bezieht sich de...
Vorwort: Vue3.0 implementiert dreidimensionales S...
Vorwort Heute erklärt Ihnen Prince die vollständi...
In der vorherigen Entwicklung haben wir die Stand...
Wenn eine Website im Breitbildformat ist, ziehen ...
1. Dokumentationsregeln 1. Groß-/Kleinschreibung b...
veranschaulichen: Stamm und Alias im Standort D...
In diesem Artikel finden Sie den spezifischen Cod...
Ich habe ein halbes Jahr lang nicht gebloggt, wofü...
1. Version verwenden vite:2.0 Ant-Design-Vue: 2.0...
MySQL-Mehrtabellenabfrage (kartesisches Produktpr...