Dockerを使用してDjango+MySQL8開発環境をデプロイする方法の詳細な説明

Dockerを使用してDjango+MySQL8開発環境をデプロイする方法の詳細な説明

しばらく前にシステムを再インストールしましたが、バックアップを取っていなかったので、コンピューター上の開発環境がすべて消えてしまいました。

Python 環境とデータベースのインストールを考えるのは頭の痛い作業ですし、インストール プロセス中にエラーが多数発生する可能性もあります。

現在、Docker を学習中です。これで現在の問題点が解決されるのではないでしょうか?また、今回だけでなく、将来的にも再インストールの心配はありません。Dockerfileとdocker-composeファイルさえあれば、どんな環境でもコマンド1つで簡単に実行できます。

以前は、Python 開発環境は virtualenv または Pipenv を使用してデプロイされていました。今回Dockerを使ってみて、Dockerの方が便利だということが分かりました。以下で詳しく紹介させていただきます。

Dockerファイル

Python:3.6.8 から

環境変数 PYTHONUNBUFFERED 1

mkdir -p /code を実行
コピー ./requirements.txt /code

WORKDIR /コード

sed -i "s/archive.ubuntu./mirrors.aliyun./g" /etc/apt/sources.listを実行します。
sed -i "s/deb.debian.org/mirrors.aliyun.com/g" /etc/apt/sources.list を実行します。

apt-get clean && apt-get -y update && \ を実行します。
 apt-get -y で libsasl2-dev 、 python-dev 、 libldap2-dev 、 libssl-dev 、 libsnmp-dev をインストールします。
pip3 install --index-url https://mirrors.aliyun.com/pypi/simple/ --no-cache-dir -r requirements.txt を実行します。

コピー ./* /code/

Dockerfile を使用してイメージを作成し、Python バージョンは 3.6.8 で、ソース コードをコンテナー内の /code ディレクトリにコピーします。

docker-compose

バージョン: '3'

サービス:
 ウェブ:
 建てる:
  コンテクスト: 。
  dockerfile: Dockerファイル
 画像: ウェブ
 コンテナ名: ウェブ
 ホスト名: web
 再起動: 常に
 コマンド: python /code/manage.py runserver 0.0.0.0:8000
 ボリューム:
  - .:/ウェブ
 ポート:
  - 「8000:8000」
 依存:
  -MySQLについて 

 マイスク:
 画像: mysql
 コンテナ名: mysql
 ホスト名:mysql
 再起動: 常に
 コマンド: --default-authentication-plugin=mysql_native_password --mysqlx=0
 ポート:
  -3306:3306
 ボリューム:
  - ./db:/var/lib/mysql
 環境:
  -MYSQL_HOST=ローカルホスト 
  -MYSQL_PORT=3306 
  -MYSQL_DATABASE=デバイス
  -MYSQL_USER=デバイス
  -MYSQL_パスワード=123456
  -MYSQL_ROOT_PASSWORD=123456

docker-compose を使用してコンテナをオーケストレーションし、合計 2 つのサービスを開始します。Web サービスはバックグラウンドの Django サービスであり、mysql はデータベース サービスです。

注意すべき点は3つあります。

  • Web サービスは、depends_on コマンドを使用して、mysql サービスに依存していることを示します。
  • mysql サービスは --default-authentication-plugin=mysql_native_password コマンドを追加する必要があります。 MySQL 8.0 以降では、デフォルトの暗号化ルールで caching_sha2_password が使用されていますが、これはクライアントではサポートされていません。以前は、mysql_native_password が使用されていました。
  • ボリュームを使用してデータを永続化します。そうしないと、コンテナーが削除された後にデータが失われます。

要件

ジャンゴ==2.2.11
mysqlクライアント==1.4.6

Django に必要な pip パッケージを起動します。Django のバージョンは少なくとも 2.0 である必要があります。そうでない場合はエラーが報告されます。

Djangoの設定
データベース = {
 'デフォルト': {
  'エンジン': 'django.db.backends.mysql',
  '名前': 'dev',
  'ユーザー': 'dev',
  'パスワード': '123456',
  'ホスト': 'mysql',
  'ポート': '3306'
 }
}

Django 設定ファイルでデータベース情報を設定します。内容は docker-compose の内容と一致している必要があります。

注意すべき点は、HOST を docker-compose のサービス名として設定する必要があることです。私の場合は mysql です。 localhost や 127.0.0.1 などの他の値に設定すると、エラーが報告されます。

Docker は起動時にローカル ネットワークを設定するため、mysql を対応するサービスのコンテナーに解決できますが、対応するサービスは localhost 上にありません。

走る

ミラーを作成するには、次のコマンドを使用します。

$ docker-compose -f ./docker-compose.yml ビルド

前の手順をスキップして、次のコマンドを使用してサービスを直接開始することもできます。イメージがない場合は、最初にイメージが作成されてからサービスが開始されます。

$ docker-compose -f ./docker-compose.yml を起動します

トラブルシューティング

展開プロセス中に、基本的に構成エラーによって発生する次のエラーが発生する可能性があります。このような場合は、設定をよく確認してください。記事と同じであれば問題ありません。

  • 'プラグイン caching_sha2_password をロードできませんでした: /usr/lib/x86_64-linux-gnu/mariadb19/plugin/caching_sha2_password.so: 共有オブジェクト ファイルを開けません: そのようなファイルまたはディレクトリはありません'
  • django.core.exceptions.ImproperlyConfigured: MySQLdb モジュールの読み込み中にエラーが発生しました。
  • django.db.utils.OperationalError: (2002、「'db' の MySQL サーバーに接続できません (115)」)
  • django.db.utils.OperationalError: (2002、「ソケット '/var/run/mysqld/mysqld.sock' を介してローカル MySQL サーバーに接続できません (2)」)
  • django.db.utils.OperationalError: (2002、「'127.0.0.1' の MySQL サーバーに接続できません (115)」)
  • django.db.utils.OperationalError: (2002、「ソケット '/var/run/mysqld/mysqld.sock' を介してローカル MySQL サーバーに接続できません (2)」)

さらに難しい問題にも遭遇しました。

[警告] root@localhost は空のパスワードで作成されています。--initialize-insecure オプションをオフにすることを検討してください。

パスワードが間違って設定されていると思い、長い間確認しましたが、問題は見つかりませんでした。後でオンラインで説明を見つけたので、無視することにしました。

これは、データベース ファイルの初期化 (mysqld --initialize-insecure) 中に表示される警告です。パスワード付きの root ユーザーは、データベースが Unix ソケットのみでリッスンしているときに後で作成されます。

参考資料:

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 開発環境をデプロイする方法についての記事はこれで終わりです。Django+MySQL8 の Docker デプロイに関するより関連性の高いコンテンツについては、123WORDPRESS.COM の以前の記事を検索するか、以下の関連記事を引き続き参照してください。今後とも 123WORDPRESS.COM をよろしくお願いいたします。

以下もご興味があるかもしれません:
  • MySQL8 ベースの docker-compose デプロイメント プロジェクトの実装
  • Dockerを使用してMySQL 8.0をデプロイする方法の例
  • DockerにMySQL 8.0をインストールする方法
  • MySQL 5.7 の Docker バージョンを MySQL 8.0.13 にアップグレードし、データを移行する
  • DockerにMySQL8をインストールする方法
  • Docker デプロイメント MySQL8 クラスター (マスター 1 台とスレーブ 2 台) の実装手順

<<:  MySQL統計テーブルのサイズを説明する例

>>:  mysql データはどこに保存されますか?

推薦する

MySql5.x を MySql8.x にアップグレードする方法と手順

MySQL 5.x と MySQL 8.0.X のいくつかの違いapplication.proper...

Django+vue 登録とログインのサンプルコード

登録するフロントエンドは、vue の axios を使用して値を渡し、取得したアカウントとパスワード...

CSSは、他のレイヤーを変更せずに、多層ネスト構造の最外層を回転させる効果を実現します。

次のようなシナリオがあります。円形のコンテナで、最も外側のコンテナの背景が円弧になっています。内側の...

Layuiテーブルは指定された行のラジオボタンを選択し、その行の実装コードまでスクロールします。

layui テーブルには複数行のデータがあります。外部入力コンテンツを通じて、指定された行を見つけ...

Echart Bar の 2 列チャート スタイルの最も完全な詳細な説明

目次序文インストールと設定1. Echartsをインストールする2. Echartsをグローバルに導...

iframe に関するいくつかの発見と考察

この物語は、今日の予期せぬ発見から始まります。同社には複数のウェブサイトがある。友達リンクにはお互い...

フロントエンドJavaScriptの動作原理

目次1. JavaScript エンジンとは何ですか? 2. V8エンジン3. ランタイム環境4. ...

GitHub のサードパーティ認証方式を Vue で実装する例

目次OAuth アプリの作成コードを取得するaccess_tokenを取得するユーザー情報を取得する...

win2008R2 64 ビット システムでの mysql5.7.17 のインストールと構成の例

123WORDPRESS.COM では、さまざまな環境での MYSQL の他のバージョンのインストー...

Vue3スタイルのCSS変数注入の実装

目次まとめ基本的な例モチベーションデザインの詳細コンパイルの詳細採用戦略練習するヒント適切なプロパテ...

HTML でのメタタグと使用法の詳細な説明

これ以上無駄話をして時間を無駄にしないので、今日の話題を始めましょう。 HTML のメタタグ1. メ...

nginx+php実行リクエストの動作原理の詳細な説明

PHPの仕組みまず、よく耳にするcgi、php-cgi、fastcgi、php-fpmの関係を理解し...

Linuxのバージョン情報を復号化する方法

Linux バージョンに関する情報を表示および解釈するのは、見た目よりも少し複雑です。単純なバージョ...

Vue コード強調プラグインの総合的な比較と評価

目次総合的な比較アクティブの観点から機能的な観点から詳細な比較1. エース2. コードミラー3. モ...

a タグにはテキストと画像があります。テキストを非表示にして画像のみを表示するにはどうすればよいでしょうか?

多くの場合、画像を表示する<a>タグのスタイルに遭遇しますが、タグ内にテキストがあり、そ...