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

dmesg时间戳转换-ag真人游戏

作用:显示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

验证结果:

网站地图