mysql 查看binlog 日期_Linux 如何用命令查看binlog文件的创建时间

背景

MySQL在26日 16:23:49产生了大量的慢查询,在这段时间内,binlog文件刷新的很快(查看慢日志是mysql DML并发比较多),想知道写完一个binlog文件究竟花了几分钟时间?

5f9f3bc9b1040ecf1b5f141026042b35.png

分析

三个binlog文件的最后修改间隔时间分别是2 分钟和1 分钟

同一个事务只能写同一个binlog文件

mysql-bin.016126文件的最后修改时间16:22不一定是mysql-bin.016127 文件创建的时间(存在大事务的情况下,大事务还在写上一个binlog文件,新的事务已经在写新创建的binlog文件了)

使用mysqlbinlog 可以读取binlog文件中的event,知道文件的创建时间

在Linux下,是否有命令可以查出文件的创建时间了?

方法

1、使用stat命令

stat mysql-bin.016126

File: ‘mysql-bin.016126’

Size: 262146609 Blocks: 512016 IO Block: 4096 regular file

Device: fd02h/64770d Inode: 135529302 Links: 1

Access: (0640/-rw-r-----) Uid: ( 5701/actiontech-mysql) Gid: ( 5701/actiontech-mysql)

Access: 2019-04-28 14:41:42.967043003 +0800

Modify: 2019-04-26 16:24:21.823932020 +0800

Change: 2019-04-26 16:24:21.823932020 +0800

1、访问时间,读一次这个文件的内容,这个时间就会更新。比如对这个文件运用 more、cat等命令。ls、stat命令都不会修改文件的访问时间

2、修改时间,修改时间是文件内容最后一次被修改时间。比如:vi后保存文件。ls -l列出的时间就是这个时间

3、状态改动时间。是该文件的i节点最后一次被修改的时间,通过chmod、chown命令修改一次文件属性,这个时间就会更新

如果文件创建后就没有修改过,修改时间=创建时间;如果文件创建后,状态就没有改变过,那么状态改变时间=创建时间;如果文件创建后,没有被读取过,那么访问时间=创建时间。对使用过的文件,这些基本不太可能

2、使用debugfs

获取binlog文件存放根文件目录

grep 'datas' /etc/fstab

/dev/mapper/CentOS-datas /datas ext4 defaults 1 2

得到binlog文件inode号

ls -i mysql-bin.016127

135529232 mysql-bin.016127

得到文件创建时间

debugfs -R 'stat <135529232>' /dev/mapper/centos-datas

debugfs 1.42.9 (28-Dec-2013)

Inode: 135529232 Type: regular Mode: 0640 Flags: 0x80000

Generation: 2396969921 Version: 0x00000000:00000001

User: 5701 Group: 5701 Size: 262147164

File ACL: 0 Directory ACL: 0

Links: 1 Blockcount: 512016

Fragment: Address: 0 Number: 0 Size: 0

ctime: 0x5cc2c082:47dcd9bc -- Fri Apr 26 16:25:38 2019

atime: 0x5cc55c49:2929fd18 -- Sun Apr 28 15:54:49 2019

mtime: 0x5cc2c082:47dcd9bc -- Fri Apr 26 16:25:38 2019

crtime: 0x5cc2c035:c470d1d0 -- Fri Apr 26 16:24:21 2019

Size of extra inode fields: 28

EXTENTS:

crtime即为文件创建时间

crtime和mtime文件最后修改时间差1分17秒

MySQL写完一个binlog文件用时1分多钟

注意

xfs文件系统不支持用debugfs来查看文件的创建时间

grep root /etc/fstab

/dev/mapper/centos-root / xfs defaults 1 1

ls -i /test1

357556 /test1

debugfs -R 'stat <357556>' /dev/mapper/centos-root

debugfs 1.42.9 (28-Dec-2013)

/dev/mapper/centos-root: Bad magic number in super-block while opening filesystem

stat: Filesystem not open0b1331709591d260c1c78e86d0c51c18.png

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值