人妖在线一区,国产日韩欧美一区二区综合在线,国产啪精品视频网站免费,欧美内射深插日本少妇

新聞動(dòng)態(tài)

centos8使用Docker部署Django項(xiàng)目的詳細(xì)教程

發(fā)布日期:2022-02-04 17:55 | 文章來(lái)源:站長(zhǎng)之家

引言

在本文中將介紹在Docker中通過(guò)django + uwsgi + nginx部署方式部署Django項(xiàng)目,

由于記錄的是學(xué)習(xí)過(guò)程,使用的都是目前較高的版本。

python 版本為3.8.3
django 版本為3.0.6
nginx 版本為1.17.10

好了簡(jiǎn)單的介紹之后,就進(jìn)入正題了。

創(chuàng)建一個(gè)工作目錄

創(chuàng)建一個(gè)工作目錄用來(lái)存放項(xiàng)目,和Dockerfile等文件。

mkdir uwsgidocker

簡(jiǎn)單說(shuō)明一下各個(gè)文件

docker-compose.yml: Docker Compose是 docker 提供的一個(gè)命令行工具,用來(lái)定義和運(yùn)行由多個(gè)容器組成的應(yīng)用。
            使用 compose,我們可以通過(guò) YAML 文件聲明式的定義應(yīng)用程序的各個(gè)服務(wù),并由單個(gè)命令完成應(yīng)用的創(chuàng)建和啟動(dòng)。
            在一開(kāi)始我沒(méi)有使用docker-compose.yml
Dockerfile:      是一個(gè)用來(lái)構(gòu)建鏡像的文本文件,文本內(nèi)容包含了一條條構(gòu)建鏡像所需的指令和說(shuō)明。
my_django:     是一個(gè)剛創(chuàng)建的django項(xiàng)目,主要是將 ALLOWED_HOSTS = [] 改為 ALLOWED_HOSTS = ["*"] 
nginxconf:       是個(gè)包含nginx配置和創(chuàng)建nginx鏡像的Dockerfile文件的文件夾。
pip.conf:       是關(guān)于pip的配置,主要是用于pip加速下載的。
uwsgi_conf.ini: uwsgi的配置文件

注意:在django項(xiàng)目中的settings.py文件里,需要將 ALLOWED_HOSTS = [] 改為 ALLOWED_HOSTS = [ " * " ] 。

制作uwsgi鏡像

根據(jù)Dockerfile文件制作uwsgi的鏡像并運(yùn)行。

FROM python:3.8.3
# 創(chuàng)建目錄
RUN mkdir -p /usr/src/app
# 設(shè)置工作目錄
WORKDIR /usr/src/app
# 將pip.conf文件復(fù)制到/root/.pip/pip.conf
COPY pip.conf /root/.pip/pip.conf
# 更新pip
RUN pip install --upgrade pip
# 下載django和uwsgi 在一般項(xiàng)目中只需下載requirement.txt
RUN pip install django && pip install uwsgi
# 將當(dāng)前目錄下的文件全部復(fù)制過(guò)去,只有是復(fù)制項(xiàng)目,uwsgi配置文件
COPY . /usr/src/app/
# 在run的時(shí)候啟動(dòng)uwsgi
CMD uwsgi --ini uwsgi_conf.ini
# 暴露端口
EXPOSE 80 8080 8000 8888

uwsgi 配置文件, 官網(wǎng)

[uwsgi]
# 項(xiàng)目目錄,由于在當(dāng)前目錄,直接寫(xiě)就好了
chdir = my_django
# uwsgi的啟動(dòng)文件,在項(xiàng)目下的wsgi.py
module = my_django.wsgi
# 允許主線程存在(true)
master = true
# 進(jìn)程數(shù)
processes = 1
# 用于指定項(xiàng)目的運(yùn)行的端口,可以使用socket和http,我使用的是http便于查看
http = 0.0.0.0:8000
# socket = 0.0.0.0:8000
# http = 10.0.0.10:8000
# socket = 10.0.0.10:8008
# socket = /usr/src/app/my_django/uwsgi.sock
# 當(dāng)服務(wù)器退出的時(shí)候自動(dòng)清理環(huán)境,刪除unix socket文件和pid文件
vacuum = true

好了,有了著兩個(gè)文件就可以制作uwsgi鏡像了。執(zhí)行下面命令,就能生成鏡像了。

docker build -t myuwsgi ./

使用 docker images 查看鏡像

運(yùn)行uwsgi鏡像

既然鏡像已經(jīng)制作完成了,接下來(lái)就是運(yùn)行鏡像,在瀏覽器查看。

直接使用如下命令,暴露端口便于查看。

docker run --rm -it --name webuwsgi -p 8000:8000 myuwsgi

運(yùn)行結(jié)果

接下來(lái)就可以在瀏覽器訪問(wèn)了,輸入ip和端口進(jìn)行訪問(wèn) 192.168.56.102:8000

這就證明uwsgi鏡像制作完成,并能成功運(yùn)行。

接下來(lái)就是制作nginx鏡像,用于反向代理

制作Nginx鏡像

首先進(jìn)入nginxconf目錄, cd nginxconf/ 便于操作,然后編輯Dockerfile文件

FROM nginx
# 刪除默認(rèn)的nginx配置文件
RUN rm -rf /etc/nginx/conf.d/default.conf
# 將當(dāng)前目錄下的配置文件拷貝到/etc/nginx/conf.d/目錄下
COPY nginx.conf /etc/nginx/conf.d/nginx.conf
EXPOSE 80

編輯nginx.conf文件

server {
 # 監(jiān)聽(tīng)端口
 listen 80;
 # 主機(jī)名
 server_name localhost;
 location / {
 include uwsgi_params;
 # uwsgi服務(wù)的ip與端口,
 proxy_pass http://192.167.0.2:8000;
 # uwsgi使用socket時(shí)可直接使用
 # uwsgi_pass 192.167.0.2:8000;
 proxy_set_header X-Real-IP $remote_addr;
 proxy_set_header Host $host;
 proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
 }
 
 location /static {
 # 靜態(tài)文件
 alias /usr/share/nginx/html/static;
 }
}

uwsgi容器的IP可以用docker inspect 容器名

docker inspect webuwsgi

查看

好了,接下來(lái)就是制作nginx鏡像了,使用如下命令,制作鏡像

docker build -t mynginx ./

使用 docker images 查看鏡像

運(yùn)行Nginx鏡像

既然鏡像已經(jīng)制作完成了,接下來(lái)就是運(yùn)行鏡像,然后在瀏覽器查看。

直接使用如下命令,暴露端口便于查看。

docker run --rm -it -p 80:80 --name nginxweb mynginx

運(yùn)行結(jié)果

接下來(lái)就可以在瀏覽器訪問(wèn)了,輸入ip直接進(jìn)行訪問(wèn) 192.168.56.102

好了,這就是在docker上使用uwsgi+nginx部署django項(xiàng)目。

接下來(lái)我們使用uwsgi+nginx+docker-compose部署django項(xiàng)目。

使用Docker-compose

編輯docker-compose.yml文件,分配ip,并在nginx,uwsgi配置文件稍做修改就好了

docker-compose.yml文件

version: '3'
services:
version: '3'
services:
 uwsgi:
 build:
 context: ./
 image: uwsgi
 restart: always
 networks:
 django:
 ipv4_address: 10.0.0.10
 ports:
 - "8000:8000"
 volumes:
 - /root/uwsgidocker/:/usr/src/app/:rw
 command: uwsgi --ini /usr/src/app/uwsgi_conf.ini
 nginx:
 image: myweb
 build:
 context: ./nginxconf
 ports:
 - "80:80"
 - "8080:8080"
 volumes:
 - /root/uwsgidocker/nginxconf/nginx.conf:/etc/nginx/conf.d/nginx.conf:rw
 restart: always
 privileged: true
 networks:
 django:
 ipv4_address: 10.0.0.20
networks:
 django:
 ipam:
 config:
 - subnet: 10.0.0.0/24

uwsgi_conf.ini 文件,就是改一下ip

[uwsgi]
chdir = my_django
module = my_django.wsgi
uid = root
gid = root
master = true
processes = 1
# http = 0.0.0.0:8000
# socket = 0.0.0.0:8000
# http = 10.0.0.10:8000
socket = 10.0.0.10:8008
# socket = /usr/src/app/my_django/uwsgi.sock
vacuum = true

nginx.conf文件,同理,更改ip

server {
 listen 80;
 server_name localhost;
 location / {
 include uwsgi_params;
 # proxy_pass http://192.167.0.2:8000;
 # uwsgi_pass 192.167.0.2:8000;
 # proxy_set_header Host $host;
 # proxy_redirect off;
 # proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
 # uwsgi_pass unix:/usr/src/app/my_django/uwsgi.sock;
 uwsgi_pass 10.0.0.10:8008;
 proxy_set_header X-Real-IP $remote_addr;
 proxy_set_header Host $host;
 proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
 }
 location /static {
 alias /usr/share/nginx/html/static;
 }
}

好了,將配置稍作修改之后,就可以直接運(yùn)行了

docker-compose運(yùn)行

1.啟動(dòng)-構(gòu)建鏡像&&啟動(dòng)容器

docker-compose up 或者 docker-compose up -d 后臺(tái)運(yùn)行

2.停止

docker-compose stop #停止容器的運(yùn)行

3.停止并刪除容器

docker-compose down

4.輸入IP,進(jìn)行訪問(wèn),結(jié)果

是不是發(fā)現(xiàn)使用docker-compose特別方便啊,在此我也推薦大家使用這個(gè)哦!

總結(jié)

到此這篇關(guān)于centos8使用Docker部署Django項(xiàng)目的詳細(xì)教程的文章就介紹到這了,更多相關(guān)docker部署django項(xiàng)目?jī)?nèi)容請(qǐng)搜索本站以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持本站!

美國(guó)服務(wù)器租用

版權(quán)聲明:本站文章來(lái)源標(biāo)注為YINGSOO的內(nèi)容版權(quán)均為本站所有,歡迎引用、轉(zhuǎn)載,請(qǐng)保持原文完整并注明來(lái)源及原文鏈接。禁止復(fù)制或仿造本網(wǎng)站,禁止在非www.sddonglingsh.com所屬的服務(wù)器上建立鏡像,否則將依法追究法律責(zé)任。本站部分內(nèi)容來(lái)源于網(wǎng)友推薦、互聯(lián)網(wǎng)收集整理而來(lái),僅供學(xué)習(xí)參考,不代表本站立場(chǎng),如有內(nèi)容涉嫌侵權(quán),請(qǐng)聯(lián)系alex-e#qq.com處理。

相關(guān)文章

實(shí)時(shí)開(kāi)通

自選配置、實(shí)時(shí)開(kāi)通

免備案

全球線路精選!

全天候客戶服務(wù)

7x24全年不間斷在線

專屬顧問(wèn)服務(wù)

1對(duì)1客戶咨詢顧問(wèn)

在線
客服

在線客服:7*24小時(shí)在線

客服
熱線

400-630-3752
7*24小時(shí)客服服務(wù)熱線

關(guān)注
微信

關(guān)注官方微信
頂部