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 データはどこに保存されますか?

推薦する

JavaScript のマクロタスクとマイクロタスクの詳細

目次1. マイクロタスクとは何ですか? 2. マクロタスクとは何ですか? 3. 事例3.1 結論4....

Jsモジュール化の動作原理とソリューションの詳細な説明

目次1. モジュラーコンセプト2. モジュール化3. モジュール化プロセス1. 通常の記述(グローバ...

nginx を使用したプロキシ サーバーの設定

Nginx は、リバース プロキシ機能を使用して負荷分散を実装できるほか、フォワード プロキシ機能を...

Linux C バックグラウンドサービスプログラムの単一プロセス制御の実装

導入通常、バックグラウンド サーバー プログラムには 1 つのプロセスのみが必要ですが、単一のプロセ...

DockerはGitを使用してJenkinsのリリースとテストプロジェクトの詳細なプロセスを実装します

目次1. Dockerをインストールする2. カスタムネットワークアドレスを作成する3. Docke...

HTML でナンバープレート番号と州の略語を入力するためのサンプルコード

原理としては、まずボタン付きの div を記述し、次に画面のサイズに応じて自動的に適応してキーボード...

Dockerが正常に起動しない原因と解決策を詳しく解説

1. Docker 起動時の異常なパフォーマンス: 1. ステータスが繰り返し再起動している場合は、...

MySQL のインデックス障害の一般的なシナリオと回避方法

序文これまでにも、一部の SQL ステートメントを不適切に使用すると MySQL インデックスが失敗...

Linux で docker-compose を使用したソフトウェア構成の詳細な説明

序文この記事では、docker-compose の構成をいくつか紹介します。これらを参考にして、独自...

MySQL 上級学習インデックスの長所と短所、使用ルール

1. インデックスの利点と欠点利点: 高速検索、高速グループ化および並べ替えデメリット: ストレージ...

Vueコンポーネントの再利用と拡張の詳細な説明

目次概要延長は必要ですか?スロットJavaScript ユーティリティ関数拡張コンポーネントの複数の...

ウィンドウ環境で VScode を使用して仮想マシン MySQL に接続する方法

1. 仮想マシン側1. MySQLの設定ファイルを見つける:sudo vim /etc/mysql/...

Nginx ルーティング転送とリバースプロキシロケーション構成の実装

Nginx を設定する 3 つの方法最初の方法は、位置一致部分を直接置き換える。 2 番目の pro...

MySQL 高可用性クラスタの展開とフェイルオーバーの実装

目次1. 内閣府1. コンセプト2. MHAの構成3. MHAの特徴2. MySQL+MHAをビルド...