欧美阿v视频在线大全_亚洲欧美中文日韩V在线观看_www性欧美日韩欧美91_亚洲欧美日韩久久精品

主頁 > 知識庫 > 詳解如何使用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開發環境的相關信息資訊供網民參考!
  • 推薦文章
    欧美阿v视频在线大全_亚洲欧美中文日韩V在线观看_www性欧美日韩欧美91_亚洲欧美日韩久久精品
  • <rt id="w000q"><acronym id="w000q"></acronym></rt>
  • <abbr id="w000q"></abbr>
    <rt id="w000q"></rt>
    成人av在线一区二区| 欧美高清www午色夜在线视频| ww久久中文字幕| 日韩成人免费在线| 国产精品无码专区| 欧美一区二区高清| 日韩电影一区二区三区四区| 国产xxxxxxxxx| 日韩一级片在线观看| 人人狠狠综合久久亚洲| 精品无码人妻少妇久久久久久| 欧美老女人第四色| 日韩一区精品视频| 可以直接看的无码av| 欧美电视剧在线观看完整版| 日韩vs国产vs欧美| 亚洲色成人网站www永久四虎| 欧美精品一区视频| 国产麻豆精品一区二区| 少妇高潮在线观看| 亚洲女与黑人做爰| 2018国产精品| 日韩欧美成人激情| 国产裸体歌舞团一区二区| 久久精品一区二区三区四区五区| 中文字幕一区二区三区在线不卡| av成人免费在线观看| 欧美久久久久久蜜桃| 免费在线观看一区| 成人三级视频在线观看| 综合久久国产九一剧情麻豆| 性折磨bdsm欧美激情另类| 欧美一区二区三级| 国产一区二区三区免费观看| 亚洲综合视频网站| 亚洲国产aⅴ天堂久久| 香蕉网在线播放| 国产性色一区二区| 91视频你懂的| 日韩免费观看2025年上映的电影| 国产一区二区三区精品欧美日韩一区二区三区 | 性活交片大全免费看| 欧美电视剧免费观看| 国产成人av电影在线观看| 在线观看一区二区精品视频| 日韩不卡手机在线v区| 操她视频在线观看| 一片黄亚洲嫩模| 久久av无码精品人妻系列试探| 国产精品污www在线观看| 无码国产精品久久一区免费| 精品福利一二区| 99国产精品国产精品毛片| 日韩一级大片在线| 成人午夜视频福利| 91精品国产欧美一区二区| 国产精品69久久久久水密桃| 精品婷婷伊人一区三区三| 久草精品在线观看| 欧美在线free| 极品尤物av久久免费看| 在线观看91精品国产入口| 裸体在线国模精品偷拍| 色香蕉久久蜜桃| 久久精品国产精品亚洲红杏| 色婷婷激情综合| 久久精品国内一区二区三区| 色老汉一区二区三区| 精品在线播放午夜| 欧美日韩国产小视频| 国产不卡在线一区| 欧美一区二区免费观在线| 成人精品一区二区三区四区| 日韩美女一区二区三区| 91在线一区二区| 国产亚洲自拍一区| 亚洲图片欧美另类| 国产精品久久久久久久久免费丝袜| 一本加勒比波多野结衣| 亚洲天堂av一区| 国产又粗又猛又爽又黄的视频四季 | 国产成人精品一区二区在线小狼| 久久久久久夜精品精品免费| 久久无码专区国产精品s| 国产亚洲美州欧州综合国| 国产xxxx视频| 亚洲精品视频在线| 国产精品视频看看| 美国精品在线观看| 欧美剧情片在线观看| av电影在线观看一区| 国产亚洲欧美日韩日本| 性欧美丰满熟妇xxxx性仙踪林| 一区二区三区在线免费观看| 午夜激情福利网| 国内成人免费视频| 欧美va日韩va| 波多野结衣影院| 亚洲一区在线观看免费| 午夜少妇久久久久久久久| 国产黄色精品网站| 久久久久久**毛片大全| 波多野结衣 在线| 婷婷激情综合网| 欧美日本不卡视频| 69久久精品无码一区二区| 亚洲色图制服诱惑| 欧美三级在线免费观看| 高清不卡在线观看av| 国产女主播一区| 国产aaaaaaaaa| 国产乱码精品1区2区3区| 久久亚洲影视婷婷| 在线免费观看日韩av| 日本免费新一区视频| 日韩一级大片在线| www.超碰97| 免费成人在线观看视频| 日韩欧美久久一区| 无码人妻精品一区二区三应用大全| 五月天一区二区三区| 91精品国产综合久久国产大片| 911亚洲精选| 亚洲超碰精品一区二区| 欧美日韩在线综合| 精品人妻在线视频| 天天亚洲美女在线视频| 欧美一级二级三级蜜桃| 国产精品无码一区二区三区免费| 热久久国产精品| 欧美精品一区二区三区在线播放 | 亚洲国产精品自拍| 8x福利精品第一导航| 亚洲男人在线天堂| 蜜臀av一区二区在线观看| 亚洲精品一区二区三区四区高清| 青青草自拍偷拍| 国产91精品露脸国语对白| 亚洲同性同志一二三专区| 日本韩国视频一区二区| 少妇献身老头系列| 日本va欧美va欧美va精品| 欧美精品一区二区三区蜜桃| jizz日本在线播放| bt欧美亚洲午夜电影天堂| 亚洲影院久久精品| 日韩欧美在线一区二区三区| 久久久久久久久福利| 成人黄色小视频| 亚洲一区自拍偷拍| 欧美大胆人体bbbb| 日本午夜精品视频| 99re8在线精品视频免费播放| 亚洲丰满少妇videoshd| 精品久久国产字幕高潮| 欧洲美女女同性互添| 三级网站免费看| 日本欧美在线观看| 国产欧美日产一区| 欧美在线免费视屏| 久久久无码人妻精品一区| 国产一区激情在线| 亚洲激情图片一区| 欧美成人激情免费网| 国产少妇在线观看| 这里只有精品在线观看视频| 国精品**一区二区三区在线蜜桃| 136国产福利精品导航| 欧美一区二区在线观看| 无码人中文字幕| 无码人妻丰满熟妇啪啪网站| 久久精品久久99精品久久| 亚洲视频综合在线| 精品美女被调教视频大全网站| 日韩三级在线观看视频| 精品熟女一区二区三区| 国产乱码精品一区二区三区av | 日韩精品中文字幕在线一区| 亚洲人做受高潮| 亚洲啪av永久无码精品放毛片| 国产精一品亚洲二区在线视频| 亚洲综合色自拍一区| 久久夜色精品国产欧美乱极品| 在线观看日韩一区| 超薄肉色丝袜一二三| 久久发布国产伦子伦精品| 黑人精品欧美一区二区蜜桃| 亚洲综合激情另类小说区| 久久久亚洲精品石原莉奈| 欧美日韩一区三区四区| 福利视频第一页| 欧美精品黑人猛交高潮| 91视视频在线直接观看在线看网页在线看| 美女一区二区三区在线观看| 亚洲精品v日韩精品| 国产欧美日韩在线观看| 欧美一区二区三区四区高清| 91aaa在线观看| 国产传媒在线看| 丰满少妇一区二区三区|