当前位置: 首页 > 知识库问答 >
问题:

MySQL:用户“test”@“localhost”(使用密码:YES)的访问被拒绝,根用户除外

施权
2023-03-14

我面临mysql非root/admin用户的问题,我按照以下步骤创建用户及其权限,如果我做错了,请纠正我,

我正在RHEL 5.7 64位上安装mysql,下面提到了包,一旦我完成rpm安装,我们就可以开始了

  1. 使用mysql\u install\u db创建mysql数据库,然后
  2. 然后启动mysql服务
  3. 使用mysql\u升级我们也在对服务器进行升级

在此过程后,我可以登录为root,但与非root用户我无法登录到服务器:

[root@clustertest3 ~]# rpm -qa | grep MySQL
MySQL-client-advanced-5.5.21-1.rhel5
MySQL-server-advanced-5.5.21-1.rhel5


[root@clustertest3 ~]# cat /etc/my.cnf
[mysqld]
datadir=/var/lib/mysql
socket=/var/lib/mysql/mysql.sock
user=mysql
# Default to using old password format for compatibility with mysql 3.x
# clients (those using the mysqlclient10 compatibility package).
old_passwords=1

# Disabling symbolic-links is recommended to prevent assorted security risks;
# to do so, uncomment this line:
# symbolic-links=0

[mysqld_safe]
log-error=/var/log/mysqld.log
pid-file=/var/run/mysqld/mysqld.pid

[root@clustertest3 ~]# ls -ld /var/lib/mysql/mysql.sock
srwxrwxrwx 1 mysql mysql 0 Nov  30 11:09 /var/lib/mysql/mysql.sock

mysql> CREATE USER 'golden'@'%' IDENTIFIED BY 'password';
Query OK, 0 rows affected (0.00 sec)

mysql> GRANT ALL PRIVILEGES ON * . * TO 'golden'@'%';
Query OK, 0 rows affected (0.00 sec)

mysql> FLUSH PRIVILEGES;
Query OK, 0 rows affected (0.00 sec)

mysql> SELECT USER(),CURRENT_USER();
+----------------+----------------+
| USER()         | CURRENT_USER() |
+----------------+----------------+
| root@localhost | root@localhost |
+----------------+----------------+
1 row in set (0.00 sec)

[root@clustertest3 ~]# mysql -ugolden -p
Enter password:
ERROR 1045 (28000): Access denied for user 'golden'@'localhost' (using password: YES)

这就是我面临的问题,对此有什么解决办法吗?


共有3个答案

沃阳飙
2023-03-14

尝试:

CREATE USER 'golden'@'localhost' IDENTIFIED BY 'password';
GRANT ALL PRIVILEGES ON * . * TO 'golden'@'localhost';
FLUSH PRIVILEGES;

或者更好地使用:mysql\u setpermission创建用户

邢星波
2023-03-14

如果您使用远程机器(示例工作台)等连接到MySQL,请使用以下步骤在安装MySQL的操作系统上消除此错误

mysql -u root -p

CREATE USER '<<username>>'@'%%' IDENTIFIED BY '<<password>>';
GRANT ALL PRIVILEGES ON * . * TO '<<username>>'@'%%';
FLUSH PRIVILEGES;

尝试登录到MYSQL实例。
这对我来说消除了这个错误。

单展
2023-03-14

不要将所有数据库上的所有权限授予非root用户,这是不安全的(并且您已经拥有该角色的“root”)

GRANT <privileges> ON database.* TO 'user'@'localhost' IDENTIFIED BY 'password';

此语句创建新用户并向其授予选定的权限。即。:

GRANT INSERT, SELECT, DELETE, UPDATE ON database.* TO 'user'@'localhost' IDENTIFIED BY 'password';

查看文档以查看所有详细的权限

编辑:您可以通过此查询查找更多信息(以“root”身份登录):

select Host, User from mysql.user;

看看发生了什么

 类似资料: