凭啥让人一边骂一边买,配置详解

原标题:华为用户感动哭!历史一刻到来:终于支持微信指纹支付

原标题:配置详解 | performance_schema全方位介绍(二)

原标题:iPhone,凭啥让人一边骂一边买?

在指纹识别功能已经成为手机标配的今天,绝大多数的智能手机都支持指纹功能和包括指纹支付在内的衍生功能,甚至像iPhone X、OPPO Find X等手机更是更进一步,采用了技术含量更高的3D结构光技术进行加密解锁和支付,智能手机的生物加密解锁功能已经非常完善。

澳门威利斯人手机版 1

苹果秋季新品发布会即将到来,这场可以用“盛宴”二字来形容的发布会,吸引着全世界科技爱好者的关注。而这一切,源于十一年前的初代iPhone面世。

然而让人感到奇怪的是,在微信支付快速发展的今天,华为手机却不支持微信指纹支付,每次支付都需要手动输入六位数密码,实在是让人摸不着头脑。而且,过去华为Mate 7还是首批支持微信指纹支付的手机,今天怎么反而开倒车了呢?

罗小波·沃趣科技高级数据库技术专家

期间的18款iPhone产品,让苹果成为行业的引领者,也助力其成为世界上首个市值超过1万亿美元的上市公司。

澳门威利斯人手机版 2

出品:沃趣科技

澳门威利斯人手机版 3

华为和腾讯从未就这个问题公开回应过消费者的疑问,所以背后的恩怨纠葛我们也无法得知。而恩怨总是要化解的,早前小雷(微信:leitech)就曾报道,华为宣布将会在10月起陆续推送新固件,从而让旗下产品支持微信指纹支付。今天又有一个好消息传来,华为nova 3和nova 3i的新固件已经准备好,当用户升级之后,就可以支持微信指纹支付了。

IT从业多年,历任运维工程师、高级运维工程师、运维经理、数据库工程师,曾参与版本发布系统、轻量级监控系统、运维管理平台、数据库管理平台的设计与编写,熟悉MySQL体系结构,Innodb存储引擎,喜好专研开源技术,追求完美。

当然作为普通消费者的我们,更在意产品如何。

澳门威利斯人手机版 4

| 导语

一个显著的点,iPhone的售价大有越走越高的趋势,而且十分有趣的是,未拆封的初代iPhone,在网上拍出了5万美元的高价,原因就在于这些传奇开端的机器,拥有了不可低估的情怀价值。

只不过为何让nova系列手机尝鲜也让人看不懂,或许是nova手机在华为产线之中有着不俗的销量吧。但实现零的突破对于华为来说意义还是非常重大的,可以预见的是,在不久后华为旗下包括荣耀品牌的一系列手机,都会支持微信指纹支付,用户使用微信支付的时候需要手动输入密码的尴尬可休矣。

在上一篇 《初相识 | performance_schema全方位介绍》 中粗略介绍了如何配置与使用performance_schema,相信大家对performance_schema能够为我们提供什么样的性能数据已经有一个初步的认识,今天将带领大家一起踏上系列第二篇的征程(全系共7个篇章),在这一期里,我们将为大家全面讲解performance_schema配置方式以及各个配置表的作用。下面,请跟随我们一起开始performance_schema系统的学习之旅吧。

虽然价格不是一切,但从某个角度来说,贵才能让产品有更多的想象空间。从产品十年发展来看,也正是如此。

澳门威利斯人手机版 5

| 基本概念

一场险危机四伏的发布会开启时代颠覆

在实现微信指纹支付之后,无疑可以提高华为手机用户的选择自由度和支付的安全性。毕竟比起明文数字密码来说,生物安全加密的安全性要高不少,支付账户被盗用、被利用的可能性大大降低。

instruments:生产者,用于采集MySQL 中各种各样的操作产生的事件信息,对应配置表中的配置项我们可以称为监控采集配置项,以下提及生产者均统称为instruments

澳门威利斯人手机版 6

澳门威利斯人手机版 7

consumers:消费者,对应的消费者表用于存储来自instruments采集的数据,对应配置表中的配置项我们可以称为消费存储配置项,以下提及消费者均统称为consumers

说到苹果,话题自然离不开它的缔造者乔布斯。就在十一年前的一月份,乔布斯带着一款看似完美的初代iPhone开了一场盛大的发布会。

本次华为和腾讯达成共识,不好说是谁做的让步。如今华为已经是世界第二大厂商,出货量超越苹果;在国内则是连庄多任的销量冠军,影响力非凡。华为手机支持微信指纹支付,无论对于华为还是腾讯还是消费者来说,都是有利无害的好事。返回搜狐,查看更多

友情提示:以下内容阅读起来可能比较烧脑,内容也较长,建议大家端好板凳,坐下来,点上一支烟,细细品读,这也是学习performance_schema路上不得不过的火焰山,坚持下去,"翻过这座山,你就可以看到一片海!"

这款iPhone以在当时来说精美的设计、全新的触控操作,吸引了大批拥趸。但实际上,这是一场存在着众多不可控因素的发布会,此时如展示一般华丽的iPhone其实还并未诞生。

责任编辑:

| 编译时配置

澳门威利斯人手机版 8

在以往,我们认为自行编译安装MySQL其性能要优于官方编译好的二进制包、rpm包等。可能在MySQL早期的版本中有这样的情况, 但随着MySQL版本不断迭代,业界不少人亲测证实,目前的MySQL版本并不存在自行编译安装性能比官方编译好的二进制包性能高,所以,通常情况下,我们不建议去耗费数十分钟来编译安装MySQL,因为在大规模部署的场景,此举十分浪费时间(需要通过编译安装的方式精简模块的场景除外)

当时乔布斯用来展示的,只是一款还不能满足正常使用的原型机而已——此时的原型机还存在大量的bug,经常出现断网、死机的情况,甚至如果不按一定的流程操作手机,手机都会无法正常运行。

可以使用cmake的编译选项来自行决定你的MySQL实例是否支持performance_schema的某个等待事件类别,如下:

而在发布会之前的5天内,乔布斯每一天的演习都会遇到各种各样的问题。不得不说,运气这事儿,很玄妙。

shell> cmake .

目光回归到产品,初代iPhone确实拥有着十足的吸引力,即便是在那个诺基亚摩托罗拉已经行至巅峰的时代——在工程塑料还是主要机身材质的当时,初代iPhone就用上了金属;物理键盘大行其道,而初代iPhone却采用了全屏触摸;率先采用康宁大猩猩玻璃材质用作屏幕盖板,在此之前康宁的钢化玻璃主要用作为汽车的挡风玻璃。

-DDISABLE_PSI_STAGE=1 #关闭STAGE事件监视器

澳门威利斯人手机版 9

-DDISABLE_PSI_STATEMENT=1 #关闭STATEMENT事件监视器

同样,初代iPhone搭载的系统也是iOS系统的开端,即便那时的系统命名是iPhone OS。

注意:虽然我们可以通过cmake的编译选项关闭掉某些performance_schema的功能模块,但是,通常我们不建议这么做,除非你非常清楚后续不可能使用到这些功能模块,否则后续想要使用被编译时关闭的模块,还需要重新编译。

也许在现在看来,这款系统在录像、文本复制、更换壁纸、多任务、没有第三方程序的系统等方面的功能缺失让它并不能成为一个好系统,但全触控的交互方式,以及操作简易的Safari却也让iPhone OS不失亮点。

当我们接手一个别人安装的MySQL数据库服务器时,或者你并不清楚自己安装的MySQL版本是否支持performance_schema时,我们可以通过mysqld命令查看是否支持Performance Schema

从此以后,iPhone的发展似乎走上了一条光明大路,爆发从未停止。

# 如果发现performance_schema开头的几个选项,则表示当前mysqld支持performance_schema,如果没有发现performance_schema相关的选项,说明当前数据库版本不支持performance_schema,你可能需要升级mysql版本:

iOS前时代的爆发与沉淀

shell> mysqld --verbose -- help

澳门威利斯人手机版 10

...

一时的爆发往往意味着爆发过后的疲软与下降,2008年,iPhone的继任产品iPhone 3G从硬件上看也单单只是例行升级。

--performance_schema

新机加入了对3G网络的支持,增加定位功能,提升续航等等。但后壳材质从原来的金属用回了工程塑料。

Enable the performance schema.

这时不禁让我们有这样的念头:第二代iPhone还能火起来吗?

--performance_schema_events_waits_history_long_size= #

澳门威利斯人手机版 11

Number of rows inevents_waits_history_long.

但实际上,相比于昂贵的初代iPhone,iPhone 3G拥有一个极大的变化,那就是价格便宜,8GB机型在签订与运营商的补贴合同之后,起售价格仅为199美元。

还可以登录到MySQL实例中使用SQL命令查看是否支持performance_schema:

iPhone 3G在上市第一个月内的销量实际上已经突破了300万台,这个数字已经接近初代iPhone全年销量的一半。第一季度的出货量就已经达到 690 万部,超过了前五个季度初代 iPhone 约 610 万的总出货量。

# Support列值为YES表示数据库支持,否则你可能需要升级mysql版本:

澳门威利斯人手机版 12

mysql> SHOW ENGINESG

虽然是例行升级,但iPhone 3G搭载的iPhone OS 2.0却给iPhone以后的快速发展奠定了坚实的基础——支持App Store,而且苹果给出了iOS SDK开发工具包,这让开发者们能为iPhone提供更多APP,而且相比于其它平台,苹果可以控制自家的应用质量与风格走向。

...

不足一个月,App Store的应用量从初始的五百个疯狂增长到两万个。原来的完全封闭到相对开放,对苹果的生态建设拥有着里程碑式的意义。

admin@localhost : (none) 12:54:00> show engines;

澳门威利斯人手机版 13

*************************** 6. row ***************************

2009年,带有“Speed”速度后缀的iPhone 3GS问世。也是从此开始,iPhone一代两升级版本的传统确立下来。

Engine: PERFORMANCE_SCHEMA

正如我们所知,iPhone 3GS在配置上拥有了重大的升级,性能翻了两番的处理器、提升到320万像素的摄像头、加入了电子罗盘,以及在当时来说还很恐怖的32GB存储,都让其拥有更加充足的吸引力。

Support: YES

同是在2009年,诺基亚推出经典高端机型诺基亚N97,三个月销量达到了200万部,价格稍低的5800XpressMusic在近10个月内达到了800万部。此时的诺基亚,市场占有率高达45%。

Comment: Performance Schema

而此时,苹果就已经表现出了咄咄逼人的态势,第二季度苹果共售出520万部iPhone。总量来说,iPhone 3GS达到了2073万台,比之iPhone 3G的1163万台拥有着将近一倍的提升。

Transactions: NO

澳门威利斯人手机版 14

XA: NO

此时,iPhone 3GS搭载的是iOS前的最后一个系统版本iPhone OS 3.0。有人说这个系统版本并没有什么亮点可言,但一艘巨轮想要远航就得把每个角落做到尽善尽美,iPhone OS 3.0恰恰就是把每个角落都打磨好的版本,比如加上了文本的粘贴复制、Spotlight全局搜索等等。

Savepoints: NO

承上启下,我们可以这样评价iPhone OS 3.0。

9 rows in set (0.00 sec)

iOS时代的制霸与传奇

注意:在mysqld选项或show engines语句输出的结果中,如果看到有performance_schema相关的信息,并不代表已经启用了performance_schema,仅仅只是代表数据库支持,如果需要启用它,还需要在服务器启动时使用系统参数performance_schema=on(MySQL 5.7之前的版本默认关闭)显式开启

澳门威利斯人手机版 15

|启动时配置

2010年,苹果发布了这款足以称为经典的机型iPhone 4。也正是从iPhone 4开始,苹果手机才逐渐走到大众的面前。

performance_schema中的配置是保存在内存中的,是易失的,也就是说保存在performance_schema配置表(本章后续内容会讲到)中的配置项在MySQL实例停止时会全部丢失。所以,如果想要把配置项持久化,就需要在MySQL的配置文件中使用启动选项来持久化配置项,让MySQL每次重启都自动加载配置项,而不需要每次重启都再重新配置。

iPhone 4上市后三天,销量就突破了170万部,乔布斯宣称,这创下了苹果公司有史以来最成功的产品发布纪录。

(1) 启动选项

虽然iPhone 4并不是完美无缺,但不得不说,这是一款在当时来说代表行业高度的产品——双面玻璃的优秀质感、平直金属机身的精致外观、Retina标准的视网膜屏幕、容量翻番的512MG RAM、自主的A4芯片、背照式500万像素摄像头、加入陀螺仪等等,都证明了这是一款优秀的产品。

performance_schema有哪些启动选项呢?我们可以通过如下命令行命令进行查看:

澳门威利斯人手机版 16

[root@localhost ~] # mysqld --verbose --help |grep performance-schema |grep -v '--' |sed '1d' |sed '/[0-9]+/d'

也正是从这一代起,系统正式更名为iOS。而且,系统的改变可不仅仅限于名称。

......

首先拟物化设计不仅做出了差异化,还做到了精致。雨珠毛玻璃的设计相信很多果粉还记忆犹新。

performance-schema-consumer-events-stages-current FALSE

其次,苹果的正向口碑也在这一代大量积累,比如拍照好、系统流畅等等。而这恰恰是源于iOS 4的深度优化。

澳门威利斯人手机版,performance-schema-consumer-events-stages-history FALSE

毫不夸张的说,当时给人留下的iOS比安卓流畅的印象,一直影响至今。

performance-schema-consumer-events-stages-history- longFALSE

澳门威利斯人手机版 17

performance-schema-consumer-events-statements-current TRUE

之后的iPhone 4s,几个升级点也是比较显著的:设计上改良了天线位置,解决了上一代存在的信号问题;采用了自主研发的双核处理器A5芯片,性能相比A4提升了1倍,图形处理能力提升7倍;摄像头模组再升级,像素达到了800万,进光量也更高。

performance-schema-consumer-events-statements-history TRUE

此时的iOS 5,生态建设得到了极大的完善——搭载语音助手Siri、iMessage即时通讯软件、iCloud云服务,生态的完善让iOS不再是一个单薄的终端系统,而是给用户构建了一套完整的生活辅助使用方案。

performance-schema-consumer-events-statements-history- longFALSE

澳门威利斯人手机版 18

performance-schema-consumer-events-transactions-current FALSE

如果说销量是决定成败的关键,那么从这一代起,苹果开始走在了行业的前端。

performance-schema-consumer-events-transactions-history FALSE

2011年第二季度,iPhone已超越诺基亚智能手机销量,苹果成为全球最大智能手机商。在苹果和安卓的围剿下,诺基亚终于开始走了下坡路,而这也正是诺基亚手机帝国覆灭的开始。

performance-schema-consumer-events-transactions-history- longFALSE

或许,在iPhone 4s发布第二天就与世长辞的乔布斯想不到,当时不可一世的诺基亚帝国,就这么真真切切成为了历史。

performance-schema-consumer-events-waits-current FALSE

来自行业顶端的傲娇与霸气

performance-schema-consumer-events-waits-history FALSE

之后iPhone的发展,可以用“稳如老狗”四字来形容,每一代产品都在稳步的升级,几乎每一代产品都能成功引领手机行业的发展。

performance-schema-consumer-events-waits-history- longFALSE

虽然每每在手机发布之初,调侃的人从不缺少,但嘴上说不买但产品一上市就掏腰包抢购的却大有人在。也不得不佩服,iPhone的粘性之巨。

performance-schema-consumer-global-instrumentation TRUE

  • iPhone5/5s

performance-schema-consumer-statements-digest TRUE

澳门威利斯人手机版 19

performance-schema-consumer-thread-instrumentation TRUE

最显著的变化就是手机变长,另外在iPhone 5s上增加了香槟金的配色,在手机行业中引发了一场发手机必发土豪金的风潮。但事实上,不只是外观,iPhone由里到外都拥有较为显著的升级。

performance-schema-instrument

比如iPhone5s上的Touch ID按压式指纹识别,再比如从iPhone 5上的A6处理器,其性能开始领先安卓阵营,尤其体现在处理器的单核心性能上。

......

iPhone 5s上采用的64位A7处理器,单核性能几乎达到了当时安卓阵营旗舰处理器的一倍。

下面将对这些启动选项进行简单描述(这些启动选项是用于指定consumers和instruments配置项在MySQL启动时是否跟随打开的,之所以叫做启动选项,是因为这些需要在mysqld启动时就需要通过命令行指定或者需要在my.cnf中指定,启动之后通过show variables命令无法查看,因为他们不属于system variables)

澳门威利斯人手机版 20

  • performance_schema_consumer_events_statements_current=TRUE

iOS最直接的变化,就是在iPhone 5s的iOS 7上开始采用扁平式的UI外观设计。同样,这样的设计再次席卷了手机行业。

是否在mysql server启动时就开启events_statements_current表的记录功能(该表记录当前的语句事件信息),启动之后也可以在setup_consumers表中使用UPDATE语句进行动态更新setup_consumers配置表中的events_statements_current配置项,默认值为TRUE

  • iPhone 6/6 Plus& iPhone 6s/6s Plus
  • performance_schema_consumer_events_statements_history=TRUE

澳门威利斯人手机版 21

与performance_schema_consumer_events_statements_current选项类似,但该选项是用于配置是否记录语句事件短历史信息,默认为TRUE

更大的尺寸让机身外型设计不得不发生改变。虽然叫丑声此起彼伏,但这一代iPhone照样引领了手机行业的设计发展。

  • performance_schema_consumer_events_stages_history_long=FALSE

iPhone 6s开始,屏幕上加入了z轴深度的交互方式3D Touch。虽然这种交互方式不少安卓厂商都有意模仿,但后者并不具备统一完备的第三方软件适配,所以这样操作至今无人超越。

与performance_schema_consumer_events_statements_current选项类似,但该选项是用于配置是否记录语句事件长历史信息,默认为FALSE

  • iPhone 7/7 Plus
  • 除了statement(语句)事件之外,还支持:wait(等待)事件、state(阶段)事件、transaction(事务)事件,他们与statement事件一样都有三个启动项分别进行配置,但这些等待事件默认未启用,如果需要在MySQL Server启动时一同启动,则通常需要写进my.cnf配置文件中
  • performance_schema_consumer_global_instrumentation=TRUE

澳门威利斯人手机版 22

是否在MySQL Server启动时就开启全局表(如:mutex_instances、rwlock_instances、cond_instances、file_instances、users、hostsaccounts、socket_summary_by_event_name、file_summary_by_instance等大部分的全局对象计数统计和事件汇总统计信息表 )的记录功能,启动之后也可以在setup_consumers表中使用UPDATE语句进行动态更新全局配置项

整体外型变化不大,但却升级了不少细节设计,比如增加了亮黑色、取消掉3.5mm耳机孔、采用支持Force Touch震动仿真的Home键、支持IP67级防水防尘等等。

默认值为TRUE

取消3.5mm耳机孔从此成为一种风潮,无线耳机也因此迎来了一个良性发展时代。

  • performance_schema_consumer_statements_digest=TRUE
  • iPhone 8/8 Plus&iPhone X

是否在MySQL Server启动时就开启events_statements_summary_by_digest 表的记录功能,启动之后也可以在setup_consumers表中使用UPDATE语句进行动态更新digest配置项

澳门威利斯人手机版 23

默认值为TRUE

确切的说,iPhone 8/8 Plus相当于iPhone 7/7 Plus的小幅升级版,亮点方面没什么好说。事实上,近两年并不显著的升级也让苹果饱受诟病。

  • performance_schema_consumer_thread_instrumentation=TRUE

但作为十周年纪念版的iPhone X却亮点满满——三面窄边框的异形全面屏设计、全新的手势滑动交互、3D结构光面部识别、双OIS光学防抖等等,正如其广告语所言:Hello,未来。

是否在MySQL Server启动时就开启

澳门威利斯人手机版 24

events_xxx_summary_by_yyy_by_event_name表的记录功能,启动之后也可以在setup_consumers表中使用UPDATE语句进行动态更新线程配置项

据悉本次新品发布会,苹果将会推出三款新品,其中一款将支持双卡双待。靠一个双卡就能吸引如此之多的目光,其它厂商是想嫉妒也嫉妒不来的。毫无疑问,发布会后又会有一大批有钱人骂着苹果的升级不多,骂完直接掏钱喊真香了。返回搜狐,查看更多

默认值为TRUE

责任编辑:

  • performance_schema_instrument[=name]

是否在MySQL Server启动时就启用某些采集器,由于instruments配置项多达数千个,所以该配置项支持key-value模式,还支持%号进行通配等,如下:

# [=name]可以指定为具体的Instruments名称(但是这样如果有多个需要指定的时候,就需要使用该选项多次),也可以使用通配符,可以指定instruments相同的前缀+通配符,也可以使用%代表所有的instruments

## 指定开启单个instruments

--performance-schema-instrument= 'instrument_name=value'

## 使用通配符指定开启多个instruments

--performance-schema-instrument= 'wait/synch/cond/%=COUNTED'

## 开关所有的instruments

--performance-schema-instrument= '%=ON'

--performance-schema-instrument= '%=OFF'

注意,这些启动选项要生效的前提是,需要设置performance_schema=ON。另外,这些启动选项虽然无法使用show variables语句查看,但我们可以通过setup_instruments和setup_consumers表查询这些选项指定的值。

(2) system variables

与performance_schema相关的system variables可以使用如下语句查看,这些variables用于限定consumers表的存储限制,它们都是只读变量,需要在MySQL启动之前就设置好这些变量的值。

root@ localhost: (none) 11: 43: 29> show variables like '%performance_schema%';

.....

42 rowsinset(0 .01sec)

下面,我们将对这些system variables(以下称为变量)中几个需要关注的进行简单解释(其中大部分变量是-1值,代表会自动调整,无需太多关注,另外,大于-1值的变量在大多数时候也够用,如果无特殊需求,不建议调整,调整这些参数会增加内存使用量)

performance_schema=ON

  • 控制performance_schema功能的开关,要使用MySQL的performance_schema,需要在mysqld启动时启用,以启用事件收集功能
  • 该参数在5.7.x之前支持performance_schema的版本中默认关闭,5.7.x版本开始默认开启
  • 注意:如果mysqld在初始化performance_schema时发现无法分配任何相关的内部缓冲区,则performance_schema将自动禁用,并将performance_schema设置为OFF

performance_schema_digests_size=10000

  • 控制events_statements_summary_by_digest表中的最大行数。如果产生的语句摘要信息超过此最大值,便无法继续存入该表,此时performance_schema会增加状态变量

performance_schema_events_statements_history_long_size=10000

  • 控制events_statements_history_long表中的最大行数,该参数控制所有会话在events_statements_history_long表中能够存放的总事件记录数,超过这个限制之后,最早的记录将被覆盖
  • 全局变量,只读变量,整型值,5.6.3版本引入 * 5.6.x版本中,5.6.5及其之前的版本默认为10000,5.6.6及其之后的版本默认值为-1,通常情况下,自动计算的值都是10000 * 5.7.x版本中,默认值为-1,通常情况下,自动计算的值都是10000

performance_schema_events_statements_history_size=10

  • 控制events_statements_history表中单个线程(会话)的最大行数,该参数控制单个会话在events_statements_history表中能够存放的事件记录数,超过这个限制之后,单个会话最早的记录将被覆盖
  • 全局变量,只读变量,整型值,5.6.3版本引入 * 5.6.x版本中,5.6.5及其之前的版本默认为10,5.6.6及其之后的版本默认值为-1,通常情况下,自动计算的值都是10 * 5.7.x版本中,默认值为-1,通常情况下,自动计算的值都是10

除了statement(语句)事件之外,wait(等待)事件、state(阶段)事件、transaction(事务)事件,他们与statement事件一样都有三个参数分别进行存储限制配置,有兴趣的同学自行研究,这里不再赘述

performance_schema_max_digest_length=1024

  • 用于控制标准化形式的SQL语句文本在存入performance_schema时的限制长度,该变量与max_digest_length变量相关(max_digest_length变量含义请自行查阅相关资料)
  • 全局变量,只读变量,默认值1024字节,整型值,取值范围0~1048576,5.6.26和5.7.8版本中引入

performance_schema_max_sql_text_length=1024

  • 控制存入events_statements_current,events_statements_history和events_statements_history_long语句事件表中的SQL_TEXT列的最大SQL长度字节数。 超出系统变量performance_schema_max_sql_text_length的部分将被丢弃,不会记录,一般情况下不需要调整该参数,除非被截断的部分与其他SQL比起来有很大差异
  • 全局变量,只读变量,整型值,默认值为1024字节,取值范围为0~1048576,5.7.6版本引入
  • 降低系统变量performance_schema_max_sql_text_length值可以减少内存使用,但如果汇总的SQL中,被截断部分有较大差异,会导致没有办法再对这些有较大差异的SQL进行区分。 增加该系统变量值会增加内存使用,但对于汇总SQL来讲可以更精准地区分不同的部分。

| 运行时配置

在MySQL启动之后,我们就无法使用启动选项来开关相应的consumers和instruments了,此时,我们如何根据自己的需求来灵活地开关performance_schema中的采集信息呢?(例如:默认配置下很多配置项并未开启,我们可能需要即时去修改配置,再如:高并发场景,大量的线程连接到MySQL,执行各种各样的SQL时产生大量的事件信息,而我们只想看某一个会话产生的事件信息时,也可能需要即时去修改配置),我们可以通过修改performance_schema下的几张配置表中的配置项实现

这些配置表中的配置项之间存在着关联关系,按照配置影响的先后顺序,可整理为如下图(该表仅代表个人理解):

澳门威利斯人手机版 25

(1) performance_timers表

performance_timers表中记录了server中有哪些可用的事件计时器(注意:该表中的配置项不支持增删改,是只读的。有哪些计时器就表示当前的版本支持哪些计时器),setup_timers配置表中的配置项引用此表中的计时器

每个计时器的精度和数量相关的特征值会有所不同,可以通过如下查询语句查看performance_timers表中记录的计时器和相关的特征信息:

mysql> SELECT * FROM performance_timers;

+-------------+-----------------+------------------+----------------+

| TIMER_NAME |TIMER_FREQUENCY | TIMER_RESOLUTION |TIMER_OVERHEAD |

+-------------+-----------------+------------------+----------------+

|CYCLE | 2389029850 |1| 72 |

| NANOSECOND |1000000000| 1 |112|

|MICROSECOND | 1000000 |1| 136 |

| MILLISECOND |1036| 1 |168|

|TICK | 105 |1| 2416 |

+-------------+-----------------+------------------+----------------+

performance_timers表中的字段含义如下**:**

  • TIMER_NAME:表示可用计时器名称,CYCLE是指基于CPU(处理器)周期计数器的定时器。在setup_timers表中可以使用performance_timers表中列值不为null的计时器(如果performance_timers表中有某字段值为NULL,则表示该定时器可能不支持当前server所在平台)
  • TIMER_FREQUENCY:表示每秒钟对应的计时器单位的数量(即,相对于每秒时间换算为对应的计时器单位之后的数值,例如:每秒=1000毫秒=1000000微秒=1000000000纳秒)。对于CYCLE计时器的换算值,通常与CPU的频率相关。对于performance_timers表中查看到的CYCLE计时器的TIMER_FREQUENCY列值 ,是根据2.4GHz处理器的系统上获得的预设值(在2.4GHz处理器的系统上,CYCLE可能接近2400000000)。NANOSECOND 、MICROSECOND 、MILLISECOND 计时器是基于固定的1秒换算而来。对于TICK计时器,TIMER_FREQUENCY列值可能会因平台而异(例如,某些平台使用100个tick/秒,某些平台使用1000个tick/秒)
  • TIMER_RESOLUTION:计时器精度值,表示在每个计时器被调用时额外增加的值(即使用该计时器时,计时器被调用一次,需要额外增加的值)。如果计时器的分辨率为10,则其计时器的时间值在计时器每次被调用时,相当于TIMER_FREQUENCY值+10
  • TIMER_OVERHEAD:表示在使用定时器获取事件时开销的最小周期值(performance_schema在初始化期间调用计时器20次,选择一个最小值作为此字段值),每个事件的时间开销值是计时器显示值的两倍,因为在事件的开始和结束时都调用计时器。注意:计时器代码仅用于支持计时事件,对于非计时类事件(如调用次数的统计事件),这种计时器统计开销方法不适用
  • PS:对于performance_timers表,不允许使用TRUNCATE TABLE语句

(2)**setup_timers**表

setup_timers表中记录当前使用的事件计时器信息(注意:该表不支持增加和删除记录,只支持修改和查询)

可以通过UPDATE语句来更改setup_timers.TIMER_NAME列值,以给不同的事件类别选择不同的计时器,setup_timers.TIMER_NAME列有效值来自performance_timers.TIMER_NAME列值。

对setup_timers表的修改会立即影响监控。正在执行的事件可能会使用修改之前的计时器作为开始时间,但可能会使用修改之后的新的计时器作为结束时间,为了避免计时器更改后可能产生时间信息收集到不可预测的结果,请在修改之后使用TRUNCATE TABLE语句来重置performance_schema中相关表中的统计信息。

mysql> SELECT * FROM setup_timers;

+-------------+-------------+

| NAME |TIMER_NAME |

+-------------+-------------+

|idle | MICROSECOND |

| wait |CYCLE |

|stage | NANOSECOND |

| statement |NANOSECOND |

本文由澳门威利斯人手机版发布于www.4886.com,转载请注明出处:凭啥让人一边骂一边买,配置详解

TAG标签:
Ctrl+D 将本页面保存为书签,全面了解最新资讯,方便快捷。