日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

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

瀏覽:231日期:2023-10-18 09:48:47

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

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

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

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

Dockerfile

FROM python:3.6.8ENV PYTHONUNBUFFERED 1RUN mkdir -p /codeCOPY ./requirements.txt /codeWORKDIR /codeRUN sed -i 's/archive.ubuntu./mirrors.aliyun./g' /etc/apt/sources.listRUN sed -i 's/deb.debian.org/mirrors.aliyun.com/g' /etc/apt/sources.listRUN apt-get clean && apt-get -y update && apt-get -y install libsasl2-dev python-dev libldap2-dev libssl-dev libsnmp-devRUN pip3 install --index-url https://mirrors.aliyun.com/pypi/simple/ --no-cache-dir -r requirements.txtCOPY ./* /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.11mysqlclient==1.4.6

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

Django settingsDATABASES = { ’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內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: MySQL 數據庫
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
六月婷婷一区| 久久婷婷亚洲| 亚洲青青久久| 亚洲丝袜美腿一区| 中文字幕免费一区二区| 日韩中文字幕一区二区高清99| 综合精品一区| 日韩国产欧美三级| 国产精品qvod| 91欧美在线| 国内精品99| 欧美+亚洲+精品+三区| 蜜臀91精品国产高清在线观看| 在线精品视频在线观看高清| 久久国产精品99国产| 日本午夜精品一区二区三区电影 | 丝袜美腿一区二区三区| 综合色一区二区| 日韩高清国产一区在线| 国产极品嫩模在线观看91精品| 国语对白精品一区二区| 精品免费av在线| 好看的av在线不卡观看| 亚洲精选成人| 国产美女久久| 92国产精品| 快she精品国产999| 欧美日韩黄网站| 精品国产乱码久久久久久樱花 | 欧美精品羞羞答答| 在线一区二区三区视频| 国产欧美一区二区三区国产幕精品| 美女视频网站久久| 欧美日韩精品免费观看视欧美高清免费大片 | 日韩精品中文字幕吗一区二区 | 日韩av在线播放中文字幕| 欧美激情久久久久久久久久久| 97精品国产| 亚洲欧美日韩视频二区| 国产精品一区亚洲| 久久久国产精品一区二区中文| 快she精品国产999| 欧美成a人片免费观看久久五月天| 欧美不卡高清一区二区三区| 一级成人国产| 久久一区精品| 欧美日韩三区| 国产精一区二区| 欧美日韩在线网站| 日韩精品久久理论片| 成人精品久久| 蜜臀91精品一区二区三区| 国产精品久久久久久模特 | 免费日韩视频| 精品一区二区男人吃奶| 亚洲激情另类| 国产欧美日韩精品高清二区综合区| 中文字幕在线官网| 日本综合视频| 亚洲福利国产| 国产极品一区| 蜜桃视频在线观看一区| av在线最新| 日韩精选在线| 99精品视频精品精品视频| 日本天堂一区| 欧美亚洲国产激情| 国产高清视频一区二区| 国产精品人人爽人人做我的可爱| 你懂的亚洲视频| 丝袜美腿高跟呻吟高潮一区| 成人污污视频| 亚洲五月综合| 免费国产自久久久久三四区久久 | 老鸭窝一区二区久久精品| 免费在线观看成人| 日韩精品首页| 免费一级欧美片在线观看网站| 久久av一区| 久久国产免费| 久久精品午夜| 日本99精品| 视频一区免费在线观看| 日韩一区二区三区免费| 牛牛精品成人免费视频| 老牛国产精品一区的观看方式| 日韩一区二区三区免费播放| 久久超级碰碰| 日韩激情精品| 蜜臀久久99精品久久久久宅男| 天堂网av成人| 国产在线观看www| 久久精品午夜| 国产精区一区二区| 日本在线不卡视频一二三区| 亚洲在线免费| 好吊视频一区二区三区四区| 亚洲一级少妇| 欧美激情国产在线| 九九久久国产| 国产亚洲人成a在线v网站 | 国产精品最新| 91亚洲精品视频在线观看| 亚洲一二av| 免费久久精品视频| 9色国产精品| 99亚洲视频| 午夜久久久久| 91高清一区| 亚洲精品网址| 亚洲国产成人精品女人| 免费观看久久av| 蜜桃成人av| 欧美日韩中文字幕一区二区三区| 国产精品原创| 亚洲黄色中文字幕| 黑人精品一区| 国产 日韩 欧美一区| 欧美aa一级| 久久久久国产精品一区二区| 亚洲一区资源| 欧美日韩免费观看视频| 日本欧美不卡| 久久高清精品| 热久久免费视频| 亚洲午夜国产成人| 综合一区av| 日韩精品欧美大片| 日韩黄色在线观看| 偷拍亚洲精品| 日本欧美一区| 国产日韩精品视频一区二区三区| 日韩三级一区| 日韩超碰人人爽人人做人人添| 91精品丝袜国产高跟在线| 国产免费久久| 三上亚洲一区二区| 99久久激情| 香蕉视频成人在线观看| 日韩一区二区三区高清在线观看 | 国产精品久久久久久久久久妞妞| 久久永久免费| 激情不卡一区二区三区视频在线| 日韩欧美三级| 在线亚洲自拍| 一区二区91| 国产精品www.| 日韩成人三级| 国产婷婷精品| 欧美片第1页综合| 狠狠久久伊人| 五月天综合网站| 青青伊人久久| 欧美国产小视频| 国产亚洲网站| 国产日韩一区二区三区在线| 精品国产精品国产偷麻豆| 97精品国产福利一区二区三区| 欧美亚洲精品在线| 亚洲日产av中文字幕| 久久精品亚洲| 亚洲国产一区二区三区在线播放| 免费精品视频最新在线| 国产精品宾馆| 久久精品国产99久久| 亚洲免费影院| 国产探花一区在线观看| 日韩在线不卡| 午夜精品福利影院| 国产999精品在线观看| 欧美日韩国产精品一区二区亚洲| 日韩高清电影免费| 欧美国产精品| 欧美成人综合| 日韩成人在线看| 欧美成人a交片免费看| 久久福利毛片| 精品国产美女a久久9999| 午夜欧美在线| 国产精品国产三级在线观看| 免费毛片在线不卡| 国产精品中文字幕亚洲欧美 | 亚洲精品福利| 伊人网在线播放| 在线精品观看| 日韩电影在线视频| 日韩av一区二区在线影视| se01亚洲视频| 欧美日韩一区二区三区四区在线观看 | 97久久亚洲| 91精品国产成人观看| 亚洲开心激情| 久久中文字幕av一区二区不卡| 91精品美女| 欧美日韩国产传媒| 久久久亚洲欧洲日产| 蜜桃久久av一区| 久久久久久色| 亚洲激情不卡| 国产精品久久观看|