[MySQL 5.6] Performance Schema 之 PS配置项(1)

尽管Performance Schema(以下简称PS)在5.5中已经出现,但一直没有使用过,并且相比5.6,5.5的PS表要少很多。 以下从一个初学者的角度,阅读PS的官方文档,做一些简单的笔记

官方文档见:http://dev.mysql.com/doc/refman/5.6/en/performance-schema.html
目录: 
  1. 1.开启PS
  2. 2.配置PS
  3. 2.1 setup_timers表决定了不同的instrument使用的timer类型
  4. 2.2setup_instruments 
  5. 2.3 setup_consumers表 列出了事件信息的消费者类型
  6. 2.4.setup_objects
  7. 2.5.setup_actors

1.开启PS

首先需要强调一点,开启PS是有性能开销的,在一个性能测试场景上,我对比了阿里内部版本的Percona Server 5.5.18与官方MySQL5.6.10,发现在同等压力下,5.6版本有明显的更高的CPU开销(大约高了10~20%)

确认是否开启:
编译阶段:-DWITH_PERFSCHEMA_STORAGE_ENGINE:BOOL=ON    
默认是ON,可以设为OFF来在编译阶段关闭Performance Schema

也可以在启动mysqld时,关闭选项performance_schema

如果你在error log中看到类似错误的PS表结构或者PS表找不到之类的错误,在开启实例后,可以执行一下mysql_upgrade
[ERROR] Native table 'performance_schema'.'events_waits_history' has the wrong structure [ERROR] Native table 'performance_schema'.'events_waits_history_long' 
has the wrong structure 

2.配置PS


Performance Schema可以通过配置setup表来在运行时配置PS,包括以下几个表:

mysql> show tables like ‘%setup%';

+—————————————-+
| Tables_in_performance_schema (%setup%) |
+—————————————-+
| setup_actors                           |
| setup_consumers                        |
| setup_instruments                      |
| setup_objects                          |
| setup_timers                           |
+—————————————-+
5 rows in set (0.00 sec) 

事件的计数设置有两个相关的表:
performance_timers 列出了可用的时间计数器(timer)及其特征 

mysql> SELECT * FROM performance_timers;

+————-+—————–+——————+—————-+
| TIMER_NAME  | TIMER_FREQUENCY | TIMER_RESOLUTION | TIMER_OVERHEAD |
+————-+—————–+——————+—————-+
| CYCLE       |      2490706467 |                1 |             38 |
| NANOSECOND  |      1000000000 |                1 |            128 |
| MICROSECOND |         1000000 |                1 |            135 |
| MILLISECOND |            1036 |                1 |            150 |
| TICK        |             103 |                1 |            450 |
+————-+—————–+——————+—————-+ 


其中CYCLE由CPU  cycle counter 来决定timer
TIMER_FREQUENCY表示每秒内的计数次数,对于CYCLE类型和CPU的速度相关。
TICK取决于不同的平台,例如,在我的机器上,每秒103个tick,tick表示每发生一次timer interrupt的时间间隔,tick的一些概念可以参考网上找到的这篇文章:http://www.360doc.com/content/11/1201/09/1317564_168810003.shtml
TIMER_RESOLUTION表示每次增加计数的单元,如果为10的话,就表示每次值加10
TIMER_OVERHEAD:the minimal number of cycles of overhead to obtain one timing with the given timer

2.1 setup_timers表决定了不同的instrument使用的timer类型

mysql> SELECT * FROM setup_timers;

+———–+————-+
| NAME      | TIMER_NAME  |
+———–+————-+
| idle      | MICROSECOND |
| wait      | CYCLE       |
| stage     | NANOSECOND  | 
| statement | NANOSECOND  |
+———–+————-+
setup_timers 可以配置每种instrument 使用哪种timer, timer必须是performance_timers表中的某一列,可以通过update语句来进行更新 

对于wait类型,最重要的是减少OVERHEAD,所以选择CYCLE类型,相应的代价是损失计时精度
statement或者stage的执行时间总的来说,相比wait要高一个数量级。为了给statement计时,最重要的是原则是要有一个精确的衡量,并且不受处理器频率影响,因此默认的为NANOSECOND,其额外的‘OVERHEAD’相比CYCLE TIMER并不明显,因为调用一个timer两次的开销(一次是statement开始,一次是statement结束)相比statement执行本身的CPU时间要小很多个数量级。如果使用CYCLE,只有坏处,没有好处。
cycle计数器的精度依赖于CPU的速度,使用CYCLE 计数器实际上比使用标准gettimeofday的开销要小,后者的一次调用可能产生上百次cycle。

修改 setup_timers 表会立刻生效,所以可能一个事件的开头和结束使用了两个不同的timer

2.2setup_instruments 

setup_instruments 表中包含了上述四种类型(idle,wait, stage,statement)对应的的instrument,对象可以通过更新ENABLED和TIMED列来决定是否收集对应事件的信息 

mysql> select count(*) from  setup_instruments;

+———-+
| count(*) |
+———-+
|      545 |
+———-+
1 row in set (0.00 sec)

mysql> desc setup_instruments;

+———+——————+——+—–+———+——-+
| Field   | Type             | Null | Key | Default | Extra |
+———+——————+——+—–+———+——-+
| NAME    | varchar(128)     | NO   |     | NULL    |       |
| ENABLED | enum(‘YES’,’NO’) | NO   |     | NULL    |       |
| TIMED   | enum(‘YES’,’NO’) | NO   |     | NULL    |       |
+———+——————+——+—–+———+——-+ 


目前5.6.10的版本有545个instrument可以来做配置。其中ENABLED列表示是否为该instrument收集事件,TIMED列表示是否为该instrument计时;如果TIMED列的值被关闭,就不会去为对应的事件生成TIMER_STARTTIMER_END, 以及 TIMER_WAIT的值

事件的事件被转换为纳秒来统计,不管是使用哪种timer;这主要是为了使用一个统一的时间单位。

2.3 setup_consumers表 列出了事件信息的消费者类型

mysql> SELECT * FROM setup_consumers;

+——————————–+———+
| NAME                           | ENABLED |
+——————————–+———+
| events_stages_current          | YES     |
| events_stages_history          | YES     |
| events_stages_history_long     | YES     |
| events_statements_current      | YES     |
| events_statements_history      | YES     |
| events_statements_history_long | YES     |
| events_waits_current           | YES     |
| events_waits_history           | YES     |
| events_waits_history_long      | YES     |
| global_instrumentation         | YES     |
| thread_instrumentation         | YES     |
| statements_digest              | YES     |
+——————————–+———+
12 rows in set (0.00 sec) 


如果你不关注某个consumer,可以关闭掉,这样服务器就不会去花费时间来维护。例如,如果你不想使用历史事件统计,就可以把几个history事件关闭。主要包括以下几种consumer:

Global and Thread Consumers
a.global_instrumentation是最高层次的consumer,如果将其设置为NO,就会关闭全局instrumentation,其他的consumer都会被忽略掉,不管他们被设置成YSE或者NO。 当global_instrumentation被设置为YES时,就会去维护全局状态,同样也会去检查thread_instrumentation

如果只打开了global_instrumentation而关闭其他consumer,维护的全局状态表包括:
  • mutex_instances

  • rwlock_instances

  • cond_instances

  • file_instances

  • file_summary_by_instance

  • file_summary_by_event_name

  • objects_summary_global_by_type

  • table_lock_waits_summary_by_table

  • table_io_waits_summary_by_index_usage

  • table_io_waits_summary_by_table

  • events_waits_summary_by_instance

  • events_waits_summary_global_by_event_name


b.只有global_instrumentation为YES时才会去检查thread_instrumentation。 如果thread_instrumentation为NO,他会禁止线程级别或者独立事件收集信息。如果设置为YES,则会维护线程级别的信息,同时也会检查 events_xxx_current consumer 

线程级别的信息所对应的表包括:
events_waits_summary_by_thread_by_event_name

Statement Digest Consumer
需要将global_instrumentation设置为YES,否则statements_digest会被忽略掉。它不依赖于 Statement Event consumer,这意味着你可以在每个digest中获得统计信息而无需在 events_statements_current中收集信息,这有利于减少开销

Wait Event Consumers
这些consumer需要global_instrumentation和thread_instrumentation同时设置为YES.包括以下几个:
a.events_waits_current,如果设置为NO,则不为 events_waits_current表收集独立的等待事件。如果为YES,就会开启 events_waits_current表的信息收集,同时检查events_waits_history和events_waits_history_long这两个consumer。
b.events_waits_history,前提是打开events_waits_current,该consumer用于控制表events_waits_history中是否收集信息。
c.events_waits_history_long,前提是打开events_waits_current,该consumer用于控制表events_waits_history_long中是否收集信息。

Stage Event Consumers
这些consumer需要global_instrumentation和thread_instrumentation同时设置为YES.包括以下几个: 

层次关系和Wait Event Consumer类似
events_stages_current , 对应 events_stages_current表
events_stages_history, 对应events_stages_history表
events_stages_history_long,对应events_stages_history_long表 

Statement Event Consumers
events_statements_current,对应events_statements_current等
events_statements_history, 对应events_statements_history
events_statements_history_long,对应events_statements_history_long 

综上,consumer级别为:
global_instrumentation
    |–thread_instrumentation
       |–events_waits_current
          |–events_waits_history
          |–events_waits_history_long
       |–events_stages_current
          |–events_stages_history
          |–events_stages_history_long
       |–events_statements_current
          |–events_statements_history
          |–events_statements_history_long
    |– statements_digest
其中高级别的consumer决定是否去检查低级别的consumer

2.4.setup_objects

setup_objects用于决定哪些对象可以被监控,当前只能控制表对象,该表默认最大可以插入100行记录,但可以通过参数performance_schema_setup_objects_size来调整其大小 

默认状态下,该表的数据包括:

mysql> select * from setup_objects;

+————-+——————–+————-+———+——-+
| OBJECT_TYPE | OBJECT_SCHEMA      | OBJECT_NAME | ENABLED | TIMED |
+————-+——————–+————-+———+——-+
| TABLE       | mysql              | %           | NO      | NO    |
| TABLE       | performance_schema | %           | NO      | NO    |
| TABLE       | information_schema | %           | NO      | NO    |
| TABLE       | %                  | %           | YES     | YES   |
+————-+——————–+————-+———+——-+ 

默认情况下,监控的表对象排除mysql/PS/IS库下的表,其中IS库下的表,不管是否开启,都不会去监控。PS会根据 setup_objects 和setup_instruments来决定是否开启一个instrument并为其计时。对于在setup_objects中的表对象,必须在两个表中都ENABLED才会收集事件信息,如果需要计时,则两者的TIEMD列都必须为YES。

2.5.setup_actors

setup_actors 用于决定新的前台线程的初始监控状态,默认情况下包括所有用户:

mysql> select * from  setup_actors;

+——+——+——+
| HOST | USER | ROLE |
+——+——+——+
| %    | %    | %    |
+——+——+——+
1 row in set (0.00 sec)

该表中的记录可以决定需要对哪些用户线程进行监控,在threads 表中记录了所有的前台/后台线程状态(有点跟PROCESSLIST表类似),并记录其是否被监控。为了让threads生效,需要打开 setup_consumers表中的thread_instrumentation。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/398395.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Tensorflow从入门到精通之——Tensorflow基本操作

前边的章节介绍了什么是Tensorflow,本节将带大家真正走进Tensorflow的世界,学习Tensorflow一些基本的操作及使用方法。同时也欢迎大家关注我们的网站和系列教程:http://www.tensorflownews.com/,学习更多的机器学习、深度学习的知…

一幅长文细学Vue(七)——路由

7 路由 摘要:在本文中我们会谈及路由的知识点,了解前端路由工作的过程以及如何在Vue3中配置路由,知道怎么使用嵌套路由和实现动态路由匹配,以及使用编程式导航和导航守卫。 声明:为了文章的清爽性,在文章内…

[编程题] 按照左右半区的方式重新组合单链表

[编程题] 按照左右半区的方式重新组合单链表 给定一个单链表的头部节点head,链表长度为N。 如果N为偶数,那么前N/2个节点算作左半区,后N/2个节点算作右半区; 如果N为奇数,那么前N/2个节点算作左半区,后N/21…

iOS开发之单例模式

1、概述 单例模式是一种常用的软件设计模式,通过单例模式可以保证系统中一个类只有一个实例而且该实例易于外界访问,从而方便对实例个数的控制并节约系统资源。 如果希望系统中某个类的对象只能存在一个,单例模式是最好的解决方案&#xff0c…

Codeforces 913 二进制背包(柠檬水) 暴力贪心特殊背包(选题)

A B C 给你N(N<30)种水瓶每种水瓶有无限个 每个的体积是2^(i-1)价格是cost[i] 要求你花最少的钱弄出L体积的水 先从前到后扫一遍cost[i1]min(cost[i1],cost[i]*2) 再从后往前扫一遍cost[i]min(cost[i],cost[i1) 保证了价格的最优化 然后从0开始到30 如果二进制有当前体积的…

android baidupush

实战 QQ demo源码&#xff08;本例中有该应用&#xff09; 服务器端下载&#xff1a;http://download.csdn.net/download/knight_black_bob/9822551 android eclipse 版&#xff1a;http://download.csdn.net/download/knight_black_bob/9822553 android stdio 版本&#xff1…

jQuery源码分析--Event模块(1)

jQuery的Event模块提供了强大的功能&#xff1a;事件代理&#xff0c;自定义事件&#xff0c;自定义数据等。今天记录一下它实现的原理。 我们都知道&#xff0c;在js的原生事件中&#xff0c;有事件对象和回调函数这两样东西。但是事件对象是只读的&#xff0c;所以jQuery就用…

tab enter键出现

PHP>code style>formatter>edit>tab policy>space>indentation size > 2转载于:https://www.cnblogs.com/qinqiu/p/8711835.html

JSP内置对象(9个常用的内置对象)

为什么80%的码农都做不了架构师&#xff1f;>>> 2012-08-06 1.request对象 客户端的请求信息被封装在request对象中&#xff0c;通过它才能了解到客户的需求&#xff0c;然后做出响应。它是HttpServletRequest类的实例。 序号 方 法 说 明 1 object getAttribute(S…

用户可计算型出题程序

此次程序是对上次程序的再次开发&#xff0c;我将自己视作另一个在开发者&#xff0c;在对自己前面程序进行再次审视时&#xff0c;有了别样的感受&#xff0c;自己写的程序&#xff0c;一定要为别人(也有可能是自己)留一条活路。闲话不多说&#xff0c;进入大家最喜欢的**环节…

085 Maximal Rectangle 最大矩形

给定一个填充了 0 和 1 的二进制矩阵&#xff0c;找到最大的只包含 1 的矩形并返回其面积。例如&#xff0c;给出以下矩阵&#xff1a;1 0 1 0 01 0 1 1 11 1 1 1 11 0 0 1 0返回 6 详见&#xff1a;https://leetcode.com/problems/maximal-rectangle/description/ Java实现&am…

使用React、Node.js、MongoDB、Socket.IO开发一个角色投票应用的学习过程(三)

前篇 使用React、Node.js、MongoDB、Socket.IO开发一个角色投票应用的学习过程&#xff08;一&#xff09;使用React、Node.js、MongoDB、Socket.IO开发一个角色投票应用的学习过程&#xff08;二&#xff09;原文第十三步&#xff0c;Express API路由 第一个路由是用来创建角色…

匿名方法,lambad表达式,匿名类

其实lambad表达式就是“函数”或者说是“方法”写法的一个进化&#xff0c;越来越简化而已&#xff0c;如数学方法里的f(X)。 匿名方法&#xff1a;顾名思义&#xff0c;匿名方法就是没有名称的方法&#xff0c;但是有定义参数。 匿名方法最明显的好处就是可以降低另写一个方法…

Python3.1-标准库之Numpy

这系列用来介绍Python的标准库的支持Numpy部分。资料来自http://wiki.scipy.org/Tentative_NumPy_Tutorial&#xff0c;页面有许多链接&#xff0c;这里是直接翻译&#xff0c;所以会无法链接。可以大致看完该博文&#xff0c;再去看英文版。 1、先决条件 想要运行numpy&#x…

poxtfix+dovecot+saslauthd+courier-authlib +mysql + extmail 完整虚拟邮箱系统部署

所需软件&#xff1a;平台&#xff0c;RHEL5.8postfix-2.9.15 dovecot系统自带courier-authlib-0.62.4高与0.64本平台可能无法使用mysql 5.7 含&#xff1a;mysql-5.7.12-1.el5.x86_64.rpm mysql-community-client-5.7.12-1.el5.x86_64.rpmmysql-community-common-5.7.12-1.el5…

C++笔记------模版

模版-----是为了让代码更加通用&#xff0c;使代码不受数据类型的影响。减少代码冗余。模版将数据类型当作一个参数进行传递。包括函数模版和类模板。 函数模版&#xff1a; //定义一个比较大小的函数模版 template<typename Type> // 也可以写成 template <class Ty…

黑马Android全套视频无加密完整版

课程描述&#xff1a;java基础到javaweb开发&#xff0c;从基础入门到实战。安卓基础到实战。实体班近5个月的课程实录&#xff01;&#xff01;&#xff01;课程表&#xff1a;xml&dom_sax_dom4j编程tomcat与web程序结构与Http协议与HttpUrlConnectionjava web之servletja…

target runtime apache v7.0 not defined 的解决方法

在工作台目录下找到自己操作的项目的文件夹 /.settings/org.eclipse.wst.common.project.facet.core.xml 删掉 <runtime name"Apache Tomcat v7.0"/> 参考&#xff1a;https://jingyan.baidu.com/album/ce09321b479d102bfe858f66.html?picindex1转载于:https…

强大的CSS3动画库animate.css

今天要给大家介绍一款强大的CSS3动画库animate.css&#xff0c;animate.css定义了大概50多种动画形式&#xff0c;包括淡入淡出&#xff0c;文字飞入、左右摇摆动画等等。使用animate.css也非常简单&#xff0c;你可以给页面上的任意元素&#xff0c;特别是文字添加各种神奇的动…

有关系统环境变量的设置问题

不知道各位朋友有没有想过这样用的问题&#xff0c;我们在使用windows使用在cmd下运行Ping、Netstat等之类的命令时&#xff0c;为什么可以使用呢&#xff1f; 这些后面牵涉到哪些东西呢&#xff1f; 我们今天就来介绍下有关这方面的知识。我们现在以win8作为测试对象&#xff…