校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃

主頁 > 知識庫 > 詳解如何使用Docker部署Django+MySQL8開發環境

詳解如何使用Docker部署Django+MySQL8開發環境

熱門標簽:重慶營銷外呼系統排名 地圖標注企業名稱侵權案件 地圖標注需要現場嗎 400電話辦理哪家好廠商 網站上插入地圖標注內容 工廠位置地圖標注 繽客網注冊時地圖標注出不來 企業400電話辦理哪正規 鶴壁電銷外呼系統怎么安裝

前一段時間重裝了系統,然后我還沒有備份,導致電腦里的開發環境全都沒有了。

一想到又要裝 Python 環境,還要裝數據庫,然后安裝過程中還可能報一堆錯就頭疼。

最近正在學習 Docker,這不正好解決了我當前的痛點了嗎?而且,不止這次重裝系統,以后再重裝都不怕了,只要拿著 Dockerfile 和 docker-compose 文件,不管到什么環境,一條命令輕松跑起來。

之前部署 Python 開發環境,都是用的 virtualenv,或者是 Pipenv。這次使用 Docker 之后,對比下來,還是 Docker 更加方便,下面就來詳細介紹。

Dockerfile

FROM python:3.6.8

ENV PYTHONUNBUFFERED 1

RUN mkdir -p /code
COPY ./requirements.txt /code

WORKDIR /code

RUN sed -i "s/archive.ubuntu./mirrors.aliyun./g" /etc/apt/sources.list
RUN sed -i "s/deb.debian.org/mirrors.aliyun.com/g" /etc/apt/sources.list

RUN apt-get clean && apt-get -y update && \

 apt-get -y install libsasl2-dev python-dev libldap2-dev libssl-dev libsnmp-dev
RUN pip3 install --index-url https://mirrors.aliyun.com/pypi/simple/ --no-cache-dir -r requirements.txt

COPY ./* /code/

使用 Dockerfile 來創建鏡像,Python 版本是 3.6.8,將源代碼拷貝到容器中 /code 目錄。

docker-compose

version: '3'

services:
 web:
 build:
  context: .
  dockerfile: Dockerfile
 image: web
 container_name: web
 hostname: web
 restart: always
 command: python /code/manage.py runserver 0.0.0.0:8000
 volumes:
  - .:/web
 ports:
  - "8000:8000"
 depends_on:
  - mysql 

 mysql:
 image: mysql
 container_name: mysql
 hostname: mysql
 restart: always
 command: --default-authentication-plugin=mysql_native_password --mysqlx=0
 ports:
  - 3306:3306
 volumes:
  - ./db:/var/lib/mysql
 environment:
  - MYSQL_HOST=localhost 
  - MYSQL_PORT=3306 
  - MYSQL_DATABASE=dev
  - MYSQL_USER=dev
  - MYSQL_PASSWORD=123456
  - MYSQL_ROOT_PASSWORD=123456

使用 docker-compose 來編排容器,一共啟兩個服務,web 服務就是后臺的 Django 服務,mysql 是數據庫服務。

有三點需要注意:

  • web 服務使用 depends_on 命令,表示依賴于 mysql 服務。
  • mysql 服務一定要加 --default-authentication-plugin=mysql_native_password 命令。因為從 MySQL 8.0 開始,默認的加密規則使用的是 caching_sha2_password,而我們的客戶端并不支持。之前使用的是 mysql_native_password。
  • 使用 volumes 來持久化數據,否則容器刪除之后,數據就都丟了。

requirements

Django==2.2.11
mysqlclient==1.4.6

啟動 Django 需要的 pip 包,Django 版本至少要 2.0,否則會報錯。

Django settings
DATABASES = {
 'default': {
  'ENGINE': 'django.db.backends.mysql',
  'NAME': 'dev',
  'USER': 'dev',
  'PASSWORD': '123456',
  'HOST': 'mysql',
  'PORT': '3306'
 }
}

在 Django settings 文件中配置數據庫信息,內容需要與 docker-compose 中一致。

有一點需要注意,HOST 一定要配置成 docker-compose 中的服務名稱,在我這里是 mysql。配置成其他,比如 localhost 或者 127.0.0.1 會報錯。

因為 Docker 啟動時會設置一個本地網絡,可以將 mysql 解析到對應服務的容器,而對應的服務并不在 localhost 上。

Run

使用如下命令創建鏡像。

$ docker-compose -f ./docker-compose.yml build

也可以省略上一步,直接使用如下命令啟動服務,如果沒有鏡像,會先創建鏡像,然后再啟動服務。

$ docker-compose -f ./docker-compose.yml up

排錯

在部署過程中,可能會碰到如下這些錯誤,基本都是配置錯誤造成的。如果發生了,一定要仔細檢查配置,只要和文中相同,是不會有問題的。

  • 'Plugin caching_sha2_password could not be loaded: /usr/lib/x86_64-linux-gnu/mariadb19/plugin/caching_sha2_password.so: cannot open shared object file: No such file or directory'
  • django.core.exceptions.ImproperlyConfigured: Error loading MySQLdb module.
  • django.db.utils.OperationalError: (2002, "Can't connect to MySQL server on 'db' (115)")
  • django.db.utils.OperationalError: (2002, "Can't connect to local MySQL server through socket '/var/run/mysqld/mysqld.sock' (2)")
  • django.db.utils.OperationalError: (2002, "Can't connect to MySQL server on '127.0.0.1' (115)")
  • django.db.utils.OperationalError: (2002, "Can't connect to local MySQL server through socket '/var/run/mysqld/mysqld.sock' (2)")

我還遇到一個比較坑的問題是這個:

[Warning] root@localhost is created with an empty password ! Please consider switching off the --initialize-insecure option.

我以為是我的密碼設置不正確,檢查了好久都沒發現問題,后來在網上找到了解釋,直接忽略就行了。

That is just a warning printed by during database file initialization (mysqld --initialize-insecure). The root user with password is created later while the database is listening only on the unix socket.

參考文檔:

http://fusionblender.net/django-and-mysql-8-using-docker/
https://github.com/docker-library/mysql/issues/307…
https://www.jianshu.com/p/4eafa4f87fd5

到此這篇關于詳解如何使用Docker部署Django+MySQL8開發環境的文章就介紹到這了,更多相關Docker部署Django+MySQL8內容請搜索腳本之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持腳本之家!

標簽:日照 渭南 96 克拉瑪依 棗莊 常州 鹽城 東莞

巨人網絡通訊聲明:本文標題《詳解如何使用Docker部署Django+MySQL8開發環境》,本文關鍵詞  詳解,如何,使用,Docker,部署,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《詳解如何使用Docker部署Django+MySQL8開發環境》相關的同類信息!
  • 本頁收集關于詳解如何使用Docker部署Django+MySQL8開發環境的相關信息資訊供網民參考!
  • 推薦文章
    校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃
    色综合久久天天综合网| 91福利在线免费观看| a4yy欧美一区二区三区| 国产日韩欧美不卡在线| 成人国产免费视频| 国产精品乱码一区二区三区软件| 高清不卡在线观看| 亚洲卡通动漫在线| 欧美另类z0zxhd电影| 久久成人免费网站| 国产女主播在线一区二区| 99精品视频在线免费观看| 亚洲一区二区四区蜜桃| 日韩美女在线视频| 99久久久国产精品免费蜜臀| 五月激情综合婷婷| 国产人成一区二区三区影院| 欧美伊人久久大香线蕉综合69| 日韩va亚洲va欧美va久久| 国产亚洲成aⅴ人片在线观看| 日本丰满少妇一区二区三区| 久久国产精品无码网站| 亚洲人成在线观看一区二区| 精品久久久久久久人人人人传媒| 不卡的av中国片| 美女国产一区二区| 一区二区理论电影在线观看| 久久婷婷国产综合国色天香| 欧美日韩一区二区在线观看| 本田岬高潮一区二区三区| 麻豆成人久久精品二区三区红| 18涩涩午夜精品.www| 精品国产伦一区二区三区观看方式 | 欧美军同video69gay| 国产高清在线观看免费不卡| 日产国产欧美视频一区精品| 亚洲老妇xxxxxx| 国产精品不卡一区二区三区| 亚洲精品一区二区三区精华液| 欧洲精品中文字幕| 91网站黄www| 粉嫩aⅴ一区二区三区四区| 精品中文字幕一区二区小辣椒 | 一本色道综合亚洲| 成人在线综合网| 国产精品69久久久久水密桃| 免费看精品久久片| 日本一不卡视频| 亚洲电影中文字幕在线观看| 一区二区三区精品视频| 亚洲摸摸操操av| 一区二区三区视频在线看| 亚洲男帅同性gay1069| 亚洲精品成人天堂一二三| 1区2区3区精品视频| 成人免费在线播放视频| 亚洲女人的天堂| 亚洲综合激情网| 午夜精品免费在线| 免费在线观看日韩欧美| 老司机午夜精品| 国产盗摄一区二区三区| 不卡一区二区三区四区| 91欧美激情一区二区三区成人| 99精品在线免费| 在线观看亚洲精品| 91精品国产一区二区| 精品成人在线观看| 国产精品看片你懂得| 久久久美女毛片| 亚洲国产高清在线| 夜夜嗨av一区二区三区中文字幕| 亚洲123区在线观看| 精品亚洲aⅴ乱码一区二区三区| 国产乱子轮精品视频| av一区二区三区| 欧美丰满一区二区免费视频| 久久男人中文字幕资源站| 亚洲四区在线观看| 免费观看成人av| 99久久久精品| 久久久蜜桃精品| 婷婷久久综合九色国产成人| 国产精品自在在线| 91国内精品野花午夜精品| 日韩美女天天操| 亚洲自拍偷拍综合| 国产成人免费在线观看| 欧美日韩色一区| 国产精品丝袜一区| 麻豆精品一区二区av白丝在线| av爱爱亚洲一区| 日韩免费观看高清完整版| 国产精品国产a| 日韩成人免费看| www.亚洲激情.com| 精品免费国产一区二区三区四区| 中文字幕一区二区三区在线播放| 亚洲国产综合在线| 成人a级免费电影| 欧美久久一二区| 国产精品三级久久久久三级| 日本伊人色综合网| 在线观看一区日韩| 国产精品国产自产拍在线| 另类调教123区| 欧美精选午夜久久久乱码6080| 中文字幕一区二区日韩精品绯色| 蓝色福利精品导航| 欧美一区二区久久久| 亚洲成人av在线电影| av高清久久久| 亚洲国产精品99久久久久久久久| 精品写真视频在线观看| 欧美大片免费久久精品三p| 午夜伦理一区二区| 欧美日韩在线不卡| 亚洲午夜精品在线| 91蜜桃免费观看视频| 中文字幕在线一区二区三区| 国产不卡高清在线观看视频| 久久精品日韩一区二区三区| 久久99国产精品久久| 欧美大胆人体bbbb| 激情六月婷婷综合| 久久久欧美精品sm网站| 国产精品 欧美精品| 中文字幕第一区第二区| 国产在线看一区| 日韩亚洲欧美成人一区| 日韩高清不卡一区二区| 这里只有精品99re| 精品亚洲成av人在线观看| 精品入口麻豆88视频| 国产乱码一区二区三区| 中文av一区特黄| 91影视在线播放| 亚洲一级二级三级在线免费观看| 欧美在线不卡视频| 视频一区国产视频| 日韩精品一区二区在线观看| 精品一区二区久久久| 国产欧美日韩精品一区| 91最新地址在线播放| 亚洲电影一区二区三区| 欧美二区三区的天堂| 久久国产精品99久久人人澡| 国产日韩欧美精品综合| 色综合久久久久综合体桃花网| 天堂va蜜桃一区二区三区 | 丁香亚洲综合激情啪啪综合| 国产精品高潮呻吟久久| 欧美午夜精品电影| 老司机免费视频一区二区三区| 中文字幕欧美日本乱码一线二线| 色综合天天综合网天天狠天天 | 国产精品毛片久久久久久| 日本乱码高清不卡字幕| 麻豆精品视频在线| 中文字幕制服丝袜一区二区三区 | 欧美日韩精品是欧美日韩精品| 日日摸夜夜添夜夜添精品视频| 日韩精品专区在线| 国产在线精品不卡| 亚洲精品亚洲人成人网| 久久尤物电影视频在线观看| 色综合天天视频在线观看 | 色国产综合视频| 激情小说欧美图片| 亚洲在线成人精品| 国产丝袜在线精品| 91精品国产综合久久久久| 成人激情黄色小说| 蜜乳av一区二区| 中文字幕在线观看不卡| 日韩精品一区二区三区在线播放| 成人av免费在线| 久久国产尿小便嘘嘘尿| 亚洲欧美日韩久久精品| 中文字幕精品综合| 欧美不卡在线视频| 欧美日韩国产片| 99精品热视频| 国产盗摄女厕一区二区三区| 日本aⅴ精品一区二区三区 | 亚洲高清视频中文字幕| 《视频一区视频二区| 久久久精品2019中文字幕之3| 欧美在线你懂得| 91在线免费播放| 国产美女精品一区二区三区| 三级成人在线视频| 亚洲成人资源网| 悠悠色在线精品| 亚洲嫩草精品久久| 一区二区中文字幕在线| 国产色婷婷亚洲99精品小说| 久久久午夜精品| 久久精品夜色噜噜亚洲aⅴ| 日韩一区二区三区在线|