EC2(ubuntu)に構築したDjangoからRDS(mysql)への接続する方法

こんにちは、nishi_talk(@nishi_talk)です。
最近案件で使うことが多い、EC2(ubuntu)に構築したDjangoからRDS(mysql)への接続する方法をご紹介します。




前提条件

ここら辺はインストール・設定済み。

EC2内環境

  • ubuntu
  • python 3.6.4
  • Django 2.1.4

RDS環境

  • MariaDB エンジンバージョン 10.1.34

RDS環境の設定方法

RDS環境の設定はこちらの記事がすごい丁寧解説されてるので、参照して設定。
Django、Amazon RDS(MariaDB)に接続する

Djangoの設定方法

DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.mysql',
        'NAME': 'mydjango',
        'USER': 'マスターユーザー',
        'PASSWORD': 'マスターユーザーパスワード',
        'HOST': '詳細で確認したエンドポイント',
        'PORT': '3306',
    }
}

migareteしたときにログにエラーが。。。

$ python manage.py migrate

Traceback (most recent call last):
  File "/home/ubuntu/.pyenv/versions/3.6.4/lib/python3.6/site-packages/django/db/backends/base/base.py", line 216, in ensure_connection
    self.connect()
  File "/home/ubuntu/.pyenv/versions/3.6.4/lib/python3.6/site-packages/django/db/backends/base/base.py", line 194, in connect
    self.connection = self.get_new_connection(conn_params)
  File "/home/ubuntu/.pyenv/versions/3.6.4/lib/python3.6/site-packages/django/db/backends/mysql/base.py", line 227, in get_new_connection
    return Database.connect(**conn_params)
  File "/home/ubuntu/.pyenv/versions/3.6.4/lib/python3.6/site-packages/MySQLdb/__init__.py", line 85, in Connect
    return Connection(*args, **kwargs)
  File "/home/ubuntu/.pyenv/versions/3.6.4/lib/python3.6/site-packages/MySQLdb/connections.py", line 208, in __init__
    super(Connection, self).__init__(*args, **kwargs2)
_mysql_exceptions.OperationalError: (2006, "Can't connect to MySQL server on 'xxxxxxxxxxxxxxxxxxxxx' (110)")
・
・
・
django.db.utils.OperationalError: (2006, "Can't connect to MySQL server on 'xxxxxxxxxxxxxxxxxxxxx' (110)")

原因

サーバーに接続できてないみたい。

まずはEC2からRDSで作成したインスタンスに接続できるか確認。
EC2にsshで接続して、mysqlに接続できるか確認。

$ mysql -h エンドポイント -P 3306 -u root -p

接続が成功の場合はこんな感じの表示になります。

Enter password: ←ここに設定したパスワードを入力
Welcome to the MySQL monitor.  Commands end with ; or \g.
Your MySQL connection id is 18
Server version: 5.6.41 Source distribution

Copyright (c) 2000, 2018, Oracle and/or its affiliates. All rights reserved.

Oracle is a registered trademark of Oracle Corporation and/or its
affiliates. Other names may be trademarks of their respective
owners.

Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.

mysql>

私が接続できなかった時は、mysqlのコマンドが使えなかったので、mysql-clientをインストールすると接続できました。
EC2にsshで接続して、mysql-clientをインストールします。

$ sudo apt-get install mysql-client

それでも接続できない場合、AWSのセキュリティーグループの設定を確認。

EC2からRDS(MySQL)に接続できない。セキュリティグループの設定について・・・

EC2からRDS(MySQL)に接続できない。セキュリティグループの設定について・・・

mysqlコマンドで接続ができたら、djangoを使って接続できるか確認します。

$ python3 manage.py migrate
ubuntu@ip-xxxxxx:~/xxxxxx$ python3 manage.py migrate
System check identified some issues:
・
・
・

Running migrations:
  Applying contenttypes.0001_initial... OK
  Applying auth.0001_initial... OK
  Applying admin.0001_initial... OK
  Applying admin.0002_logentry_remove_auto_add... OK
  Applying admin.0003_logentry_add_action_flag_choices... OK
  Applying contenttypes.0002_remove_content_type_name... OK
  Applying auth.0002_alter_permission_name_max_length... OK
  Applying auth.0003_alter_user_email_max_length... OK
  Applying auth.0004_alter_user_username_opts... OK
  Applying auth.0005_alter_user_last_login_null... OK
  Applying auth.0006_require_contenttypes_0002... OK
  Applying auth.0007_alter_validators_add_error_messages... OK
  Applying auth.0008_alter_user_username_max_length... OK
  Applying auth.0009_alter_user_last_name_max_length... OK
  Applying sessions.0001_initial... OK

今度は無事に接続できました。