自动SQL限流
数据库自治服务DAS支持自动SQL限流功能,您可以设置触发条件,当相关条件满足时会自动触发SQL限流。
前提条件
目标数据库实例为:
RDS MySQL 5.6、5.7、 8.0高可用版、三节点企业版。
PolarDB MySQL版 5.6集群版、5.7集群版、 8.0集群版、8.0高压缩引擎(X-Engine)。
MyBase MySQL 5.6、5.7、 8.0高可用版。
适用场景
自动限流主要应用在以下3种场景:
流量问题:出现缓存穿透或异常调用情况,导致某类SQL并发量急剧上升。
数据问题:存在大订单数据的账号,该账号的相关SQL占用大量数据库资源。
SQL问题:未创建索引的SQL被大量调用,影响正常业务。
功能限制
自动SQL限流的限流模式是通过关键词限流:
支持的SQL类型有SELECT、UPDATE、DELETE和INSERT。
不支持限流INSERT...SELECT...类型的SQL语句。
仅RDS MySQL 8.0和PolarDB MySQL版 5.7、8.0支持限流INSERT类型的SQL语句。
视频教程
操作步骤
- 登录DAS控制台。
- 在左侧导航栏中,单击实例监控。
- 找到目标实例,单击实例ID,进入目标实例详情页。
- 在左侧导航栏中,单击自治中心。
在自治中心页面,单击右侧自治功能开关。
在自治功能管理 > 自治功能设置页签中,开启自治功能开关,并在优化和限流页签勾选自动限流,然后设置如下参数作为自动限流的触发条件。
参数
描述
CPU利用率大于
CPU利用率阈值,大于等于70%。
活跃会话数量大于
活跃会话数阈值。
与CPU利用率关系为或时,大于等于16。
与CPU利用率关系为且时,大于等于2。
可限流时间段
可以进行自动SQL限流的时间段。
最大限流时间
进行SQL限流的最大时长。
如果最大限流时间设置为0,当数据库实例状态满足自动SQL限流触发阈值时,会触发限流,但是会立即失效。若选中同时KILL执行中的异常SQL,则异常SQL会被终止执行。
持续时间大于
持续时间阈值,CPU利用率与活跃会话数量满足限流阈值的持续时间超过此参数值时,触发自动SQL限流。
单击确定。
您可以在数据库实例的实例会话中,查看已自动触发的SQL限流,详细操作请参见查看自动SQL限流历史。
说明当自动限流规则创建后,应用端使用了同时包含所有关键词的SQL语句:
RDS MySQL 5.6、RDS MySQL 5.7的实例和PolarDB MySQL版 5.6的集群会返回1317错误(query execution was interrupted)。
RDS MySQL 8.0实例、PolarDB MySQL版 5.7和PolarDB MySQL版 8.0集群会让相关SQL会处于
Concurrency control waiting
状态,直至等待数量超过ccl_max_waiting_count参数的值(如果实例版本支持该参数)时,会返回错误码和错误描述(Concurrency control waiting count exceed max waiting count),错误码分别是:RDS MySQL 8.0为
ERROR 7534 (HY000)
。PolarDB MySQL版 5.7为
ERROR 3277 (HY000)
。PolarDB MySQL版 8.0为
ERROR 7533 (HY000)
。
其中,若ccl_max_waiting_count参数值为默认值0时,所有被限流的SQL均会处于
Concurrency control waiting
状态,不返回错误。通过DAS限流时,若该参数值为0,DAS会将其值设置为DAS的默认值;若用户将其设置为大于0的其他值,DAS不再设置该参数,直接使用用户的设置。
可选:单击事件订阅设置,设置自动SQL限流事件通知。
当发生自动SQL限流时,会生成警告级别的DAS事件,请打开开启订阅服务开关,并配置如下参数:
参数
说明
紧急程度
事件的异常级别,即哪些事件触发后需要通知您。
严重:影响数据库正常运行的事件。
警告:需要关注的可能会影响数据库的事件。
优化:根据数据库运行情况给出的优化建议。
通知:暂无建议的数据库异常事件。
选择联系人(组)
单击
移动到已选联系人(组),触发事件后会通知勾选的联系人或组。
通知方式
触发事件后的通知方式。
手机短信
Webhook
手机短信+Webhook
手机短信+邮件
说明Webhook当前支持钉钉、企业微信、飞书和应用实时监控服务ARMS。
通知语言
当前仅支持中文。
通知最小间隔
再次发起通知的最小时间间隔,即首次通知后,如果事件持续保持触发状态,间隔多久会再次发起通知。
查看自动SQL限流历史
- 登录DAS控制台。
- 在左侧导航栏中,单击实例监控。
- 找到目标实例,单击实例ID,进入目标实例详情页。
在左侧导航栏,单击实例会话。
在实例会话页面:
单击SQL限流:
在运行中页签,查看正在执行的限流规则。
在运行结束页签,选择需要查看的时间段,查看限流历史记录。
如果在配置自动SQL限流参数时,选中同时KILL执行中的异常SQL,则可以单击结束会话历史记录,查看结束会话的历史记录。
了解更多
关于自动SQL限流的详细技术解读,详情请参见自动SQL限流。