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 @   什么都不会的小郭  阅读(1438)  评论(0编辑  收藏  举报
编辑推荐:
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
阅读排行:
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· 单线程的Redis速度为什么快?
点击右上角即可分享
微信分享提示