MySQL zaczął używać kont systemowych do akceptowania połączeń od wersji 5.7 przy użyciu auth_socket wtyczka hasła. Może być wymagane połączenie z serwerem MySQL przy użyciu konta root z hasłem przy użyciu opcji mysql_native_password. Możemy zmienić domyślne zachowanie konta root, aby używało natywnego hasła za pomocą poleceń podanych poniżej.
# Login to MySQL
sudo mysql
# Check password scheme of root user
SELECT user,authentication_string,plugin,host FROM mysql.user;
# Note the password plugin of root user
+------------------+-------------------------------------------+-----------------------+-----------+
| user | authentication_string | plugin | host |
+------------------+-------------------------------------------+-----------------------+-----------+
| root | | auth_socket | localhost |
+------------------+-------------------------------------------+-----------------------+-----------+
# Change password plugin of root user
ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY '<pw>';
# Apply changes
flush privileges;
# Check password scheme of root user
SELECT user,authentication_string,plugin,host FROM mysql.user;
# Note the password plugin of root user
+------------------+-------------------------------------------+-----------------------+-----------+
| user | authentication_string | plugin | host |
+------------------+-------------------------------------------+-----------------------+-----------+
| root | *E5C4F73D963132CEF9BB4PA79LA818C08BAQC300 | mysql_native_password | localhost |
+------------------+-------------------------------------------+-----------------------+-----------+
W ten sposób możemy użyć natywnej wtyczki hasła dla użytkownika MySQL.