MySQL使用局域网IP登录报错(password yes)方法

本文介绍了解决MySQL默认仅允许localhost或127.0.0.1访问的问题,并提供了一个链接,详细说明如何配置MySQL以允许其他主机进行访问。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

是因为mysql默认只能使用localhost或127.0.0.1访问

解决方法:https://www.cnblogs.com/beyang/p/4905309.html

当你在PyCharm中尝试连接MySQL数据库时遇到 `Access denied for user 'root'@'localhost' (using password: YES)` 错误,这通常意味着用户名、密码或权限配置有问题。以下是几种常见原因及解决办法: --- ### 1. **检查用户名和密码是否正确** - 确认你在 PyCharm 中输入的 MySQL 用户名(如 `'root'`)及其对应的密码是否匹配。 - 如果不确定密码是否正确,可以登录到命令行终端,并运行以下命令测试: ```bash mysql -u root -p ``` 输入密码后如果能够成功进入 MySQL,则说明用户凭据无误。 --- ### 2. **确认用户的主机权限设置** - 默认情况下,MySQL 的根用户可能只允许从本机访问 (`localhost`) 或特定 IP 地址访问。 - 检查并修改用户权限以确保 `'root'@'%'` 被授权访问所有来源地址。你可以通过下面 SQL 命令添加新的权限范围: ```sql CREATE USER 'root'@'%' IDENTIFIED BY 'your_password'; GRANT ALL PRIVILEGES ON *.* TO 'root'@'%'; FLUSH PRIVILEGES; ``` --- ### 3. **验证密码策略问题** - 新版本 MySQL 可能会对复杂度较低的密码实施限制规则。如果你使用密码过于简单,可能会导致无法正常登陆。 - 修改密码强度校验插件的方法如下: ```sql SET GLOBAL validate_password.policy = LOW; -- 设置低级安全要求 ALTER USER 'root'@'localhost' IDENTIFIED BY '新密码'; -- 更改当前用户的密码 ``` --- ### 4. **防火墙阻止了通信请求** - 防火墙可能导致外部程序不能触及本地服务器端口。如果是远程连接,请确保证开放了默认 MYSQL 数据库服务监听端口号 (**3306**) 并未受阻拦。 - 使用命令查看状态: ```bash sudo ufw status netstat -tuln | grep 3306 ``` --- ### 5. **绑定地址配置不当** - 打开我的SQL安装目录下的my.ini文件,找到bind-address字段,默认值可能是 "127.0.0.1" ,表示仅接受来自同一台机器内部循环接口的数据包传输;若需支持局域网内其他设备发起查询操作需求的话需要将其更改为“0.0.0.0”或者其他实际IP数值。 --- 完成上述步骤后再回到PyCharm重新尝试建立连接即可解决问题! --- ####
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值