0

0

mysql如何限制用户访问特定主机_mysql主机权限设置

P粉602998670

P粉602998670

发布时间:2026-02-13 04:27:24

|

619人浏览过

|

来源于php中文网

原创

mysql权限模型以“用户+主机”二元组为核心,创建用户时应直接指定host(如'192.168.1.100'),避免手动修改mysql.user表;须配合防火墙限制并实测验证。

mysql如何限制用户访问特定主机_mysql主机权限设置

直接用 CREATE USER 'user'@'host' 指定来源主机

MySQL 的权限模型本质是 “用户+主机” 二元组,host 字段不是附加配置,而是账户身份的一部分。想限制只能从某台机器访问,最稳妥的方式就是在创建时就写死:CREATE USER 'appuser'@'192.168.1.100' IDENTIFIED BY 'p@ssw0rd';。这比事后改权限更安全,也避免了因缓存或结构校验导致的异常。

  • 只允许本地 Unix socket 连接?用 'user'@'localhost'(注意:它不等价于 'user'@'127.0.0.1'
  • 允许整个内网段?用通配符 'user'@'192.168.1.%',但别写成 '192.168.1.0/24' —— MySQL 不支持 CIDR
  • 域名可用,但默认开启 skip_name_resolve=OFF 时会做反向 DNS 查询,可能卡住连接或匹配错 host

别手改 mysql.user 表,用 RENAME USER 或重建

看到网上有 UPDATE mysql.user SET Host='xxx' WHERE User='yyy' 的做法?别碰。MySQL 8.0+ 对系统表结构强校验,手动 UPDATE 可能破坏权限缓存一致性,甚至让账户无法登录。真要改已有用户的 host,优先走官方路径:

云模块网站管理系统3.1.03
云模块网站管理系统3.1.03

云模块_YunMOK网站管理系统采用PHP+MYSQL为编程语言,搭载自主研发的模块化引擎驱动技术,实现可视化拖拽无技术创建并管理网站!如你所想,无限可能,支持创建任何网站:企业、商城、O2O、门户、论坛、人才等一块儿搞定!永久免费授权,包括商业用途; 默认内置三套免费模板。PC网站+手机网站+适配微信+文章管理+产品管理+SEO优化+组件扩展+NEW Login界面.....目测已经遥遥领先..

下载
  • 安全迁移:用 RENAME USER 'olduser'@'%' TO 'olduser'@'192.168.1.100';
  • 彻底清理:先 DROP USER 'olduser'@'%';,再 CREATE USER ... GRANT ...
  • 切记:改完必须 FLUSH PRIVILEGES;,否则新规则不生效

防火墙才是真正的第一道门

仅靠 MySQL 层的 host 限制,拦不住连接建立阶段的扫描、爆破或连接数耗尽攻击。操作系统防火墙(如 iptablesufw)必须同步配置,作为兜底防线:

  • Ubuntu 上只放行指定 IP:sudo ufw allow from 192.168.1.100 to any port 3306
  • CentOS 7+ 用 firewalld:firewall-cmd --permanent --add-rich-rule='rule family="ipv4" source address="192.168.1.100" port port="3306" protocol="tcp" accept'
  • 规则加完记得 reload,且确认默认策略是 deny —— 否则等于没设

验证是否真生效:从目标 IP 连,别只在本机试

很多人改完以为好了,结果应用连不上才发现被锁在外面。验证必须从被允许的那台机器上实测:mysql -u appuser -p -h your-mysql-server-ip。如果报 Access denied for user 'appuser'@'192.168.1.100',说明密码错或 host 不匹配;如果报 Connection refused 或超时,大概率是防火墙或 bind-address 没配对。

  • 查当前所有用户:SELECT User, Host FROM mysql.user;,确认 Host 列精确匹配你写的值
  • 检查 MySQL 是否监听对外地址:netstat -tlnp | grep :3306,若只显示 127.0.0.1:3306,那即使权限开了也没用
  • 错误日志位置因安装方式而异,常见的是 /var/log/mysql/error.log,拒绝原因通常就写在里面
实际中最容易被忽略的,是 'user'@'localhost''user'@'127.0.0.1' 被当成同一个账户来管理,以及防火墙规则没 reload 就以为生效了。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
mysql修改数据表名
mysql修改数据表名

MySQL修改数据表:1、首先查看数据库中所有的表,代码为:‘SHOW TABLES;’;2、修改表名,代码为:‘ALTER TABLE 旧表名 RENAME [TO] 新表名;’。php中文网还提供MySQL的相关下载、相关课程等内容,供大家免费下载使用。

674

2023.06.20

MySQL创建存储过程
MySQL创建存储过程

存储程序可以分为存储过程和函数,MySQL中创建存储过程和函数使用的语句分别为CREATE PROCEDURE和CREATE FUNCTION。使用CALL语句调用存储过程智能用输出变量返回值。函数可以从语句外调用(通过引用函数名),也能返回标量值。存储过程也可以调用其他存储过程。php中文网还提供MySQL创建存储过程的相关下载、相关课程等内容,供大家免费下载使用。

351

2023.06.21

mongodb和mysql的区别
mongodb和mysql的区别

mongodb和mysql的区别:1、数据模型;2、查询语言;3、扩展性和性能;4、可靠性。本专题为大家提供mongodb和mysql的区别的相关的文章、下载、课程内容,供大家免费下载体验。

284

2023.07.18

mysql密码忘了怎么查看
mysql密码忘了怎么查看

MySQL是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,属于 Oracle 旗下产品。MySQL 是最流行的关系型数据库管理系统之一,在 WEB 应用方面,MySQL是最好的 RDBMS 应用软件之一。那么mysql密码忘了怎么办呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

519

2023.07.19

mysql创建数据库
mysql创建数据库

MySQL是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,属于 Oracle 旗下产品。MySQL 是最流行的关系型数据库管理系统之一,在 WEB 应用方面,MySQL是最好的 RDBMS 应用软件之一。那么mysql怎么创建数据库呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

262

2023.07.25

mysql默认事务隔离级别
mysql默认事务隔离级别

MySQL是一种广泛使用的关系型数据库管理系统,它支持事务处理。事务是一组数据库操作,它们作为一个逻辑单元被一起执行。为了保证事务的一致性和隔离性,MySQL提供了不同的事务隔离级别。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

391

2023.08.08

sqlserver和mysql区别
sqlserver和mysql区别

SQL Server和MySQL是两种广泛使用的关系型数据库管理系统。它们具有相似的功能和用途,但在某些方面存在一些显著的区别。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

536

2023.08.11

mysql忘记密码
mysql忘记密码

MySQL是一种关系型数据库管理系统,关系数据库将数据保存在不同的表中,而不是将所有数据放在一个大仓库内,这样就增加了速度并提高了灵活性。那么忘记mysql密码我们该怎么解决呢?php中文网给大家带来了相关的教程以及其他关于mysql的文章,欢迎大家前来学习阅读。

635

2023.08.14

c语言 数据类型
c语言 数据类型

本专题整合了c语言数据类型相关内容,阅读专题下面的文章了解更多详细内容。

4

2026.02.12

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
MySQL 教程
MySQL 教程

共48课时 | 2.2万人学习

MySQL 初学入门(mosh老师)
MySQL 初学入门(mosh老师)

共3课时 | 0.3万人学习

简单聊聊mysql8与网络通信
简单聊聊mysql8与网络通信

共1课时 | 832人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号