GaussDB数据库中SQL诊断解析之配置SQL限流

devtools/2024/12/22 1:45:09/

配置SQL限流

GaussDB提供SQL限流功能,当存在异常SQL(如存在不优索引)、SQL并发量上升时,通过SQL限流功能控制异常SQL的访问量或者并发量,保障服务的可用性。

前提条件

登录账号需要具备授权项“gaussdb:instance:listFlowlimit”、“gaussdb:instance:flowlimitAddOrUpdate”、“gaussdb:instance:createFlowLimit”、“gaussdb:instance:updateFlowLimit”、“gaussdb:instance:deleteFlowLimit”、“gaussdb:instance:getFlowLimitInfo”、“gaussdb:instance:getFlowLimitTemplate”、“gaussdb:instance:listFlowLimitInfo”、"gaussdb:instance:syncFlowLimit"和“gaussdb:instance:flowlimitDelete”。

约束限制

GaussDB实例的数据库引擎版本需要大于等于V2.0-8.0.1,内核版本大于等于505.0.0。
分布式不支持自治限流任务。

  • 分布式实例不支持SQLID类型的限流。
  • 不支持对系统级别用户(例如root等)进行SQL限流。
  • 当前不支持批量删除SQL限流任务。
  • 每个实例最多支持1000条限流任务。
  • 对于关键词限流任务,一个关键词中包含英文逗号视作以逗号分割的两个关键词,作用时不区分关键词前后顺序。
  • 用户通过系统级别用户(例如root等)进行后台SQL限流的增删改,会导致实际限流任务情况与前端不一致。
  • 限流规则匹配会消耗CPU性能,建议同一个实例里不要创建大量限流规则。
  • 新添加SQL限流规则之前已经开始执行的SQL语句不会被计入并发数。
  • 容灾场景下,主实例上的限流规则会自动同步到备实例,容灾升主后暂时不支持限流规则的增删改查,切回原实例后可继续管理限流任务。
  • 备份恢复到新实例、容灾场景切回原实例,如果出现数据丢失的情况,请参考故障处理。
  • 实例异常和规格变更期间允许创建、修改、查看限流规则,但可能会失败,如果出现失败或异常可
  • 以通过删除限流规则处理,删除前请确保数据库正常。
  • 驱动建立数据库连接涉及的SQL语句(如:select setting from pg_settings where name=‘delimiter_name’)被限流会导致无法新建连接,不允许该类SQL的限流操作。
  • 实例节点在创建、重启过程中(比如扩副本、扩分片),可能会因为节点无法连接导致SQL限流任务详情查询异常。
  • 灰度升级期间或容灾升主后双主场景下原备实例的限流创建、修改、删除限流规则会触发任务流校验,返回“当前实例正在有其他操作”的错误信息,而限流任务一直显示创建中、修改中或删除中,可
  • 以通过单击“数据同步”恢复数据的正常。
  • 内核如果抛出报错信息,如ERROR: The workload rule takes effect and this request will be cancelled. rule_id: x, rule_name: “xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx”,其中rule_name对应Console控制台“限流任务ID”,对应审计日志task id。
  • 当多个限流任务规则同时生效于同一条SQL语句,存在生效优先级:
  • 并发数/最大活跃会话数的数量越小优先级越高。
  • 并发数/最大活跃会话数相同时,优先级:自治限流任务>SQLID类型>关键词类型。
  • 并发数/最大活跃会话数相同且限流类型一致时,后创建的限流任务优先拦截。
  • 避免创建同名表。如果不同Database或不同SCHEMA下存在同名表,创建该表相关的SQLID限流任务时,限流规则可能不生效。

创建限流任务

登录管理控制台。

单击管理控制台左上角的,选择区域和项目。
在页面左上角单击,选择“数据库 > 云数据库 GaussDB”,进入云数据库 GaussDB信息页面。
在“实例管理”页面,选择指定的实例,单击实例的名称,进入实例详情页面。
选择“诊断优化 > SQL诊断 > SQL限流”。
选择“SQL限流任务”或“自治限流任务”,单击“创建任务”,填写限流信息,具体参数填写请参考表1。
创建SQL限流任务

图1 创建SQL限流任务
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

数据同步

登录管理控制台。

单击管理控制台左上角的,选择区域和项目。
在页面左上角单击,选择“数据库 > 云数据库 GaussDB”,进入云数据库 GaussDB信息页面。
在“实例管理”页面,选择指定的实例,单击实例的名称,进入实例详情页面。
选择“诊断优化 > SQL诊断 > SQL限流”。
单击“数据同步”。
弹框中单击“确定”可以进行备份原实例后的数据同步。
图5 数据同步

在这里插入图片描述


http://www.ppmy.cn/devtools/144240.html

相关文章

接口测试-Fidder及jmeter使用

一、接口测试的基础 1.接口的含义 也叫做API,是一组定义、程序及协议的集合,提供访问一组例程的能力,无需访问源码获理解内部工作细节 2.接口的分类 代码内部的接口,程序模块间的接口,对于程序接口测试,需…

springboot中Controller内文件上传到本地以及阿里云

上传文件的基本操作 <form action"/upload" method"post" enctype"multipart/form-data"> <h1>登录</h1> 姓名&#xff1a;<input type"text" name"username" required><br> 年龄&#xf…

图书馆管理系统(三)基于jquery、ajax

任务3.4 借书还书页面 任务描述 这部分主要是制作借书还书的界面&#xff0c;这里我分别制作了两个网页分别用来借书和还书。此页面&#xff0c;也是通过获取books.txt内容然后添加到表格中&#xff0c;但是借还的操作没有添加到后端中去&#xff0c;只是一个简单的前端操作。…

python飞机大战游戏.py

python飞机大战游戏.py import pygame import random# 游戏窗口大小 WINDOW_WIDTH 600 WINDOW_HEIGHT 800# 颜色定义 BLACK (0, 0, 0) WHITE (255, 255, 255)# 初始化Pygame pygame.init()# 创建游戏窗口 window pygame.display.set_mode((WINDOW_WIDTH, WINDOW_HEIGHT))…

电商数据增长背后的驱动力:API接口技术解析

在数字化浪潮席卷全球的今天&#xff0c;电商行业作为数字经济的重要组成部分&#xff0c;正以前所未有的速度蓬勃发展。电商数据的迅猛增长&#xff0c;不仅反映了消费者购物习惯的变化&#xff0c;也揭示了背后强大的技术驱动力。其中&#xff0c;API&#xff08;Application…

Flutter 多个弹窗关闭指定弹窗

前言 大家都知道Flutter的页面是堆栈式管理&#xff0c;通常关闭页面是最后进入的最先关闭&#xff0c;通过pop进行一个退栈操作。 但是我碰到一个问题&#xff0c;有时需要在同一页面上显示多个弹窗。如果此时需要关闭指定的某一个弹窗&#xff0c;那退栈操作明显不合适了&a…

Java 和 J2EE 有什么不同?

Java 和 J2EE 有什么不同&#xff1f; 一. Java的理解二. 什么是 J2EE三. Java 和 J2EE 的主要区别四. 结论 前言 这是我在这个网站整理的笔记,有错误的地方请指出&#xff0c;关注我&#xff0c;接下来还会持续更新。 作者&#xff1a;神的孩子都在歌唱 Java 和 J2EE&#xff…

SpringBoot+Vue3实现阿里云视频点播 实现教育网站 在上面上传对应的视频,用户开会员以后才能查看视频

要使用阿里云视频点播&#xff08;VOD&#xff09;实现一个教育网站&#xff0c;其中用户需要成为会员后才能查看视频&#xff0c;这个过程包括上传视频、设置权限控制、构建前端播放页面以及确保只有付费会员可以访问视频内容。 1. 视频上传与管理 创建阿里云账号&#xff…