欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Docker Compose 搭建簡(jiǎn)單的Python網(wǎng)絡(luò)應(yīng)用程序(步驟詳解)

 更新時(shí)間:2022年07月26日 11:28:56   作者:哇嗚喵  
在這個(gè)頁(yè)面上,你可以建立一個(gè)簡(jiǎn)單的Python網(wǎng)絡(luò)應(yīng)用程序,運(yùn)行在Docker Compose上,這篇文章主要介紹了Docker Compose 搭建簡(jiǎn)單的Python網(wǎng)絡(luò)應(yīng)用程序,需要的朋友可以參考下

在這個(gè)頁(yè)面上,你可以建立一個(gè)簡(jiǎn)單的Python網(wǎng)絡(luò)應(yīng)用程序,運(yùn)行在Docker Compose上。該應(yīng)用使用Flask框架,并在Redis中維護(hù)一個(gè)點(diǎn)擊計(jì)數(shù)器。雖然樣本使用了Python,但即使你不熟悉它,這里展示的概念也應(yīng)該是可以理解的。(官網(wǎng)教程翻譯)

前提條件

請(qǐng)確保你已經(jīng)安裝了Docker Engine和Docker Compose。你不需要安裝Python或Redis,因?yàn)閮烧叨际怯蒁ocker鏡像提供的。

第1步:設(shè)置

定義應(yīng)用程序的依賴。

  • 為該項(xiàng)目創(chuàng)建一個(gè)目錄。
$ mkdir composetest
$ cd composetest
  • 在你的項(xiàng)目目錄下創(chuàng)建一個(gè)名為 app.py 的文件,并把以下內(nèi)容粘貼進(jìn)去:
import time
import redis
from flask import Flask
app = Flask(__name__)
cache = redis.Redis(host='redis', port=6379)
def get_hit_count():
    retries = 5
    while True:
        try:
            return cache.incr('hits')
        except redis.exceptions.ConnectionError as exc:
            if retries == 0:
                raise exc
            retries -= 1
            time.sleep(0.5)
@app.route('/')
def hello():
    count = get_hit_count()
    return 'Hello World! I have been seen {} times.\n'.format(count)

在這個(gè)例子中,redis 是應(yīng)用程序網(wǎng)絡(luò)中的redis容器的主機(jī)名。我們使用Redis的默認(rèn)端口,6379。

處理瞬時(shí)錯(cuò)誤 注意 get_hit_count 函數(shù)的編寫方式。這個(gè)基本的重試循環(huán)讓我們?cè)趓edis服務(wù)不可用時(shí)多次嘗試我們的請(qǐng)求。這在應(yīng)用程序上線的時(shí)候很有用,而且如果Redis服務(wù)需要在應(yīng)用程序的生命周期內(nèi)隨時(shí)重啟,這也使我們的應(yīng)用程序更具彈性。在一個(gè)集群中,這也有助于處理節(jié)點(diǎn)之間的瞬間連接中斷。

  • 在你的項(xiàng)目目錄下創(chuàng)建另一個(gè)名為 requirements.txt 的文件,并將以下內(nèi)容粘貼進(jìn)去:
flask
redis

第2步:創(chuàng)建一個(gè)Dockerfile

在這一步,你要寫一個(gè)Dockerfile來(lái)構(gòu)建一個(gè)Docker鏡像。這個(gè)鏡像包含了Python應(yīng)用程序所需的所有依賴項(xiàng),包括Python本身。

在你的項(xiàng)目目錄中,創(chuàng)建一個(gè)名為 Dockerfile 的文件并粘貼以下內(nèi)容:

# syntax=docker/dockerfile:1
FROM python:3.7-alpine
WORKDIR /code
ENV FLASK_APP=app.py
ENV FLASK_RUN_HOST=0.0.0.0
RUN apk add --no-cache gcc musl-dev linux-headers
COPY requirements.txt requirements.txt
RUN pip install -r requirements.txt
EXPOSE 5000
COPY . .
CMD ["flask", "run"]

這告訴Docker:

  • 從Python 3.7鏡像開(kāi)始構(gòu)建一個(gè)鏡像。

  • 設(shè)置工作目錄為 /code

  • 設(shè)置 flask 命令使用的環(huán)境變量。

  • 安裝gcc和其他依賴項(xiàng)

  • 復(fù)制 requirements.txt 并安裝Python依賴項(xiàng)。

  • 給鏡像添加元數(shù)據(jù),描述容器在5000端口上監(jiān)聽(tīng)

  • 將項(xiàng)目中的當(dāng)前目錄.復(fù)制到鏡像中的工作目錄.。

  • 將容器的默認(rèn)命令設(shè)置為 flask run

第3步:在Compose文件中定義服務(wù)

在你的項(xiàng)目目錄下創(chuàng)建一個(gè)名為 docker-compose.yml 的文件,并粘貼以下內(nèi)容:

version: "3.9"
services:
  web:
    build: .
    ports:
      - "8000:5000"
  redis:
    image: "redis:alpine"

這個(gè) Compose 文件定義了兩個(gè)服務(wù):webredis

Web服務(wù)

web 服務(wù)使用一個(gè)從當(dāng)前目錄下的 Dockerfile 文件構(gòu)建的鏡像。然后它將容器和主機(jī)綁定到暴露的端口8000上。本例服務(wù)使用Flask網(wǎng)絡(luò)服務(wù)器的默認(rèn)端口,即5000。

Redis服務(wù)

redis 服務(wù)使用了一個(gè)從Docker Hub倉(cāng)庫(kù)中拉取的公共Redis鏡像。

第4步:用Compose構(gòu)建和運(yùn)行你的應(yīng)用

  • 在你的項(xiàng)目目錄中,通過(guò)運(yùn)行 docker-compose up 來(lái)啟動(dòng)你的應(yīng)用程序。
$ docker-compose up

Creating network "composetest_default" with the default driver
Creating composetest_web_1 ...
Creating composetest_redis_1 ...
Creating composetest_web_1
Creating composetest_redis_1 ... done
Attaching to composetest_web_1, composetest_redis_1
web_1    |  * Running on http://0.0.0.0:5000/ (Press CTRL+C to quit)
redis_1  | 1:C 17 Aug 22:11:10.480 # oO0OoO0OoO0Oo Redis is starting oO0OoO0OoO0Oo
redis_1  | 1:C 17 Aug 22:11:10.480 # Redis version=4.0.1, bits=64, commit=00000000, modified=0, pid=1, just started
redis_1  | 1:C 17 Aug 22:11:10.480 # Warning: no config file specified, using the default config. In order to specify a config file use redis-server /path/to/redis.conf
web_1    |  * Restarting with stat
redis_1  | 1:M 17 Aug 22:11:10.483 * Running mode=standalone, port=6379.
redis_1  | 1:M 17 Aug 22:11:10.483 # WARNING: The TCP backlog setting of 511 cannot be enforced because /proc/sys/net/core/somaxconn is set to the lower value of 128.
web_1    |  * Debugger is active!
redis_1  | 1:M 17 Aug 22:11:10.483 # Server initialized
redis_1  | 1:M 17 Aug 22:11:10.483 # 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.
web_1    |  * Debugger PIN: 330-787-903
redis_1  | 1:M 17 Aug 22:11:10.483 * Ready to accept connections

Compose會(huì)拉取一個(gè)Redis鏡像,為你的代碼構(gòu)建一個(gè)鏡像,并啟動(dòng)你定義的服務(wù)。在這種情況下,代碼在構(gòu)建時(shí)被靜態(tài)地復(fù)制到鏡像中。

如果你在本地Linux上使用Docker、Docker Desktop for Mac或Docker Desktop for Windows,那么網(wǎng)絡(luò)應(yīng)用現(xiàn)在應(yīng)該在你的Docker守護(hù)主機(jī)上監(jiān)聽(tīng)8000端口。將你的網(wǎng)絡(luò)瀏覽器指向http://localhost:8000,找到`Hello World` 消息。如果這還沒(méi)有解決,你也可以試試http://127.0.0.1:8000。

你應(yīng)該在你的瀏覽器中看到一條消息說(shuō):

Hello World! I have been seen 1 times.

3. 刷新頁(yè)面。

這個(gè)數(shù)字應(yīng)該是遞增的。

Hello World! I have been seen 2 times.

  • 切換到另一個(gè)終端窗口,并輸入 docker image ls 來(lái)列出本地圖像。

在這一點(diǎn)上,列出圖像應(yīng)該返回 redisweb。

$ docker image ls
REPOSITORY        TAG           IMAGE ID      CREATED        SIZE
composetest_web   latest        e2c21aa48cc1  4 minutes ago  93.8MB
python            3.4-alpine    84e6077c7ab6  7 days ago     82.5MB
redis             alpine        9d8fa9aa0e5b  3 weeks ago    27.5MB

你可以用 docker inspect <tag or id> 檢查鏡像。

  • 停止應(yīng)用程序,可以在第二個(gè)終端中的項(xiàng)目目錄中運(yùn)行 docker-compose down,或者在啟動(dòng)應(yīng)用程序的原始終端中點(diǎn)擊CTRL+C。

第5步:編輯Compose文件以添加綁定掛載

在你的項(xiàng)目目錄中編輯 docker-compose.yml,為 web 服務(wù)添加一個(gè)綁定掛載。

version: "3.9"
services:
  web:
    build: .
    ports:
      - "8000:5000"
    volumes:
      - .:/code
    environment:
      FLASK_ENV: development
  redis:
    image: "redis:alpine"

新的 volumes 鍵將主機(jī)上的項(xiàng)目目錄(當(dāng)前目錄)掛載到容器內(nèi)的 /code,允許你即時(shí)修改代碼,而不需要重建鏡像。environment 鍵設(shè)置 FLASK_ENV 環(huán)境變量,它告訴 flask run 在開(kāi)發(fā)模式下運(yùn)行,并在代碼變化時(shí)重新加載。這種模式只應(yīng)在開(kāi)發(fā)中使用。

第6步:用Compose重新構(gòu)建并運(yùn)行應(yīng)用程序

在你的項(xiàng)目目錄下,輸入 docker-compose up,用更新的Compose文件構(gòu)建應(yīng)用程序,并運(yùn)行它。

$ docker-compose up
Creating network "composetest_default" with the default driver
Creating composetest_web_1 ...
Creating composetest_redis_1 ...
Creating composetest_web_1
Creating composetest_redis_1 ... done
Attaching to composetest_web_1, composetest_redis_1
web_1    |  * Running on http://0.0.0.0:5000/ (Press CTRL+C to quit)
...

再次在網(wǎng)絡(luò)瀏覽器中檢查 Hello World 消息,并刷新以看到計(jì)數(shù)的增加。

共享文件夾、卷和綁定掛載

  • 如果你的項(xiàng)目在 Users 目錄之外(cd ~),那么你需要共享你正在使用的Dockerfile文件和volume的驅(qū)動(dòng)器或位置。如果你得到運(yùn)行時(shí)的錯(cuò)誤,表明找不到應(yīng)用文件,卷掛載被拒絕,或服務(wù)無(wú)法啟動(dòng),請(qǐng)嘗試啟用文件或驅(qū)動(dòng)器共享。卷掛載需要在 C:\Users(Windows)或 /Users(Mac)之外的項(xiàng)目共享驅(qū)動(dòng)器,而且對(duì)于Docker Desktop for Windows上任何使用Linux容器的項(xiàng)目都是必需的。

  • 如果你在舊的Windows操作系統(tǒng)上使用Oracle VirtualBox,你可能會(huì)遇到這個(gè)VB故障單中描述的共享文件夾的問(wèn)題。較新的Windows系統(tǒng)符合Docker Desktop for Windows的要求并且不需要VirtualBox。

第7步:更新應(yīng)用程序

因?yàn)閼?yīng)用程序代碼現(xiàn)在是用volume裝入容器的,所以你可以對(duì)其代碼進(jìn)行修改,并立即看到變化,而不需要重建鏡像。

改變 app.py 中的問(wèn)候語(yǔ),并保存它。例如,將 Hello World!的信息改為 Hello from Docker!

return 'Hello from Docker! I have been seen {} times.\n'.format(count)

在你的瀏覽器中刷新該應(yīng)用程序。問(wèn)候語(yǔ)應(yīng)該被更新,而計(jì)數(shù)器應(yīng)該仍然在遞增。

第8步:試驗(yàn)一些其他命令

如果你想在后臺(tái)運(yùn)行你的服務(wù),你可以向 docker-compose up 傳遞 -d 標(biāo)志(用于 "分離 "模式),并使用docker-compose ps 來(lái)查看當(dāng)前正在運(yùn)行的內(nèi)容:

$ docker-compose up -d
Starting composetest_redis_1...
Starting composetest_web_1...
$ docker-compose ps
       Name                      Command               State           Ports         
-------------------------------------------------------------------------------------
composetest_redis_1   docker-entrypoint.sh redis ...   Up      6379/tcp              
composetest_web_1     flask run                        Up      0.0.0.0:8000->5000/tcp

docker-compose 的運(yùn)行命令允許你為你的服務(wù)運(yùn)行一次性的命令。例如,看看 web 服務(wù)有哪些環(huán)境變量可用:

$ docker-compose run web env

參見(jiàn) docker-compose --help 以查看其他可用的命令。

如果你用 docker-compose up -d 啟動(dòng)了Compose,一旦你完成了你的服務(wù),就停止它們:

$ docker-compose stop

你可以用 down 命令來(lái)關(guān)閉一切,完全刪除容器。通過(guò) --volumes,也可以刪除Redis容器所使用的數(shù)據(jù)卷:

$ docker-compose down --volumes

在這一點(diǎn)上,你已經(jīng)明白了 Compose 是如何工作的。

到此這篇關(guān)于Docker Compose 搭建簡(jiǎn)單的Python網(wǎng)絡(luò)應(yīng)用程序的詳細(xì)步驟的文章就介紹到這了,更多相關(guān)Docker Compose 搭建Python網(wǎng)絡(luò)應(yīng)用程序內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 使用docker部署dubbo項(xiàng)目的方法步驟

    使用docker部署dubbo項(xiàng)目的方法步驟

    這篇文章主要介紹了使用docker部署dubbo項(xiàng)目的方法步驟,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2021-01-01
  • docker部署Prometheus+Cadvisor+Grafana實(shí)現(xiàn)服務(wù)器監(jiān)控

    docker部署Prometheus+Cadvisor+Grafana實(shí)現(xiàn)服務(wù)器監(jiān)控

    這篇文章主要為大家介紹了docker部署Prometheus+Cadvisor+Grafana實(shí)現(xiàn)服務(wù)器監(jiān)控,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-11-11
  • Docker容器/bin/bash?start.sh無(wú)法找到not?found問(wèn)題解決

    Docker容器/bin/bash?start.sh無(wú)法找到not?found問(wèn)題解決

    最近在學(xué)習(xí)聯(lián)系中遇到一個(gè)問(wèn)題,百度后發(fā)現(xiàn)這個(gè)需求還是挺常見(jiàn)的,所以下面這篇文章主要給大家介紹了關(guān)于Docker容器/bin/bash?start.sh無(wú)法找到not?found問(wèn)題的解決方法,需要的朋友可以參考下
    2022-08-08
  • docker資源控制管理Cgroup的實(shí)現(xiàn)

    docker資源控制管理Cgroup的實(shí)現(xiàn)

    本文主要介紹了docker資源控制管理Cgroup的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2022-07-07
  • Docker?compose搭建ELK服務(wù)基本使用

    Docker?compose搭建ELK服務(wù)基本使用

    這篇文章主要為大家介紹了Docker?compose搭建ELK服務(wù)基本使用,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-03-03
  • docker容器內(nèi)網(wǎng)絡(luò)請(qǐng)求緩慢問(wèn)題解決

    docker容器內(nèi)網(wǎng)絡(luò)請(qǐng)求緩慢問(wèn)題解決

    在使用docker的過(guò)程中發(fā)現(xiàn)了幾個(gè)問(wèn)題,在docker里進(jìn)行的網(wǎng)絡(luò)請(qǐng)求經(jīng)常會(huì)失敗,這篇文章主要介紹了docker容器內(nèi)網(wǎng)絡(luò)請(qǐng)求緩慢問(wèn)題解決
    2019-01-01
  • 詳解使用Dockerfile創(chuàng)建帶Apache服務(wù)的CentOS Docker鏡像

    詳解使用Dockerfile創(chuàng)建帶Apache服務(wù)的CentOS Docker鏡像

    本篇文章主要介紹了使用Dockerfile創(chuàng)建帶Apache服務(wù)的CentOS Docker鏡像,具有一定的參考價(jià)值,有興趣的可以了解一下。
    2016-12-12
  • 如何修改 docker 容器的啟動(dòng)參數(shù)

    如何修改 docker 容器的啟動(dòng)參數(shù)

    工作中我們經(jīng)常遇到docker容器運(yùn)行一段時(shí)間后,因?yàn)楦鞣N原因需要調(diào)整啟動(dòng)參數(shù)的情況,這篇文章主要介紹了如何修改 docker 容器的啟動(dòng)參數(shù),需要的朋友可以參考下
    2023-09-09
  • Docker v1.13 新功能介紹

    Docker v1.13 新功能介紹

    本篇文章主要介紹了Docker v1.13 新功能介紹,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2017-02-02
  • Docker通過(guò)容器生成鏡像提交DockerCommit詳解

    Docker通過(guò)容器生成鏡像提交DockerCommit詳解

    這篇文章主要介紹了Docker通過(guò)容器生成鏡像提交DockerCommit的詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步早日升職加薪
    2021-09-09

最新評(píng)論