在docker容器中运行flask应用程序时无法访问端点

时间:2019-10-07 18:32:50

标签: python docker flask docker-compose dockerfile

我正在尝试对Flask应用程序进行docker化。但是,碰到 http://127.0.0.1:5000/ 上的任意端点时出现以下错误。我已将端口正确地从 localhost 映射到容器

  

flask.cli.NoAppException flask.cli.NoAppException:导入时   “ dsdp.wsgi”,引发了ImportError:

     

回溯(最近通话最近):文件   “ /usr/local/lib/python3.7/site-packages/flask/cli.py”,第240行,在   locate_app       导入(模块名称)文件“ /var/www/dsdp/wsgi.py”,第4行,在       从app.common.observer导入ConfigPublisher,QueueSubscriber ModuleNotFoundError:没有名为“ app”的模块

这是我容器内的结构。

root@6c37b85d98cb:/var/www/dsdp# ls -ltr
total 32
-rw-rw-r-- 1 root root  135 Oct  4 07:55 uwsgi.local.ini
-rw-rw-r-- 1 root root  598 Oct  4 07:55 requirements.txt
drwxrwxr-x 5 root root 4096 Oct  4 07:55 config
-rw-rw-r-- 1 root root    0 Oct  4 07:55 __init__.py
-rwxrwxr-x 1 root root  175 Oct  7 17:14 entrypoint.sh
-rw-rw-r-- 1 root root  742 Oct  7 17:36 wsgi.py
drwxrwxr-x 7 root root 4096 Oct  7 17:43 app
-rw-rw-r-- 1 root root  614 Oct  7 17:45 Dockerfile.app.local

FLASK_APP环境变量:

root@6c37b85d98cb:/var/www/dsdp# echo $FLASK_APP 
wsgi.py

wsgi.py 中,我正尝试按以下方式导入

from app.common.observer import ConfigPublisher, QueueSubscriber
from app.common.utils.endpoints import register_blueprints

当我在本地运行flask应用程序时,这些工作正常。但是当我在docker中运行时,它抛出了错误。我在 app 文件夹中确实有一个 __ init __。py

这是我用来构建映像的Dockerfile。

Dockerfile.app.local:

FROM python:3.7
RUN mkdir -p /var/www/dsdp/
WORKDIR /var/www/dsdp/
COPY . /var/www/dsdp/
RUN pip3 install --no-cache-dir -r requirements.txt
COPY uwsgi.local.ini /etc/uwsgi.ini
EXPOSE 5000

这就是我使用 docker-compose.yml

构建图像的方式
  workload_service:
    container_name: workload_container
    restart: always
    image: workload
    build: 
      context: ./dsdp
      dockerfile: Dockerfile.app.local
    depends_on:
        - postgres_service
    ports:
      - "5000:5000"
    environment:
        - FLASK_APP=wsgi.py
        - FLASK_DEBUG=1
        - CONFIG_PATH=config/local
        - FLASK_CONFIG=local
        - APP_NAME=WORKLOAD
        - PYTHONPATH=.
    command: flask run --host=0.0.0.0 --port 5000

我在哪里犯错?

2 个答案:

答案 0 :(得分:1)

99%(或至少绝大多数)的时间发生,是因为在容器内部使用了127.0.0.1:5000。那将是localhost 容器内。这与localhost 外部容器(在主机中)不同。

解决方法是将容器内的host=绑定到0.0.0.0:5000

答案 1 :(得分:1)

将您from更改为:

from .app.common.observer

尝试在Dockerfile中设置FLASK_APP

 ENV FLASK_APP dsdp.wsgi:app
 ARG FLASK_APP=dsdp.wsgi:app

从文档中:

  

FLASK_APP =你好

The name is imported, automatically detecting an app (app) or factory (create_app).