0
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 1 year has passed since last update.

Python(Django) x Docker x AWSAdvent Calendar 2023

Day 6

【MySQL 】mysqldポート番号との競合!ERROR 1045 (28000): Access denied for user 'root'@'localhost'エラーについて

Posted at

概要

Dockerを利用してローカルDBに接続するDjangoアプリケーションを起動後、DBeaver(データベース管理ツール)でローカルDBに接続したら以下のエラーが表示されました。

ERROR 1045 (28000): Access denied for user 'root'@'localhost'

image.png

本記事ではこちらの原因と解決方法を記載します。

解決方法

まずは結論から。
以下の箇所を変更することで、解決しました。

修正前

  mysql:
    image: mysql:latest
    container_name: xxxxx
    environment:
      MYSQL_ROOT_PASSWORD: xxxxx
      MYSQL_USER: root
      MYSQL_PASSWORD: xxxxx
      MYSQL_DATABASE: xxxxx
    ports:
      - "3306:3306"

上記の状態だとDBeaverの上述のエラーになります。
※ただし、上記でもDockerコンテナに入ってmysql -u root -pでアクセスすると問題なく接続できます

修正後

  mysql:
    image: mysql:latest
    container_name: xxxxx
    environment:
      MYSQL_ROOT_PASSWORD: xxxxx
      MYSQL_USER: xxxxx
      MYSQL_PASSWORD: xxxxx
      MYSQL_DATABASE: xxxxx
    ports:
      - "3310:3306" # MySQLコンテナを3310にマッピング

上記の通り、portsを変更することで、無事にDBeaverでローカルDBに入れました。

原因は...ポート番号の競合だった

原因はポート番号3306にありました。
なぜ3310に変更したら解決したのか?というと、3306ポートで競合が発生していたからです。
以下のコマンドで、3306が使われているのか確認できます。

sudo lsof -i :3306

lsofコマンドは"List Open Files"の略。
システム上で開かれているファイルやネットワークソケット、プロセスなどの情報をリストするためのコマンドです。これにより、ポート3306でリスンしているプロセスがわかります。

なにも返ってこない場合は3306ポートは使われていません。
しかし、自分の場合、以下のように返ってきました。

COMMAND  PID       USER   FD   TYPE             DEVICE SIZE/OFF NODE NAME
mysqld  1490 XXXXXXXXXX   20u  IPv4 XXXXXXXXXXXXXXXXXX      0t0  TCP localhost:mysql (LISTEN)

上記の出力結果から、プロセスmysqldによってポート3306が使用されていることが分かります。
つまり、ローカルマシン(ホストマシン)のMySQLサーバーがポート3306でリスンしているので、他のアプリケーションが同じポートを使用しようとすると競合が発生する、ということです。

3306のままでもDockerのmysqlコンテナに入ればアクセスできたのは、Docker上では、独自に確保したポートに接続しており、競合するポートがなかったからですね。
MySQLコンテナをポート3310にマッピングした場合、MySQLサーバーはポート3310でリスンし、MySQLクライアントはポート3310を使用して接続します。

新しいMySQLコンテナをDockerで起動する際、ポート番号を3306から変更する必要があったのです。上記では3310としましたが、3306以外であればOKです。これにより、複数のMySQLインスタンスを同じホストで実行できるようになります。

補足:mysqldってなに??

mysqldはMySQLデータベースサーバー(MySQLデーモン)の実行プロセスです。
デーモンとはUNIX系OSではバックグラウンドで動作するプロセスのことで、docker compose up -dのときのdと同じデーモンプロセスですね。

ちなみに以下コマンドで稼働しているかわかります。

$ mysqladmin ping -h 127.0.0.1
mysqld is alive
0
0
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
0
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?