mysql如何设置仅允许特定内网访问_MySQL权限配置中的IP绑定

MySQL用户账号绑定IP需精确匹配host字段,如'api'@'192.168.5.11';不支持CIDR,%仅作字符通配;须删除冗余宽泛权限、检查bind-address与防火墙、区分localhost与127.0.0.1。mysql用户账号绑定具体IP地址MySQL的权限系统靠 user@host 这个组合来识别访问来源,host 部分不是"允许范围",而是"必须完全匹配"的主机标识。想只让内网某台机器连,就得把 host 写成它的实际IP,比如 'app-server'@'192.168.10.42'。常见错误是写成 'user'@'192.168.%' 或 'user'@'192.168.10.0/24' ------ MySQL不支持CIDR掩码,% 是通配符但只匹配任意字符(不含点号分隔的段数逻辑),192.168.% 实际会匹配 192.168.100.200 甚至 192.168x.y,非常危险。创建账号时直接指定IP:CREATE USER 'api'@'192.168.5.11' IDENTIFIED BY 'pwd123';已有账号需用 RENAME USER 或先 DROP USER 再重建,不能只改 host执行完记得 FLUSH PRIVILEGES;,否则变更不生效为什么GRANT后还是连不上?检查host字段是否被覆盖MySQL在权限匹配时,会按 user@host 字符串长度由长到短排序匹配,最长的优先。如果同时存在 'app'@'192.168.5.%' 和 'app'@'192.168.5.11',而前者权限更大,那么即使你从 192.168.5.11 连入,也会命中前者------导致你以为绑定了IP,实际走的是宽泛规则。查当前所有匹配该用户的记录:SELECT User, Host FROM mysql.user WHERE User = 'app';删掉冗余的宽泛条目,比如 'app'@'%' 或 'app'@'192.168.%'确认连接时客户端真实出口IP:容器里可能看到的是网关IP,K8s Pod可能经过Service代理,得看 SHOW PROCESSLIST; 里的 Host 列bind-address和防火墙是两层控制,缺一不可bind-address 是MySQL服务监听的网卡地址,不是权限控制手段。设成 127.0.0.1 就只能本地连;设成 0.0.0.0 才能接受远程连接------但此时仍受账号 host 限制。很多人只改权限却忘了放开监听,或者开了 0.0.0.0 却没配防火墙,结果外网也能扫到端口。 VWO 一个A/B测试工具

相关推荐
带派擂总6 小时前
Python全栈开发精华版最全合集(包含各种面试题) Day24_异常和错误
python
笃行3507 小时前
金仓数据库数据安全双防线:静态存储加密与传输加密实战
数据库
笃行3507 小时前
金仓数据库物理备份实战:sys_rman 全流程演练与误覆盖抢救
数据库
笃行3508 小时前
金仓数据库逻辑备份实战:从全库导出到 Schema 替换的完整闭环
数据库
金銀銅鐵9 小时前
n^5 和 n 的个位数是否总相等?
python·数学
aqi0012 小时前
15天学会AI应用开发(九)利用Chroma持久化向量数据
人工智能·python·大模型·ai编程·ai应用
金銀銅鐵12 小时前
借助 Pygame 探索最大公约数的规律
python·数学·游戏
ServBay1 天前
9 个 Python 第三方库推荐,不用 AI 都好像多出一个团队
后端·python