解决1130 Host 'localhost' is not allowed to connect to this MySQL server

刚才更改了mysql的root用户密码后就报了【1130 Host 'localhost' is not allowed to connect to this MySQL server】错。

原因:

1.报这个错是没给改后的root用户授权,所以没有权限登录。

2.但我觉得也可能是因为我更改后的密码直接是明文而不像mysql用语句或安装时创建是密文方式的,所以登录的时候无法获取到连接

解决:

【方案一】跳过授权来登录,然后删除root用户,然后再

1.先把本地mysql服务关闭掉,然后通过在mysql安装目录下打开cmd运行以下跳过授权命令

mysql>mysqld --skip-grant-tables


执行过程需要一些时间,直到出现以上信息则表示mysql启动成功。注:不要关掉这个窗口,关闭的话mysql服务则会被关闭掉

2.再执行命令进行登录

mysql>mysql -uroot -p密码

3.删除user表中的root用户,并创建与授权。

mysql>use mysql;

mysql>delete from user where user='root';

mysql> CREATE USER 'root'@'localhost' IDENTIFIED BY 'root';

4.在这个过程中可能会出现以下错误

ERROR 1290 (HY000): The MySQL server is running with the --skip-grant-tables option so it cannot exe

1290错误需要执行将当前user和privilige表中的用户信息/权限设置从mysql库(MySQL数据库的内置库)中提取到内存里的命令

mysql>flush privileges;

ERROR 1396 (HY000): Operation CREATE USER failed for 'root'@'localhost'

1396错误的原因是由于之前账号信息清理不干净。需要drop本地root信息

mysql>drop user 'root'@'localhost';

5.授权

mysql> GRANT ALL PRIVILEGES ON *.* TO 'root'@'localhost' WITH GRANT OPTION;

mysql> CREATE USER 'root'@'%' IDENTIFIED BY 'root';
mysql> GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' WITH GRANT OPTION;

mysql>flush privileges;

### 解决 MySQL 连接错误 1045 “Host localhost is not allowed to connect” 当遇到“Host 'localhost' is not allowed to connect to this MySQL server”的错误时,通常是因为权限配置不当或者用户账户设置存在问题。以下是详细的解决方案: #### 用户权限检查 确保目标主机被授权访问MySQL服务器。可以通过以下命令查看现有用户的权限分配情况: ```sql SELECT User, Host FROM mysql.user; ``` 如果发现`User`字段中有需要的用户名但是对应的`Host`不是期望的值(例如 `%` 或具体的IP地址),则可能需要调整该用户的权限。 #### 修改用户权限 对于特定用户授予从任何地方或指定位置连接的权利,可以执行如下SQL语句来创建新用户并赋予适当权限[^1]: ```sql CREATE USER 'username'@'%' IDENTIFIED BY 'password'; GRANT ALL PRIVILEGES ON *.* TO 'username'@'%'; FLUSH PRIVILEGES; ``` 这里使用了通配符`%`表示允许来自任意主机的连接;如果是固定IP,则替换为实际IP地址即可。 #### 配置文件修改 有时也需要编辑MySQL配置文件(`my.cnf`)中的绑定地址选项以支持外部连接请求。找到并更改`bind-address`参数使其监听所有网络接口而不是仅限于本地回环设备(127.0.0.1)[^2]: ```ini [mysqld] ... ! bind-address = 0.0.0.0 ``` 完成上述操作之后记得重启MySQL服务使改动生效。 #### 安全组/防火墙规则确认 另外还需核查操作系统层面的安全策略是否阻止了入站流量到达MySQL端口,默认情况下是3306端口。这涉及到Linux系统的iptables规则或者是云服务商提供的安全组设定等[^3]。 以上措施应该能够有效处理大多数关于“Host 'localhost' is not allowed to connect to this MySQL server”的问题实例。不过需要注意的是,在开放更多接入途径的同时也要重视安全性考量,合理规划最小化暴露风险范围内的资源访问控制机制。
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值