ОШИБКА 1698 (28000): Доступ запрещен для пользователя 'базируется' 'localhost'

alhelal@VimLaTeX:~$ mysql -u root -p
Enter password: 
ERROR 1698 (28000): Access denied for user 'root'@'localhost'
alhelal@VimLaTeX:~$ sudo mysql -u root -p
[sudo] password for alhelal: 
Enter password: 
Welcome to the MariaDB monitor.  Commands end with ; or \g.
Your MariaDB connection id is 35
Server version: 10.1.29-MariaDB-6 Ubuntu 18.04

Copyright (c) 2000, 2017, Oracle, MariaDB Corporation Ab and others.

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

MariaDB [(none)]>   

Почему mariadb не позволяет нормальному пользователю человечности вводить mysql как mysql пользователь root?

Я также попробовал ОШИБКУ 1698 (28000): Доступ запрещен для пользователя 'базируется' 'localhost' в Ubuntu 18.04, но отказавший?

ERROR 1064 (42000): You have an error in your SQL syntax; check the manual that corresponds to your MariaDB server version for the right syntax to use near 'USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY 'test'' at line 1
0
задан 4 June 2018 в 20:42

1 ответ

Согласно этому ответу из SO, это может быть потому, что ваш пользователь root использует плагин auth_socket, используемый по умолчанию в MySQL / MariaDB в Ubuntu.

$ sudo mysql -u root

MariaDB [mysql]> USE mysql;
MariaDB [mysql]> SELECT User, Host, plugin FROM mysql.user;

+------------------+-----------------------+
| User             | plugin                |
+------------------+-----------------------+
| root             | auth_socket           |
+------------------+-----------------------+

Изменение этого значения на mysql_native_password позволит вам подключаться без необходимости sudo:

$ sudo mysql -u root

MariaDB [mysql]> USE mysql;
MariaDB [mysql]> UPDATE user SET plugin='mysql_native_password' WHERE User='root';
MariaDB [mysql]> FLUSH PRIVILEGES;
MariaDB [mysql]> exit;

$ service mysql restart
0
ответ дан 29 October 2019 в 04:45

Другие вопросы по тегам:

Похожие вопросы: