您好,登錄后才能下訂單哦!
這篇文章主要講解了“Docker化Python Django應(yīng)用程序的方法”,文中的講解內(nèi)容簡單清晰,易于學(xué)習(xí)與理解,下面請(qǐng)大家跟著小編的思路慢慢深入,一起來研究和學(xué)習(xí)“Docker化Python Django應(yīng)用程序的方法”吧!
步驟 1 - 安裝 docker-ce
在本教程中,我們將從 docker 倉庫安裝 docker-ce 社區(qū)版。我們將安裝 docker-ce 社區(qū)版和 docker-compose(其支持 compose 文件版本 3)。
在安裝 docker-ce 之前,先使用 apt 命令安裝所需的 docker 依賴項(xiàng)。
sudo apt install -y apt-transport-https ca-certificates curl software-properties-common
現(xiàn)在通過運(yùn)行以下命令添加 docker 密鑰和倉庫。
curl -fssl https://download.docker.com/linux/ubuntu/gpg | sudo apt-key add - sudo add-apt-repository "deb [arch=amd64] https://download.docker.com/linux/ubuntu $(lsb_release -cs) stable"
安裝 docker-ce
更新倉庫并安裝 docker-ce。
sudo apt update sudo apt install -y docker-ce
安裝完成后,啟動(dòng) docker 服務(wù)并使其能夠在每次系統(tǒng)引導(dǎo)時(shí)啟動(dòng)。
systemctl start docker systemctl enable docker
接著,我們將添加一個(gè)名為 omar 的新用戶并將其添加到 docker 組。
useradd -m -s /bin/bash omar usermod -a -g docker omar
啟動(dòng) docker
以 omar 用戶身份登錄并運(yùn)行 docker 命令,如下所示
su - omar docker run hello-world
確保你能從 docker 獲得 hello-world 消息
檢查 docker 安裝
docker-ce 安裝已經(jīng)完成。
步驟 2 - 安裝 docker-compose
在本教程中,我們將使用支持 compose 文件版本 3 的最新 docker-compose。我們將手動(dòng)安裝 docker-compose
使用 curl 命令將最新版本的 docker-compose 下載到 /usr/local/bin 目錄,并使用 chmod 命令使其有執(zhí)行權(quán)限。
運(yùn)行以下命令:
sudo curl -l https://github.com/docker/compose/releases/download/1.21.0/docker-compose-$(uname -s)-$(uname -m) -o /usr/local/bin/docker-compose sudo chmod +x /usr/local/bin/docker-compose
現(xiàn)在檢查 docker-compose 版本。
docker-compose version
確保你安裝的是最新版本的 docker-compose 1.21
安裝 docker-compose
已安裝支持 compose 文件版本 3 的 docker-compose 最新版本。
步驟 3 - 配置項(xiàng)目環(huán)境
在這一步中,我們將配置 python django 項(xiàng)目環(huán)境。我們將創(chuàng)建新目錄 guide01,并使其成為我們項(xiàng)目文件的主目錄,例如包括 dockerfile、django 項(xiàng)目、nginx 配置文件等。
登錄到 omar 用戶。
su - omar
創(chuàng)建一個(gè)新目錄 guide01,并進(jìn)入目錄。
mkdir -p guide01 cd guide01/
現(xiàn)在在 guide01 目錄下,創(chuàng)建兩個(gè)新目錄 project 和 config。
mkdir project/ config/
注意:
project 目錄:我們所有的 python django 項(xiàng)目文件都將放在該目錄中。
config 目錄:項(xiàng)目配置文件的目錄,包括 nginx 配置文件、python pip 的requirements.txt 文件等。
創(chuàng)建一個(gè)新的 requirements.txt 文件
接下來,使用 vim 命令在 config 目錄中創(chuàng)建一個(gè)新的 requirements.txt 文件。
vim config/requirements.txt
粘貼下面的配置:
django==2.0.4 gunicorn==19.7.0 psycopg2==2.7.4
保存并退出。
創(chuàng)建 nginx 虛擬主機(jī)文件 django.conf
在 config 目錄下創(chuàng)建 nginx 配置目錄并添加虛擬主機(jī)配置文件 django.conf。
mkdir -p config/nginx/ vim config/nginx/django.conf
粘貼下面的配置:
upstream web { ip_hash; server web:8000; } # portal server { location / { proxy_pass http://web/; } listen 8000; server_name localhost; location /static { autoindex on; alias /src/static/; } }
保存并退出。
創(chuàng)建 dockerfile
在 guide01 目錄下創(chuàng)建新文件 dockerfile。
運(yùn)行以下命令:
vim dockerfile
現(xiàn)在粘貼下面的 dockerfile 腳本:
from python:3.5-alpine env pythonunbuffered 1 run apk update && apk add --virtual build-deps gcc python-dev musl-dev && apk add postgresql-dev bash run mkdir /config add /config/requirements.txt /config/ run pip install -r /config/requirements.txt run mkdir /src workdir /src
保存并退出。
注意:
我們想要為我們的 django 項(xiàng)目構(gòu)建基于 alpine linux 的 docker 鏡像,alpine 是最小的 linux 版本。我們的 django 項(xiàng)目將運(yùn)行在帶有 python 3.5 的 alpine linux 上,并添加 postgresql-dev 包以支持 postgresql 數(shù)據(jù)庫。然后,我們將使用 python pip 命令安裝在 requirements.txt 上列出的所有 python 包,并為我們的項(xiàng)目創(chuàng)建新目錄 /src。
創(chuàng)建 docker-compose 腳本
使用 vim 命令在 guide01 目錄下創(chuàng)建 docker-compose.yml 文件。
vim docker-compose.yml
粘貼以下配置內(nèi)容:
version: '3' services: db: image: postgres:10.3-alpine container_name: postgres01 nginx: image: nginx:1.13-alpine container_name: nginx01 ports: - "8000:8000" volumes: - ./project:/src - ./config/nginx:/etc/nginx/conf.d depends_on: - web web: build: . container_name: django01 command: bash -c "python manage.py makemigrations && python manage.py migrate && python manage.py collectstatic --noinput && gunicorn hello_django.wsgi -b 0.0.0.0:8000" depends_on: - db volumes: - ./project:/src expose: - "8000" restart: always
保存并退出。
注意:
使用這個(gè) docker-compose 文件腳本,我們將創(chuàng)建三個(gè)服務(wù)。使用 alpine linux 版的 postgresql 創(chuàng)建名為 db 的數(shù)據(jù)庫服務(wù),再次使用 alpine linux 版的 nginx 創(chuàng)建 nginx 服務(wù),并使用從 dockerfile 生成的自定義 docker 鏡像創(chuàng)建我們的 python django 容器。
配置項(xiàng)目環(huán)境
配置 django 項(xiàng)目
將 django 項(xiàng)目文件復(fù)制到 project 目錄。
cd ~/django cp -r * ~/guide01/project/
進(jìn)入 project 目錄并編輯應(yīng)用程序設(shè)置 settings.py。
cd ~/guide01/project/ vim hello_django/settings.py
注意:
我們將部署名為 “hello_django” 的簡單 django 應(yīng)用程序。
在 allow_hosts 行中,添加服務(wù)名稱 web。
allow_hosts = ['web']
現(xiàn)在更改數(shù)據(jù)庫設(shè)置,我們將使用 postgresql 數(shù)據(jù)庫來運(yùn)行名為 db 的服務(wù),使用默認(rèn)用戶和密碼。
databases = { 'default': { 'engine': 'django.db.backends.postgresql_psycopg2', 'name': 'postgres', 'user': 'postgres', 'host': 'db', 'port': 5432, } }
至于 static_root 配置目錄,將此行添加到文件行的末尾。
static_root = os.path.join(base_dir, 'static/')
保存并退出。
配置 django 項(xiàng)目
現(xiàn)在我們準(zhǔn)備在 docker 容器下構(gòu)建和運(yùn)行 django 項(xiàng)目。
步驟 4 - 構(gòu)建并運(yùn)行 docker 鏡像
在這一步中,我們想要使用 guide01 目錄中的配置為我們的 django 項(xiàng)目構(gòu)建一個(gè) docker 鏡像。
進(jìn)入 guide01 目錄。
cd ~/guide01/
現(xiàn)在使用 docker-compose 命令構(gòu)建 docker 鏡像。
docker-compose build
運(yùn)行 docker 鏡像
啟動(dòng) docker-compose 腳本中的所有服務(wù)。
docker-compose up -d
等待幾分鐘讓 docker 構(gòu)建我們的 python 鏡像并下載 nginx 和 postgresql docker 鏡像。
使用 docker-compose 構(gòu)建鏡像
完成后,使用以下命令檢查運(yùn)行容器并在系統(tǒng)上列出 docker 鏡像。
docker-compose ps docker-compose images
現(xiàn)在,你將在系統(tǒng)上運(yùn)行三個(gè)容器,列出 docker 鏡像,如下所示。
docke-compose ps 命令
我們的 python django 應(yīng)用程序現(xiàn)在在 docker 容器內(nèi)運(yùn)行,并且已經(jīng)創(chuàng)建了為我們服務(wù)的 docker 鏡像。
步驟 5 - 測(cè)試
打開 web 瀏覽器并使用端口 8000 鍵入服務(wù)器地址,我的是:。
現(xiàn)在你將看到默認(rèn)的 django 主頁。
默認(rèn) django 項(xiàng)目主頁
接下來,通過在 url 上添加 /admin 路徑來測(cè)試管理頁面。
然后你將會(huì)看到 django 管理登錄頁面。
感謝各位的閱讀,以上就是“Docker化Python Django應(yīng)用程序的方法”的內(nèi)容了,經(jīng)過本文的學(xué)習(xí)后,相信大家對(duì)Docker化Python Django應(yīng)用程序的方法這一問題有了更深刻的體會(huì),具體使用情況還需要大家實(shí)踐驗(yàn)證。這里是億速云,小編將為大家推送更多相關(guān)知識(shí)點(diǎn)的文章,歡迎關(guān)注!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請(qǐng)聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。