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.
[ec2-user@ip-00-0-0-000 pfc-master]$ rake db:create RAILS_ENV=production
Access denied for user 'root'@'localhost' (using password: YES)
[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.
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
[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!
Recommended Posts