我的编程空间,编程开发者的网络收藏夹
学习永远不晚

第01问:MySQL 一次 insert 刷几次盘?

短信预约 信息系统项目管理师 报名、考试、查分时间动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

第01问:MySQL 一次 insert 刷几次盘?

第01问:MySQL 一次 insert 刷几次盘?

问题:

MySQL 一次 insert 刷几次盘?

实验:

工具:pt-tools

  1. 先检查各个刷盘参数

开启 pt-tools!

在 MySQL 中,任意表插入一行

观察 pt-ioprofile 的结果

我们用 pt-ioprofile 跟踪 MySQL IO 的系统调用,统计了次数。可以看到本次实验中:

  1. MySQL 对 redo log 进行了 3 次刷盘(fsync);
  2. MySQL 对 binlog 进行了 1 次刷盘(fdatasync);
  3. 对 redo log 和 binlog 的刷盘的方法是不同的。

结果:

可以看到本次试验进行了一次 insert,会对 redo log 进行 3 次刷盘,对 binlog 进行 1 次刷盘。 但是需要注意以下事项:

  1. 进行相同试验,会观察到不同结果:MySQL 有多个逻辑会引发刷盘,比如 InnoDB 主线程的刷脏等;
  2. 每次 fsync,如果没有数据需要刷盘,不会对磁盘造成压力。对于 3 次刷盘不必过分担心;
  3. 以后我们会进行试验,分析到底是什么导致了刷盘。

pt-ioprofile 是 pt-tools 中的一款性能分析工具,可以监听 MySQL 进程,输出 IO 操作的次数/总时间/平均时间。 其原理如下:pt-ioprofile 用 strace 监听 MySQL 的系统调用,筛选其中与 IO 相关的系统调用,进行统计。同时 pt-ioprofile 也获取 lsof 的输出,将其与 strace 的结果匹配,得知系统调用操作了哪个 MySQL 文件。


免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

第01问:MySQL 一次 insert 刷几次盘?

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

第01问:MySQL 一次 insert 刷几次盘?

问题:MySQL 一次 insert 刷几次盘?实验:工具:pt-tools先检查各个刷盘参数2. 开启 pt-tools!3. 在 MySQL 中,任意表插入一行4. 观察 pt-ioprofile 的结果我们用 pt-ioprofile 跟踪 MySQL
第01问:MySQL 一次 insert 刷几次盘?
2015-04-03

编程热搜

目录