詳解如何使用Docker部署Django+MySQL8開發環境
前一段時間重裝了系統,然后我還沒有備份,導致電腦里的開發環境全都沒有了。
一想到又要裝 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內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!
相關文章:
1. MySQL收歸Oracle 開源數據庫或將很受傷2. Oracle災難防護的關鍵技術3. Mysql入門系列:安排預防性的維護MYSQL數據庫服務器4. Mysql入門系列:需要避免的MYSQL客戶機程序設計錯誤5. 啟動MYSQL出錯 Manager of pid-file quit without updating file.6. Mybatis數據批量插入如何實現7. 傳甲骨文將增加對MySQL投資與微軟競爭8. 整理Oracle數據庫碎片9. mysql啟動時報錯 ERROR! Manager of pid-file quit without10. 巧用SQL語言在ACCESS數據庫中批量替換內容
