如何配置用户的资源使用上限_MAX_QUERIES_PER_HOUR查询频率限制

MySQL 8.0+ 仅支持通过 CREATE/ALTER USER ... WITH MAX_QUERIES_PER_HOUR 设置频率限流,按自然小时统计语句总数,不区分类型、不看耗时,不可自定义窗口;GRANT ... WITH 已废弃且逻辑危险,应禁用。MySQL 8.0+ 怎么给用户加 MAX_QUERIES_PER_HOUR 限制直接用 CREATE USER 或 ALTER USER 设置,这是唯一原生支持的"频率限流"方式。它不拦单条慢查询,只卡单位时间内的语句总数------适合防轮询、脚本误跑、爬虫扫库这类高频轻量请求。实操建议:CREATE USER 'api_user'@'%' WITH MAX_QUERIES_PER_HOUR 120; ------ 新建用户时直接绑定,最干净ALTER USER 'report_user'@'localhost' WITH MAX_QUERIES_PER_HOUR 300; ------ 已有用户可随时调整,无需重连该限制对所有语句生效(SELECT/INSERT/UPDATE/DELETE/SET 都算),但 COMMIT、ROLLBACK、SHOW 等不计入注意:不是每秒或每分钟,是严格按"自然小时"滚动(从 00:00 开始计数),不能自定义窗口为什么 GRANT ... WITH MAX_QUERIES_PER_HOUR 在 MySQL 8.0+ 不推荐用这个语法在 5.7 是合法的,但在 8.0+ 已被废弃,且逻辑极容易踩坑:它只对当前 GRANT 语句中显式列出的权限生效,没列的权限完全不受限。比如你写 GRANT SELECT ON db.* TO u@h WITH MAX_QUERIES_PER_HOUR 100;,那用户后续如果还有 UPDATE 权限(来自另一条 GRANT),更新操作就完全绕过限制。更糟的是,多个 GRANT 记录共存时,系统取的是各条里最大的值,不是累加,查问题时数值对不上,调试成本高。所以:一律用 CREATE/ALTER USER ... WITH,别碰带 WITH 的 GRANT。MAX_QUERIES_PER_HOUR 真的能防住大查询吗不能。它只计数,不看执行时间、不看扫描行数、不看内存占用。一条 SELECT SLEEP(30) 算 1 次,一条 SELECT * FROM huge_table WHERE ... 也只算 1 次。真正耗资源的大查询,它完全不管。 通义听悟 阿里云通义听悟是聚焦音视频内容的工作学习AI助手,依托大模型,帮助用户记录、整理和分析音视频内容,体验用大模型做音视频笔记、整理会议记录。

相关推荐
曹牧1 小时前
PL/SQL:视图(View)比较
数据库·sql
2501_901200531 小时前
编写表与字段注释后数据无法保存怎么排查_权限设置与回滚处理
jvm·数据库·python
m0_733565461 小时前
mysql数据库执行全量备份影响业务_利用xtrabackup实现无锁备份
jvm·数据库·python
楠枬1 小时前
Redis 事务
数据库·redis·缓存
2401_880071401 小时前
golang如何编写DNS查询工具_golang DNS查询工具编写大全
jvm·数据库·python
phltxy1 小时前
怎么样持续提升自己的编程能力?
数据库
轻刀快马1 小时前
穿透 MQ 专栏 (五):【终局之战】MySQL 和 MQ 的世纪联姻:扒开“分布式事务”的遮羞布
数据库·分布式·消息队列
Elastic 中国社区官方博客1 小时前
Elasticsearch 9.4 为 Elastic AI 生态系统的下一阶段提供支持:Dell AI Data Platform(与 NVIDIA 合作)
大数据·数据库·人工智能·elasticsearch·搜索引擎·ai·全文检索
预测模型的开发与应用研究1 小时前
Oracle双库部署
数据库·oracle