Heim > Backend-Entwicklung > Python-Tutorial > Warum kann ich nach der Bereitstellung in Docker nicht auf meine Flask-App zugreifen?

Warum kann ich nach der Bereitstellung in Docker nicht auf meine Flask-App zugreifen?

DDD
Freigeben: 2024-12-24 07:17:16
Original
254 Leute haben es durchsucht

Why Can't I Access My Flask App After Deploying it in Docker?

Bereitstellen der Flask-App in Docker: Beheben von Serververbindungsproblemen

Beim Bereitstellen von Flask-Anwendungen in Docker können Probleme mit der Serververbindung auftreten, obwohl der Container scheinbar ausgeführt wird. In diesem Artikel wird ein häufiges Problem untersucht und eine Lösung bereitgestellt, um sicherzustellen, dass auf die Anwendung von außerhalb des Containers zugegriffen werden kann.

Problembeschreibung

Stellen Sie sich eine App namens „perfektimprezy“ vor, die auf Flask ausgeführt wird, mit dem folgende Quelle:

from flask import Flask

app = Flask(__name__)
app.debug = True

@app.route('/')
def main():
    return 'hi'

if __name__ == '__main__':
    app.run()
Nach dem Login kopieren

Bei der Bereitstellung in einem Docker-Container scheint der Server zu laufen, aber die Anwendung bleibt von außerhalb des nicht zugänglich Container.

Docker-Konfiguration

Die für die Bereitstellung verwendete Docker-Datei ist:

# Dockerfile
FROM dreen/flask
MAINTAINER dreen
WORKDIR /srv

# Get source
RUN mkdir -p /srv
COPY perfektimprezy.tar.gz /srv/perfektimprezy.tar.gz
RUN tar x -f perfektimprezy.tar.gz
RUN rm perfektimprezy.tar.gz

# Run server
EXPOSE 5000
CMD ["python", "index.py"]
Nach dem Login kopieren

Die Bereitstellungsschritte umfassen das Erstellen des Images und das Ausführen des Containers mit verfügbarem Port 5000:

>$ sudo docker build -t perfektimprezy .
>$ sudo docker run -i -p 5000:5000 -d perfektimprezy
Nach dem Login kopieren

Untersuchung

Der Container scheint wie erwartet zu laufen, wobei der Flask-Server lauscht auf Port 5000 innerhalb des Containers:

>$ sudo docker logs 1c50b67d45b1
    * Running on http://127.0.0.1:5000/ (Press CTRL+C to quit)
    * Restarting with stat
Nach dem Login kopieren

Anfragen an die Anwendung von außerhalb des Containers führen jedoch zu leeren Antworten:

>$ curl 127.0.0.1:5000 -v
* Empty reply from server
Nach dem Login kopieren

Lösung

Das Problem liegt in der Bindung der Flask-App an die Localhost-Schnittstelle. Um die Anwendung von außerhalb des Containers zugänglich zu machen, sollte sie stattdessen an die Adresse 0.0.0.0 gebunden werden.

Ändern Sie in der Initialisierung der Flask-App:

if __name__ == '__main__':
    app.run()
Nach dem Login kopieren

in:

if __name__ == '__main__':
    app.run(host='0.0.0.0')
Nach dem Login kopieren

Diese Änderung bindet die App an alle Schnittstellen auf dem Host und macht sie von außerhalb des Containers zugänglich.

Das obige ist der detaillierte Inhalt vonWarum kann ich nach der Bereitstellung in Docker nicht auf meine Flask-App zugreifen?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage