站保站

服务市场
  • 网站市场
  • 单机游戏
  • 平台大厅
  • 转让市场
  • 发卡市场
  • 广告市场
  • 下载市场
  • 收录市场
  • 本站平台
    平台客服
    微信Q群



    平台微博/weibo    平台微信/公众号    平台抖音/快手   
    曝光台    保障    地图   
    上传资源 快速赚钱
    站保站    登录      |  注册  |  

    只需一步,快速开始!

     找回密码   |   协议
    热门搜索: 网站开发 App报毒 挖矿源码 代办资质

    学习记录:performance_schema

    • 时间:2020-10-27 16:55 编辑:Ingcom 来源: 阅读:62
    • 扫一扫,手机访问
    摘要:

    学习记录:performance_schema(内容来源:某学习文件)

    重要配置表的相关说明

    /*
    performance_timers表中记录了server中有哪些可用的事件计时器
    字段解释:
    timer_name:表示可用计时器名称,CYCLE是基于CPU周期计数器的定时器
    timer_frequency:表示每秒钟对应的计时器单位的数量,CYCLE计时器的换算值与CPU的频率相关、
    timer_resolution:计时器精度值,表示在每个计时器被调用时额外增加的值
    timer_overhead:表示在使用定时器获取事件时开销的最小周期值
    */
    select * from performance_timers;

    /*
    setup_timers表中记录当前使用的事件计时器信息
    字段解释:
    name:计时器类型,对应某个事件类别
    timer_name:计时器类型名称
    */
    select * from setup_timers;

    /*
    setup_consumers表中列出了consumers可配置列表项
    字段解释:
    NAME:consumers配置名称
    ENABLED:consumers是否启用,有效值为YES或NO,此列可以使用UPDATE语句修改。
    */
    select * from setup_consumers;

    /*
    setup_instruments 表列出了instruments 列表配置项,即代表了哪些事件支持被收集:
    字段解释:
    NAME:instruments名称,instruments名称可能具有多个部分并形成层次结构
    ENABLED:instrumetns是否启用,有效值为YES或NO,此列可以使用UPDATE语句修改。如果设置为NO,则这个instruments不会被执行,不会产生任何的事件信息
    TIMED:instruments是否收集时间信息,有效值为YES或NO,此列可以使用UPDATE语句修改,如果设置为NO,则这个instruments不会收集时间信息
    */
    SELECT * FROM setup_instruments;

    /*
    setup_actors表的初始内容是匹配任何用户和主机,因此对于所有前台线程,默认情况下启用监视和历史事件收集功能
    字段解释:
    HOST:与grant语句类似的主机名,一个具体的字符串名字,或使用“%”表示“任何主机”
    USER:一个具体的字符串名称,或使用“%”表示“任何用户”
    ROLE:当前未使用,MySQL 8.0中才启用角色功能
    ENABLED:是否启用与HOST,USER,ROLE匹配的前台线程的监控功能,有效值为:YES或NO
    HISTORY:是否启用与HOST, USER,ROLE匹配的前台线程的历史事件记录功能,有效值为:YES或NO
    */
    SELECT * FROM setup_actors;

    /*
    setup_objects表控制performance_schema是否监视特定对象。默认情况下,此表的最大行数为100行。
    字段解释:
    OBJECT_TYPE:instruments类型,有效值为:“EVENT”(事件调度器事件)、“FUNCTION”(存储函数)、“PROCEDURE”(存储过程)、“TABLE”(基表)、“TRIGGER”(触发器),TABLE对象类型的配置会影响表I/O事件(wait/io/table/sql/handler instrument)和表锁事件(wait/lock/table/sql/handler instrument)的收集
    OBJECT_SCHEMA:某个监视类型对象涵盖的数据库名称,一个字符串名称,或“%”(表示“任何数据库”)
    OBJECT_NAME:某个监视类型对象涵盖的表名,一个字符串名称,或“%”(表示“任何数据库内的对象”)
    ENABLED:是否开启对某个类型对象的监视功能,有效值为:YES或NO。此列可以修改
    TIMED:是否开启对某个类型对象的时间收集功能,有效值为:YES或NO,此列可以修改
    */
    SELECT * FROM setup_objects;

    /*
    threads表对于每个server线程生成一行包含线程相关的信息,
    字段解释:
    THREAD_ID:线程的唯一标识符(ID)
    NAME:与server中的线程检测代码相关联的名称(注意,这里不是instruments名称)
    TYPE:线程类型,有效值为:FOREGROUND、BACKGROUND。分别表示前台线程和后台线程
    PROCESSLIST_ID:对应INFORMATION_SCHEMA.PROCESSLIST表中的ID列。
    PROCESSLIST_USER:与前台线程相关联的用户名,对于后台线程为NULL。
    PROCESSLIST_HOST:与前台线程关联的客户端的主机名,对于后台线程为NULL。
    PROCESSLIST_DB:线程的默认数据库,如果没有,则为NULL。
    PROCESSLIST_COMMAND:对于前台线程,该值代表着当前客户端正在执行的command类型,如果是sleep则表示当前会话处于空闲状态
    PROCESSLIST_TIME:当前线程已处于当前线程状态的持续时间(秒)
    PROCESSLIST_STATE:表示线程正在做什么事情。
    PROCESSLIST_INFO:线程正在执行的语句,如果没有执行任何语句,则为NULL。
    PARENT_THREAD_ID:如果这个线程是一个子线程(由另一个线程生成),那么该字段显示其父线程ID
    ROLE:暂未使用
    INSTRUMENTED:线程执行的事件是否被检测。有效值:YES、NO
    HISTORY:是否记录线程的历史事件。有效值:YES、NO *
    THREAD_OS_ID:由操作系统层定义的线程或任务标识符(ID):
    */
    select * from threads

    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 COUNT_STAR DESC
    –3、哪类SQL排序记录数最多?
    SELECT DIGEST_TEXT,SUM_SORT_ROWS FROM events_statements_summary_by_digest ORDER BY COUNT_STAR DESC
    –4、哪类SQL扫描记录数最多?
    SELECT DIGEST_TEXT,SUM_ROWS_EXAMINED FROM events_statements_summary_by_digest ORDER BY COUNT_STAR DESC
    –5、哪类SQL使用临时表最多?
    SELECT DIGEST_TEXT,SUM_CREATED_TMP_TABLES,SUM_CREATED_TMP_DISK_TABLES FROM events_statements_summary_by_digest ORDER BY COUNT_STAR DESC
    –6、哪类SQL返回结果集最多?
    SELECT DIGEST_TEXT,SUM_ROWS_SENT FROM events_statements_summary_by_digest ORDER BY COUNT_STAR DESC
    –7、哪个表物理IO最多?
    SELECT file_name,event_name,SUM_NUMBER_OF_BYTES_READ,SUM_NUMBER_OF_BYTES_WRITE FROM file_summary_by_instance ORDER BY SUM_NUMBER_OF_BYTES_READ + SUM_NUMBER_OF_BYTES_WRITE DESC
    –8、哪个表逻辑IO最多?
    SELECT object_name,COUNT_READ,COUNT_WRITE,COUNT_FETCH,SUM_TIMER_WAIT FROM table_io_waits_summary_by_table ORDER BY sum_timer_wait DESC
    –9、哪个索引访问最多?
    SELECT OBJECT_NAME,INDEX_NAME,COUNT_FETCH,COUNT_INSERT,COUNT_UPDATE,COUNT_DELETE FROM table_io_waits_summary_by_index_usage ORDER BY SUM_TIMER_WAIT DESC
    –10、哪个索引从来没有用过?
    SELECT OBJECT_SCHEMA,OBJECT_NAME,INDEX_NAME FROM table_io_waits_summary_by_index_usage WHERE INDEX_NAME IS NOT NULL AND COUNT_STAR = 0 AND OBJECT_SCHEMA <> ‘mysql’ ORDER BY OBJECT_SCHEMA,OBJECT_NAME;
    –11、哪个等待事件消耗时间最多?
    SELECT EVENT_NAME,COUNT_STAR,SUM_TIMER_WAIT,AVG_TIMER_WAIT FROM events_waits_summary_global_by_event_name WHERE event_name != ‘idle’ ORDER BY SUM_TIMER_WAIT DESC
    –12-1、剖析某条SQL的执行情况,包括statement信息,stege信息,wait信息
    SELECT EVENT_ID,sql_text FROM events_statements_history WHERE sql_text LIKE ‘%count(*)%’;
    –12-2、查看每个阶段的时间消耗
    SELECT event_id,EVENT_NAME,SOURCE,TIMER_END - TIMER_START FROM events_stages_history_long WHERE NESTING_EVENT_ID = 1553;
    –12-3、查看每个阶段的锁等待情况
    SELECT event_id,event_name,source,timer_wait,object_name,index_name,operation,nesting_event_id FROM events_waits_history_longWHERE nesting_event_id = 1553;

    • 全部评论(0)
    • 最新

    信息加载中,请等待

    微信客服(速回)

    微信客服(慢回)



    企业微信客服二维码
    联系我们
    平台客服: 平台QQ客服

    平台电话:400电话迁移中!

    平台邮箱:28292383@qq.com

    工作时间:周一至周五:早10:00 晚:18:00

    营业执照     网站ICP备案:鲁ICP备20027607号-1     鲁公网安备:37068702000078号     增值电信业务经营许可证、在线数据与交易处理业务许可证:鲁B2-20200681      © 2016-2024 站保站  https://www.zhanbaozhan.com/ 版权所有!      平台规范:   关于我们   广告合作   隐私条款   免责声明   法律声明   服务条款   网站地图   平台工单!