Loading [MathJax]/jax/input/TeX/config.js
前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >MySQL增删改查语句_MySQL comment

MySQL增删改查语句_MySQL comment

作者头像
Java架构师必看
发布于 2022-10-05 07:35:55
发布于 2022-10-05 07:35:55
3.4K00
代码可运行
举报
文章被收录于专栏:Java架构师必看Java架构师必看
运行总次数:0
代码可运行

大家好,我是架构君,一个会写代码吟诗的架构师。今天说一说MySQL增删改查语句_MySQL comment,希望能够帮助大家进步!!!

1.前言

mysql慢查询,已经有现成的成熟的方案收集展示了:pt-query-digest结合box公司的anemometer,没用过的移步:《mysql慢查询可视化》(本章内容需要提前了解anemometer)。

但DBA们一定还遇到过这样的问题:某个时间段CPU负载较高,但慢查却没有。这种情况一般是由高并发的但单个性能正常的SQL导致的,所以慢查没有,但总体负载会升高。

那怎么办呢?

选择1:配置events_statements_history_long,缺点明显:数据很容易被覆盖,查看不便。

选择2:之前本人参考oracle原生的一个功能,每10s自动抓一次活动会话,记录到表中,但有个明显的缺点:从库event_scheduler都是不开的,导致从库没法做。

针对该痛点,本人设计了一个定时收集events_statements_summary_by_digest,并通过amemometer展示的方案。

2.功能展示

选择时间段、host(沿用的慢查中的名称,理解为mysql实例):

展示每个digest的总次数、最高执行频率(按分钟)、平均耗时(毫秒)

点击checksum,查看某个SQL执行频率的走势图,展示每分钟执行的次数

按天聚合:

如果想查看执行频率波动有异常,可以在having中添加条件:

最高频率是平均频率的3倍:max(ts_cnt) > (sum(ts_cnt)/count(*)) * 3

3.实现逻辑

3.1.数据来源

events_statements_summary_by_digest

默认performance_schema_digests_size=10000,SQL digest较多的库要调整到20000以上;

参数不能动态调整,没有停机时间的实例可以监控记录数,满了truncate即可。

3.2.表结构

global_query_review、global_query_review_history直接沿用慢查的表结构,字段不变;

db_instance实:例配置表,记录实例的信息,python自动定时扫描该表。

3.3.python程序

python程序由两个JOB构成:

job1:check_db_pool:定时扫描db_instance表,更新连接池

job2:handle_db_all: 定时处理所有实例的数据入库

job1

目标库连接池存放在字典:db_pool_dic

获取实例ip\端口等信息,包括ischanged(最近1分钟实例信息是否改变):get_instance()

按顺序处理一下逻辑:

  • 在db_pool_dic中,但不在get_instance()中的,从db_pool_dic中删除
  • 检查db_pool_dic连接池的有效性(select 1),无效则删除
  • 在get_instance()中,ischanged="changed",且在db_pool_dic中的,从db_pool_dic中删除
  • 在get_instance()中,但不在db_pool_dic中,创建连接池,增加到db_pool_dic

job2

遍历get_instance(),以线程方式处理每个目标库:handle_db

handle_db主要任务是获取最近1分钟内每个digest执行次数的增量,入库

增量是通过连续2次获取的digest执行次数相减得到

按顺序执行以下过程:

  • 从redis中获取上次set的digest信息:df_full_last_bytes=rs.get(redis_key_name)
  • 查询digest中LAST_SEEN>now()-1mins的数据:df_1min
  • 查询digest全量信息:df_full
  • 如果df_full_last_bytes为空:return
  • df_full_last_bytes与df_1min关联,计算增量
  • redis set df_full_last_bytes,有效期90秒

补充2个SQL

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
df_full:
select concat('instance_name','-',digest,'-',ifnull(schema_name,'unknow')) checksum ,sum(count_star) count_star
from events_statements_summary_by_digest where digest is not NULL
group by checksum

df_1min:
select concat('instance_name ','-',digest,'-',ifnull(schema_name,'unknow')) checksum,ifnull(schema_name,'unknow') as db_max,
count_star,digest_text,round(avg_timer_wait/1000000000,1) query_time_avg
from events_statements_summary_by_digest
where LAST_SEEN > DATE_SUB(now(),INTERVAL 1 minute)
and digest is not NULL

只听到从架构师办公室传来架构君的声音:

东风恶,欢情薄。有谁来对上联或下联?

4. 表结构

创建管理库:digest_stat

4.1. db_instance

instance_name:自定义的实例名,唯一约束;

update_time数据变更后自动更新,python程序根据该字段更新连接池配置信息;

status:目标库是否激活,启用。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
此代码由Java架构师必看网-架构君整理
CREATE TABLE `db_instance` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `instance_name` varchar(50) COLLATE utf8mb4_bin NOT NULL,
  `ip_addr` varchar(15) COLLATE utf8mb4_bin NOT NULL,
  `port` int(11) NOT NULL,
  `user_name` varchar(50) COLLATE utf8mb4_bin NOT NULL,
  `password` varchar(50) COLLATE utf8mb4_bin NOT NULL,
  `status` int(1) NOT NULL DEFAULT '0' COMMENT '0:active, 1:inactive',
  `create_time` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP,
  `update_time` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP,
  PRIMARY KEY (`id`),
  UNIQUE KEY `idxu_instancename` (`instance_name`),
  UNIQUE KEY `idx_ip_port` (`ip_addr`,`port`)
) ENGINE=InnoDB

4.2. global_query_review

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
CREATE TABLE `global_query_review` (
  `checksum` varchar(200) NOT NULL,
  `fingerprint` text NOT NULL,
  `sample` longtext,
  `first_seen` datetime DEFAULT NULL,
  `last_seen` datetime DEFAULT NULL,
  `reviewed_by` varchar(20) DEFAULT NULL,
  `reviewed_on` datetime DEFAULT NULL,
  `comments` text,
  `reviewed_status` varchar(24) DEFAULT NULL,
  PRIMARY KEY (`checksum`)
) ENGINE=InnoDB

4.3.global_query_review_history

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
此代码由Java架构师必看网-架构君整理
CREATE TABLE `global_query_review_history` (
  `hostname_max` varchar(64) NOT NULL,
  `db_max` varchar(64) DEFAULT NULL,
  `checksum` varchar(200) NOT NULL,
  `sample` longtext,
  `ts_min` datetime NOT NULL DEFAULT '0000-00-00 00:00:00',
  `ts_max` datetime NOT NULL DEFAULT '0000-00-00 00:00:00',
  `ts_cnt` float DEFAULT NULL,
  `query_time_avg` float DEFAULT NULL,
  UNIQUE KEY `hostname_max` (`hostname_max`,`checksum`,`ts_min`,`ts_max`),
  KEY `ts_min` (`ts_min`),
  KEY `checksum` (`checksum`)
) ENGINE=InnoDB

该表记录数会很多,我司的3个库,保留了2天数据,记录数分别为41w,84w,163w

因此:

1,一定要对该表自动清理,一般不要超过7天;

2、可以调整python数据抽取策略,如每分钟超过30次的才收集,平均耗时大于1毫秒的才收集,等等

5. Anemometer程序调整

在慢查调整过的基础上,再做以下调整:

  1. conf/datasource_slowlog.inc.php

修改数据库信息

  1. conf/config.inc.php
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
$conf['history_defaults'] = array(
'table_fields' => array('date', 'cnt','max_freq','first_seen','last_seen','query_time_avg')

$conf['report_defaults'] = array(
 'fact-order'    => 'cnt DESC',
 'table_fields' => array('checksum','hostname','db','sql_short','cnt','max_freq','first_seen','last_seen','query_time_avg'),
 'dimension-hostname_max' => '一个默认的实例名称'   ##  指定实例默认值,否则默认查所有数据,响应慢

        'custom_fields' => array(
                'checksum' => 'checksum',
                'hostname' => 'hostname_max',
                'db' => 'db_max',
                'sql_short' => 'LEFT(fact.sample,30)',
                'cnt' => 'sum(ts_cnt)',
                'max_freq' => 'max(ts_cnt)',
                'query_time_avg' => 'ROUND(avg(query_time_avg),1)',
                'first_seen'  => 'substring(min(ts_min),1,16)',
                'last_seen'  => 'substring(max(ts_max),1,16)',
                'date' => 'substring(ts_min,1,10)',
                'minute_ts'     => 'round(unix_timestamp(substring(ts_min,1,16)))'
        ),
代码语言:txt
AI代码解释
复制
3. lib/Anemometer.php 
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
    private function translate_checksum($checksum)
    {
        {
            //throw new Exception("Invalid query checksum");
            return $checksum;
        }
    }

最后,具体python程序见:https://github.com/meishd/mysql_allsql_digest/

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2022-10-042,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
MySQL性能监控全掌握,快来get关键指标及采集方法!
数据库中间件监控实战,MySQL中哪些指标比较关键以及如何采集这些指标了。帮助提早发现问题,提升数据库可用性。
JavaEdge
2023/05/03
3K0
MySQL性能监控全掌握,快来get关键指标及采集方法!
MySQL performance_schema 常用性能诊断查询
--1、哪类的SQL执行最多? SELECT DIGEST_TEXT,COUNT_STAR,FIRST_SEEN,LAST_SEEN FROM events_statements_summary_by_digest ORDER BY COUNT_STAR DESC --2、哪类SQL的平均响应时间最多? SELECT DIGEST_TEXT,AVG_TIMER_WAIT FROM events_statements_summary_by_digest ORDER BY AVG_TIMER_WAIT DESC
用户1148526
2022/04/13
8490
Percona Toolkit 神器全攻略(监控类)
pt-deadlock-logger 概要 提取和记录MySQL/GreatSQL死锁 用法
GreatSQL社区
2024/07/06
1370
Percona Toolkit 神器全攻略(监控类)
MYSQL 8 从PS说起,但不止于PS , 不在使用淘汰的慢查询日志,那我怎么查慢查询(6)
这是关于MYSQL8 获取信息的方式的第六篇,终于到达了慢日志查询的位置,在MYSQL的DBA 的管理员的心目中,pt-query-digest 和 SLOW QUERY LOG 是分析慢查询的唯一的方式。实际上在MYSQL 8 中这样的慢查询的数据获取方式,已经被淘汰了,或者说不合时宜了。
AustinDatabases
2022/04/05
1.4K0
MYSQL 8 从PS说起,但不止于PS , 不在使用淘汰的慢查询日志,那我怎么查慢查询(6)
Python之Pymysql模块实现MySQL增删改查
PyMySQL 是在 Python3.x 版本中用于连接 MySQL 服务器的一个库,Python2中则使用mysqldb。
王大力测试进阶之路
2020/01/17
3.3K0
Python之Pymysql模块实现MySQL增删改查
MySQL PERFORMANCE_SCHEMA监控用法详解
MySQL 5.5开始新增一个数据库:PERFORMANCE_SCHEMA,主要用于收集数据库服务器性能参数。并且库里表的存储引擎均为PERFORMANCE_SCHEMA,而用户是不能创建存储引擎为PERFORMANCE_SCHEMA的表。
Power
2025/02/28
1080
Airflow秃头两天填坑过程:任务假死问题
既然秃头填坑, 那就该让这变得更加有价值, 有必要总结出来, 减少其他同事踩坑的可能。
明月AI
2021/10/28
2.8K3
Airflow秃头两天填坑过程:任务假死问题
利用MySQL系统数据库做性能负载诊断
1,在稳定性层面来说,更多的是关注高可用、读写分离、负载均衡,灾备管理等等high level层面的措施(就好比要保证生活的稳定性)
星哥玩云
2022/08/18
2.2K0
利用MySQL系统数据库做性能负载诊断
Mysql增删改查sql语句练习
Mysql增删改查sql语句练习 关于数据库的一些操作: 进入mysql 命令行: mysql -uroot –p 查看所有数据库: show databases; 创建数据库: create database wg charset utf8; 删除数据库: drop database wg; 选择数据库: use databases; 查看所有表: show tables; 查看创建数据库的语句:show create database databasename; 查看创建表的语句:show create table tablename; 查看表结构:desc tablename; 增: mysql> use wg; mysql> create table students( id int auto_increment primary key,name varchar(10) not null,sex varchar(12),address varchar(50),phone int not null unique); #自增长 auto_increment #非空 not null #默认值 default ‘xx’ #唯一 unique #指定字符集 charset #主键 primary key mysql> create table scores(id int auto_increment primary key,s_id int not null,grade float not null); 数据: mysql> insert into student (id,name,sex,phone) values(122,’wg’,’男’,’110’); mysql> insert into students values(111,’wg’,’121’,’dd’) ; 删: mysql> drop table tablename; mysql> truncate tablename; 快速删除表数据,自增长id从头在来,快速,从磁盘直接删除,不可恢复 mysql> delete from student; 删除整个表的数据,自增长继续 改: mysql> alter table oldtable rename newtable; 改表名 mysql> alter table scores modify s_id varchar(20);
全栈程序员站长
2022/07/25
2.2K0
Mysql增删改查sql语句练习
mysql主从同步(3)-percona-toolkit工具(数据一致性监测、延迟监控)使用梳理
在mysql工作中接触最多的就是mysql replication,mysql在复制方面还是会有一些常规问题,比如主库宕机或者从库宕机有可能会导致复制中断,通常需要进行人为修复,或者很多时候需要把一个从库提升为主库,但对从库和主库的数据一致性不能保证一样。这种情况下就需要使用percona-toolkit工具的pt-table-checksum组件来检查主从数据的一致性;如果发现不一致的数据,可以通过pt-table-sync修复;还可以通过pt-heartbeat监控主从复制延迟。当然如果数据量小,sla
洗尽了浮华
2018/01/22
3.3K0
语句效率统计视图 | 全方位认识 sys 系统库
在上一篇《统计信息查询视图|全方位认识 sys 系统库》中,我们介绍了利用sys 系统库的查询统计信息的快捷视图,本期将为大家介绍语句查询效率语句统计信息相关的视图,这些视图可以快速找出数据库中哪些语句使用了全表扫描、哪些语句使用了文件排序、哪些语句使用了临时表。
沃趣科技
2018/09/12
1.7K0
语句效率统计视图 | 全方位认识 sys 系统库
MySQL诊断调优常用SQL语
在很多时候,我们需要通过SQL语句来查看MySQL执行SQL的情况,例如查看SQL执行队列,是否存在慢查询等等。
苦叶子
2019/05/30
1.1K0
Mysql 优化——分析表读写和sql效率问题
上次我们说到mysql的一些sql查询方面的优化,包括查看explain执行计划,分析索引等等。 今天我们分享一些 分析mysql表读写、索引等等操作的sql语句。
执笔记忆的空白
2020/12/25
9750
MySQL表的增删改查(进阶)
在MySQL中,约束用于定义表中数据的规则,保证数据的一致性、完整性和准确性。以下是常见的数据库约束类型:
E绵绵
2025/02/20
1450
MySQL表的增删改查(进阶)
02 . Mysql基础操作及增删改查
SQL(Structured Query Language 即结构化查询语言) SQL语言主要用于存取数据、查询数据、更新数据和管理关系数据库系统,SQL语言由IBM开发。
iginkgo18
2020/09/27
1.9K0
事件统计 | performance_schema全方位介绍
在上一篇 《事件记录 | performance_schema全方位介绍"》中,我们详细介绍了performance_schema的事件记录表,恭喜大家在学习performance_schema的路上度过了两个最困难的时期。现在,相信大家已经比较清楚什么是事件了,但有时候我们不需要知道每时每刻产生的每一条事件记录信息, 例如:我们希望了解数据库运行以来一段时间的事件统计数据,这个时候就需要查看事件统计表了。今天将带领大家一起踏上系列第四篇的征程(全系共7个篇章),在这一期里,我们将为大家全面讲解performance_schema中事件统计表。统计事件表分为5个类别,分别为等待事件、阶段事件、语句事件、事务事件、内存事件。下面,请跟随我们一起开始performance_schema系统的学习之旅吧。
沃趣科技
2018/07/02
2K0
事件统计 | performance_schema全方位介绍
SQLite实时增删改查
至于要调用那些增删改查的方法,实质上就是在拼接这些基本语句,只要掌握住这些基本语句,那些方法要传什么参数也就很好理解了
fanfan
2022/05/07
1.2K0
SQLite实时增删改查
MySQL入门,问题不大【增删改查极速上手】
当你登录你的QQ账号和别人吹水的时候,当你期末交作业去度娘复制的时候,当你在工作中登录一些网站的时候,再比如当你查看自己几乎没有什么余额的银行卡的时候(捂脸),或许自己也没注意,(非需要,大部分人也不想注意哈哈哈)我们一直都在以某种方式与数据库打交道,或许你是一个开发人员,也或许你也只是一个普通的用户,数据库与我们的生活息息相关,作为一名程序员,现在学习 MySQL 和 Oracle 的会多一些,像微软的 SQL Server 以前配合 asp 的时候用的还是挺多的,不过现在就没那么流行了,
BWH_Steven
2020/06/03
7730
数据库中间件ProxySQL读写自动分离实践
腾讯云cdb可以提供主库VIP+只读从库VIP的形式,这样开发使用时需要维护2个VIP而且不能自动读写分离,基于现状计划使用proxysql结合clb及cdb来实现读写自动分离。 架构如下: app--clb四层--proxysql--主vip+自读vip
三杯水Plus
2019/12/30
6040
MYSQL常用SQL汇总
1、查看当前应用连接,连接数突增排查 select user,SUBSTRING_INDEX(host,':',1) as ip , count(*) as count,db from information_schema.processlist where host not in ('localhost') and user not in ('replicater') group by ip order by count; 2、查看表所属及大概行数,一般加字段索引时做参考 select TABLE_SCH
MySQL轻松学
2018/03/09
1.2K0
相关推荐
MySQL性能监控全掌握,快来get关键指标及采集方法!
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
本文部分代码块支持一键运行,欢迎体验
本文部分代码块支持一键运行,欢迎体验