Forked from kangmasjuqi/mysql_root_password_changes_on_centos7.txt
Created
February 14, 2024 10:25
-
-
Save i-amolo/dae3324eda88c6df9e813cee820104c4 to your computer and use it in GitHub Desktop.
Change/Reset MySQL Root password on Centos 7
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
https://stackoverflow.com/questions/33510184/change-mysql-root-password-on-centos7/34207996#34207996 | |
1. Stop mysql: | |
systemctl stop mysqld | |
2. Set the mySQL environment option | |
systemctl set-environment MYSQLD_OPTS="--skip-grant-tables" | |
3. Start mysql usig the options you just set | |
systemctl start mysqld | |
4. Login as root | |
mysql -u root | |
5. Update the root user password with these mysql commands | |
mysql> UPDATE mysql.user SET authentication_string = PASSWORD('MyNewPassword') WHERE User = 'root' AND Host = 'localhost'; | |
mysql> FLUSH PRIVILEGES; | |
mysql> quit | |
*** Edit *** | |
As mentioned my shokulei in the comments, for 5.7.6 and later, you should use | |
mysql> ALTER USER 'root'@'localhost' IDENTIFIED BY 'MyNewPass'; | |
Or you'll get a warning | |
6. Stop mysql | |
systemctl stop mysqld | |
7. Unset the mySQL envitroment option so it starts normally next time | |
systemctl unset-environment MYSQLD_OPTS | |
8. Start mysql normally: | |
systemctl start mysqld | |
Try to login using your new password: | |
7. mysql -u root -p |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment