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
验证结果:
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· 单线程的Redis速度为什么快?