docker-compose 运行 Flask 应用最佳实践
背景
??以前部署應(yīng)用,需要各種環(huán)境配置,各種shell操作才能搭建一套可用的服務(wù)。現(xiàn)在有了Docker之后,部署方式變了更加容易,不容易出現(xiàn)配置錯(cuò)誤,環(huán)境不一致問(wèn)題。解決了在本地環(huán)境可以運(yùn)行,遷移到線上出現(xiàn)各種問(wèn)題,這些問(wèn)題大多出現(xiàn)在線上和本地環(huán)境有差異,配置容易出現(xiàn)錯(cuò)誤等情況。那么docker-compose 和 docker 之間存在著什么聯(lián)系呢?
先來(lái)看看docker-compose 的定義: 「定義和運(yùn)行多個(gè) Docker 容器的應(yīng)用(Defining and running multi-container Docker applications)」??我們知道 docker 可以通過(guò) Dockerfile 模板文件來(lái)定義一個(gè)應(yīng)用容器。實(shí)際應(yīng)用中,經(jīng)常遇到多個(gè)容器相配合運(yùn)行一套應(yīng)用程序的情況。比如,實(shí)現(xiàn)一個(gè)Flask應(yīng)用,除了 Flask 服務(wù)本身之外,還需要一些數(shù)據(jù)庫(kù)服務(wù)容器等。Compose 恰好滿(mǎn)足了這樣的需求。它允許用戶(hù)通過(guò)一個(gè)單獨(dú)的 docker-compose.yml 模板文件(YAML 格式)來(lái)定義一組相關(guān)聯(lián)的應(yīng)用容器為一個(gè)項(xiàng)目(project)。
??通過(guò) Docker-Compose 用戶(hù)可以很容易地用一個(gè)配置文件定義一個(gè)多容器的應(yīng)用,然后使用一條指令安裝這個(gè)應(yīng)用的所有依賴(lài),完成構(gòu)建。Docker-Compose解決了容器與容器之間如何管理編排的問(wèn)題。
實(shí)施步驟
使用 Dockerfile 定制鏡像
??鏡像的定制實(shí)際上就是定制每一層所添加的配置、文件,因?yàn)?Flask 應(yīng)用需要一些環(huán)境依賴(lài)才能運(yùn)行起來(lái)。所以想要將 Flask 應(yīng)用運(yùn)行在 Docker 容器中,該容器必須將該應(yīng)用所有的環(huán)境依賴(lài)安裝好。而 Dockerfile 就是提供給我們配置相關(guān)的環(huán)境依賴(lài)等操作。Dockerfile 是一個(gè)文本文件,其內(nèi)包含了一條條的指令(Instruction),每一條指令構(gòu)建一層,因此每一條指令的內(nèi)容,就是描述該層應(yīng)當(dāng)如何構(gòu)建。
下面以我的GitHub項(xiàng)目 flask-v2ex 應(yīng)用的 Dockerfile 文件為例:
FROM daocloud.io/python:3.5MAINTAINER Guoweikuang <guoweikuang2015@gmail.com> RUN mkdir -p /home/guoweikuang/app WORKDIR /home/guoweikuang/app ADD ./requirements.txt /home/guoweikuang/app/requirements.txt RUN pip3 install -i https://pypi.tuna.tsinghua.edu.cn/simple --upgrade pip RUN pip3 install -i https://pypi.tuna.tsinghua.edu.cn/simple -r requirements.txt ADD . /home/guoweikuang/app CMD python manage.py runserver -h 0.0.0.0FROM: 指定了基礎(chǔ)鏡像,以該鏡像為基礎(chǔ),在其上進(jìn)行定制操作 MAINTAINER: 用來(lái)指定鏡像創(chuàng)建者信息 RUN: 創(chuàng)建了 **/home/guoweikuang/app** 文件夾 (后面 RUN pip3 安裝Python擴(kuò)展庫(kù)) WORKDIR: 切換目錄,可以多次切換(相當(dāng)于cd命令) ADD: 從本地目錄相應(yīng)文件拷貝到容器路徑里 CMD: 設(shè)置container啟動(dòng)時(shí)執(zhí)行的操作,運(yùn)行 Flask 應(yīng)用并設(shè)置host為0.0.0.0編寫(xiě) docker-compose.yml 文件
docker-compose.yml 文件將把所有的東西關(guān)聯(lián)起來(lái)。它描述了應(yīng)用的構(gòu)成(一個(gè) web 服務(wù)和一個(gè)數(shù)據(jù)庫(kù))、使用的 Docker 鏡像、鏡像之間的連接、掛載到容器的卷,以及服務(wù)開(kāi)放的端口。
下面以我的GitHub項(xiàng)目 flask-v2ex 應(yīng)用的 docker-compose.yml 文件為例:
version: '2'services:web:build: .container_name: flask_v2exports:- "5000:5000"redis:image: "redis:alpine"compose 中定義了兩個(gè)服務(wù) web 和 redis。
-
web 服務(wù)
- build: 使用當(dāng)前目錄的 Dockerfile build 的鏡像
- ports: 映射宿主機(jī) 5000 端口到容器的 5000 端口
- container_name: 指定了容器的名字
-
redis 服務(wù)
- image: 使用 Docker Hub 中的 redis 鏡像
使用 compose 構(gòu)建并運(yùn)行 Flask 應(yīng)用
在運(yùn)行 docker-compose up 之前,需要做一些修改,把項(xiàng)目里關(guān)于redis連接配置進(jìn)行修改
r = redis.Redis(host='localhost', port=6379, decode_responses=True)修改為:r = redis.Redis(host='redis', port=6379, decode_responses=True)在flask-v2ex 項(xiàng)目的根目錄下使用 docker-compose up 命令,如下所示:
$ docker-compose upStarting flask_v2ex ... done Starting flask_v2ex_redis_1 ... done Attaching to flask_v2ex_redis_1, flask_v2ex redis_1 | 1:C 01 Jul 07:46:52.053 # oO0OoO0OoO0Oo Redis is starting oO0OoO0OoO0Oo redis_1 | 1:C 01 Jul 07:46:52.053 # Redis version=4.0.6, bits=64, commit=00000000, modified=0, pid=1, just started redis_1 | 1:C 01 Jul 07:46:52.053 # Warning: no config file specified, using the default config. In order to specify a config file use redis-server /path/to/redis.conf redis_1 | 1:M 01 Jul 07:46:52.064 * Running mode=standalone, port=6379. redis_1 | 1:M 01 Jul 07:46:52.064 # WARNING: The TCP backlog setting of 511 cannot be enforced because /proc/sys/net/core/somaxconn is set to the lower value of 128. redis_1 | 1:M 01 Jul 07:46:52.064 # Server initialized redis_1 | 1:M 01 Jul 07:46:52.065 # WARNING you have Transparent Huge Pages (THP) support enabled in your kernel. This will create latency and memory usage issues with Redis. To fix this issue run the command 'echo never > /sys/kernel/mm/transparent_hugepage/enabled' as root, and add it to your /etc/rc.local in order to retain the setting after a reboot. Redis must be restarted after THP is disabled. redis_1 | 1:M 01 Jul 07:46:52.065 * DB loaded from disk: 0.000 seconds redis_1 | 1:M 01 Jul 07:46:52.065 * Ready to accept connections flask_v2ex | * Running on http://0.0.0.0:5000/ (Press CTRL+C to quit) flask_v2ex | * Restarting with stat flask_v2ex | * Debugger is active! flask_v2ex | * Debugger PIN: 742-073-002可以看到 Docker 守護(hù)進(jìn)程里監(jiān)聽(tīng)著 5000 端口了。可以通過(guò)http://localhost:5000 訪問(wèn) Flask 應(yīng)用。
docker-compose 使用
- docker-compose up -d : 后臺(tái)運(yùn)行
- docker-compose stop: 停止正在運(yùn)行的服務(wù)
- docker-compose down: 關(guān)閉所有容器并刪除,默認(rèn)保留 數(shù)據(jù)卷
- docker-compose ps:列出當(dāng)前運(yùn)行的服務(wù)狀態(tài)和相關(guān)信息
- docker-compose run: 一次性命令。 例如查看 web 服務(wù)的環(huán)境變量:
如果需要停止已經(jīng)運(yùn)行中的服務(wù),可以通過(guò)ctrl + c 或者 docker-compose stop 來(lái)停止服務(wù)。
參考
Docker從入門(mén)到實(shí)踐 --實(shí)戰(zhàn)Django
使用Dockerfile構(gòu)建Docker鏡像
總結(jié)
以上是生活随笔為你收集整理的docker-compose 运行 Flask 应用最佳实践的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: HTML5中本地储存概念是什么,什么优点
- 下一篇: OpenCV-Python入门教程7-P