如何使dockerized Flask app将输出写入文件?

时间:2018-04-27 11:06:49

标签: python-3.x docker flask docker-compose

我正在尝试让服务器托管(dockerized)Flask应用程序“log”发送给它的请求,只需将它们写入文本文件即可。

我的docker-compose.yml看起来像

version: '2'

services:
  writer:
    build: writer/
    ports: 
      - 5000:5000
    container_name: writer

并且在writer目录中我有writer.py文件,如下所示,它应该获取请求并将其写入本地文件feedback.txt

from flask import Flask, request, jsonify

app = Flask(__name__, static_url_path='')

@app.route('/feedback', methods=['POST']) 
def log_feedback():
    with open("feedback.txt","a") as fo:
        fo.write(request.data.decode("utf-8"))
        print(request.data.decode("utf-8"))
        fo.write('\n')
    return 'Got it!'

if __name__ == '__main__':
    app.run(host='0.0.0.0', debug = False)

作为参考,同一Dockerfile目录中的writer是:

FROM python:3.6-slim
WORKDIR /app
ADD . /app
RUN pip install -r requirements.txt
ENTRYPOINT [ "python", "writer.py" ]

requirements.txt只是

flask

示例请求

curl -H "Content-Type:application" -X POST -d '{"Content":"Hello world"}' http://0.0.0.0:5000/feedback

不幸的是,没有feedback.txt在本地写入(例如在容器外)。你可以向我暗示我应该进行的修改,例如在docker-compose.yml中(例如,使用卷?),以便在服务器上编写和访问feedback.txt

1 个答案:

答案 0 :(得分:3)

您必须在docker-compose.yml中添加一个卷。容器中的路径应包含包含写入文件的文件夹。本地文件夹的路径应该包含系统上要查看写入文件的文件夹。

version: '2'

services:
  writer:
    build: writer/
    ports: 
      - 5000:5000
    container_name: writer
    volumes:
      - /PATH/TO/YOUR/LOCAL_FOLDER:/PATH/TO/FOLDER/IN/CONTAINER