摘要:現(xiàn)在有了之后,部署方式變了更加容易,不容易出現(xiàn)配置錯(cuò)誤,環(huán)境不一致問(wèn)題。實(shí)際應(yīng)用中,經(jīng)常遇到多個(gè)容器相配合運(yùn)行一套應(yīng)用程序的情況。所以想要將應(yīng)用運(yùn)行在容器中,該容器必須將該應(yīng)用所有的環(huán)境依賴安裝好。
??以前部署應(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 恰好滿足了這樣的需求。它允許用戶通過(guò)一個(gè)多帶帶的 docker-compose.yml 模板文件(YAML 格式)來(lái)定義一組相關(guān)聯(lián)的應(yīng)用容器為一個(gè)項(xiàng)目(project)。
??通過(guò) Docker-Compose 用戶可以很容易地用一個(gè)配置文件定義一個(gè)多容器的應(yīng)用,然后使用一條指令安裝這個(gè)應(yīng)用的所有依賴,完成構(gòu)建。Docker-Compose解決了容器與容器之間如何管理編排的問(wèn)題。
??鏡像的定制實(shí)際上就是定制每一層所添加的配置、文件,因?yàn)?Flask 應(yīng)用需要一些環(huán)境依賴才能運(yùn)行起來(lái)。所以想要將 Flask 應(yīng)用運(yùn)行在 Docker 容器中,該容器必須將該應(yīng)用所有的環(huán)境依賴安裝好。而 Dockerfile 就是提供給我們配置相關(guān)的環(huán)境依賴等操作。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.5 MAINTAINER Guoweikuang編寫 docker-compose.yml 文件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.0 FROM: 指定了基礎(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
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_v2ex ports: - "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 up Starting 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 ps Name Command State Ports ------------------------------------------------------------------------------------ flask_v2ex /bin/sh -c python manage.p ... Up 0.0.0.0:5000->5000/tcp flask_v2ex_redis_1 docker-entrypoint.sh redis ... Up 6379/tcp
docker-compose run: 一次性命令。 例如查看 web 服務(wù)的環(huán)境變量:
$ docker-compose run web env PATH=/usr/local/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin HOSTNAME=e4b6b17f39dc TERM=xterm LANG=C.UTF-8 GPG_KEY=97FC712E4C024BBEA48A61ED3A5CA953F73C700D PYTHON_VERSION=3.5.4 PYTHON_PIP_VERSION=9.0.1 HOME=/root
如果需要停止已經(jīng)運(yùn)行中的服務(wù),可以通過(guò)ctrl + c 或者 docker-compose stop 來(lái)停止服務(wù)。
參考Docker從入門到實(shí)踐 --實(shí)戰(zhàn)Django
使用Dockerfile構(gòu)建Docker鏡像
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://specialneedsforspecialkids.com/yun/27567.html
摘要:現(xiàn)在有了之后,部署方式變了更加容易,不容易出現(xiàn)配置錯(cuò)誤,環(huán)境不一致問(wèn)題。實(shí)際應(yīng)用中,經(jīng)常遇到多個(gè)容器相配合運(yùn)行一套應(yīng)用程序的情況。所以想要將應(yīng)用運(yùn)行在容器中,該容器必須將該應(yīng)用所有的環(huán)境依賴安裝好。 showImg(https://segmentfault.com/img/remote/1460000017081815); 背景 ??以前部署應(yīng)用,需要各種環(huán)境配置,各種shell操作...
摘要:后來(lái)真正用的時(shí)候才發(fā)覺(jué),這個(gè)簡(jiǎn)直是個(gè)神器。容器可以被創(chuàng)建啟動(dòng)停止刪除暫停等。項(xiàng)目由編寫,實(shí)現(xiàn)上調(diào)用了服務(wù)提供的來(lái)對(duì)容器進(jìn)行管理。此命令將會(huì)停止命令所啟動(dòng)的容器,并移除網(wǎng)絡(luò)啟動(dòng)已經(jīng)存在的服務(wù)容器。停止已經(jīng)處于運(yùn)行狀態(tài)的容器,但不刪除它。 showImg(https://segmentfault.com/img/remote/1460000017531120?w=1200&h=500); ...
摘要:后來(lái)真正用的時(shí)候才發(fā)覺(jué),這個(gè)簡(jiǎn)直是個(gè)神器。容器可以被創(chuàng)建啟動(dòng)停止刪除暫停等。項(xiàng)目由編寫,實(shí)現(xiàn)上調(diào)用了服務(wù)提供的來(lái)對(duì)容器進(jìn)行管理。此命令將會(huì)停止命令所啟動(dòng)的容器,并移除網(wǎng)絡(luò)啟動(dòng)已經(jīng)存在的服務(wù)容器。停止已經(jīng)處于運(yùn)行狀態(tài)的容器,但不刪除它。 showImg(https://segmentfault.com/img/remote/1460000017531120?w=1200&h=500); ...
摘要:當(dāng)功能越來(lái)越復(fù)雜的時(shí)候,你可能修改了一些東西,導(dǎo)致另外一個(gè)功能的不可用,而單元測(cè)試也能保證了原有功能被破壞后能被檢測(cè)出來(lái)。 showImg(https://segmentfault.com/img/remote/1460000017081749); 前言 前一篇講到了 TDD 測(cè)試驅(qū)動(dòng)開(kāi)發(fā)的相關(guān)概念和環(huán)境搭建,這篇就著手開(kāi)始用TDD方式開(kāi)發(fā)了。首先這篇需要編寫用戶相關(guān)的API接口,如...
摘要:使用構(gòu)建一個(gè)創(chuàng)建一個(gè)文件夾創(chuàng)建腳本這個(gè)腳本使用了和的包,并且啟動(dòng)了一個(gè)服務(wù)端口創(chuàng)建構(gòu)建的由于在的時(shí)候,默認(rèn)會(huì)去官方去獲取,國(guó)內(nèi)是無(wú)法訪問(wèn)的,所以這里使用了的鏡像去下載包。 使用docker-compose構(gòu)建一個(gè)python-web app 創(chuàng)建一個(gè)文件夾 python-web-app $mkdir python-web-app $cd python-web-app 2.創(chuàng)建pytho...
閱讀 2601·2021-11-15 11:38
閱讀 2618·2021-11-04 16:13
閱讀 17981·2021-09-22 15:07
閱讀 1014·2019-08-30 15:55
閱讀 3261·2019-08-30 14:15
閱讀 1663·2019-08-29 13:59
閱讀 3207·2019-08-28 18:28
閱讀 1575·2019-08-23 18:29