[RUBY] Mysql2 :: Error :: ConnectionError: Accès refusé pour user'root '@' localhost '(en utilisant le mot de passe: OUI)

problème

J'essaie de déployer un portefeuille (application personnelle) créé dans un environnement local sur AWS.

Lorsque j'ai essayé de créer une base de données dans un environnement de production, j'ai eu l'erreur suivante.

Erreur

[ec2-user@ip-00-0-0-000 pfc-master]$ rake db:create RAILS_ENV=production
Access denied for user 'root'@'localhost' (using password: YES)

Solution

① Confirmer le mot de passe temporaire

[ec2-user@ip-00-0-0-000 ~]$ sudo cat /var/log/mysqld.log | grep "temporary password"

Vérifiez le mot de passe temporaire qui a été généré automatiquement lorsque vous avez installé MySQL dans le journal MySQL.

② Modifier les règles de configuration du mot de passe

Si vous modifiez votre mot de passe MySQL sans suivre cette procédure, l'erreur suivante s'affichera.

ERROR 1819 (HY000): Your password does not satisfy the current policy requirements

La règle par défaut est ** "La longueur du mot de passe doit comporter au moins 8 caractères, contient à la fois des minuscules et des majuscules et contient des caractères spéciaux" **.

Si le mot de passe déjà défini dans database.yml satisfait à cette règle, il n'est pas nécessaire de changer la règle, mais s'il ne répond pas à la règle comme" mot de passe ", il est difficile de changer la règle. Cela désactiverait la vérification.

$ sudo vi /etc/my.cnf

Ouvrez vim avec / etc / my.cnf

[mysqld]
validate-password=OFF

Ajouter.

Redémarrez MySQL pour que les paramètres prennent effet.

$ sudo systemctl restart mysqld.service

Référence: Mysql 5.7 * À propos des problèmes liés à la correspondance du mot de passe avec la stratégie

③ Changer le mot de passe

[ec2-user@ip-00-0-0-000 ~]$ mysql_secure_installation

La première configuration après l'installation de MySQL 5.7 ↑ Puisque la méthode de changement de mot de passe a été écrite dans cet article, changez le mot de passe qui y fait référence.

Saisissez le mot de passe temporaire confirmé dans ① dans "Mot de passe initial" Entrez le mot de passe défini dans database.yml dans "Nouveau mot de passe".

Répondez à toutes les questions suivantes Oui ou Non par y (Oui).

$ mysql_secure_installation

Securing the MySQL server deployment.

Enter password for user root:Entrez le mot de passe initial

The existing password for the user account root has expired. Please set a new password.

New password:entrer un nouveau mot de passe

Re-enter new password:Saisissez à nouveau le même nouveau mot de passe

VALIDATE PASSWORD PLUGIN can be used to test passwords
and improve security. It checks the strength of password
and allows the users to set only those passwords which are
secure enough. Would you like to setup VALIDATE PASSWORD plugin?

Press y|Y for Yes, any other key for No: y

There are three levels of password validation policy:

LOW Length >= 8
MEDIUM Length >= 8, numeric, mixed case, and special characters
STRONG Length >= 8, numeric, mixed case, special characters and dictionary file

Please enter 0 = LOW, 1 = MEDIUM and 2 = STRONG: 0
Using existing password for root.

Estimated strength of the password: 100
Change the password for root ? ((Press y|Y for Yes, any other key for No) : y

New password:Entrez un nouveau mot de passe conformément à la politique

Re-enter new password:Saisissez à nouveau le nouveau mot de passe

Estimated strength of the password: 50
Do you wish to continue with the password provided?(Press y|Y for Yes, any other key for No) : y
By default, a MySQL installation has an anonymous user, a user account created for them. This is intended only for
testing, and to make the installation go a bit smoother.
You should remove them before moving into a production
environment.

Remove anonymous users? (Press y|Y for Yes, any other key for No) : y
Success.


Normally, root should only be allowed to connect from
'localhost'. This ensures that someone cannot guess at
the root password from the network.

Disallow root login remotely? (Press y|Y for Yes, any other key for No) : y
Success.

By default, MySQL comes with a database named 'test' that
anyone can access. This is also intended only for testing,
and should be removed before moving into a production
environment.


Remove test database and access to it? (Press y|Y for Yes, any other key for No) : y Success.

- Removing privileges on test database...
Success.

Reloading the privilege tables will ensure that all changes
made so far will take effect immediately.

Reload privilege tables now? (Press y|Y for Yes, any other key for No) : y
Success.

All done!

Article de référence

Recommended Posts

Mysql2 :: Error :: ConnectionError: Accès refusé pour user'root '@' localhost '(en utilisant le mot de passe: OUI)
Accès refusé pour user'root '@' localhost '(en utilisant le mot de passe: NON) Action corrective en cas d'erreur
Accès refusé pour user'root '@' localhost '(en utilisant le mot de passe: OUI) et abandonné
Résoudre Mysql2 :: Error :: ConnectionError