dmesg时间戳转换

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

执行命令: 

 dmesg -H

 

问题描述:

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

> 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

验证结果:

 

 




 

posted @ 2022-12-29 15:55  什么都不会的小郭  阅读(1366)  评论(0编辑  收藏  举报