菜鸟笔记
提升您的技术认知

dmesg时间戳转换

作用:显示Linux内核的环形缓冲区信息

执行命令:

dmesg -H

dmesg时间戳转换

问题描述:

我们可以看到异常日志,但是无法确认异常时间,日志中的时间表示的是系统启动到事件发生的时间差,这个值可以转换成时间戳

unix_time=`echo "$(date +%s) - $(cat /proc/uptime | cut -f 1 -d' ') + 0.404509 " | bc`
date -d "@${unix_time}" '+%Y-%m-%d %H:%M:%S'

date +%s:从 1970 年 1 月 1 日 00:00:00 UTC 到目前为止的秒数(时间戳)
cat /proc/uptime | cut -f 1 -d' ': 显示的系统自开机后运行的时间(秒)
0.404509:日志中自开机后到出现异常的时间

通过上述计算公式:
`echo "$(date +%s) - $(cat /proc/uptime | cut -f 1 -d' ')计算出了系统开机的时间,然后加上开机到异常的时间(日志中显示的时间)就获取到了异常的unix时间戳,然后将unix时间戳转换成具体的时间
date -d "@${unix_time}" '+%Y-%m-%d %H:%M:%S' 格式化时间戳为我们能看懂的日期时间,这里要注意时区,中国的时区为CST

验证结果:

dmesg时间戳转换