dmesg时间转换工具

来源:互联网 发布:域名续费怎么收费 编辑:程序博客网 时间:2024/03/28 18:13

最近在排查一个core问题,对dmesg的时间戳,做了一个转化工具:ts_dmesg.sh

借助awk 和shell实现:

#!/bin/shuptime_ts=`cat /proc/uptime | awk '{ print $1}'`#echo $uptime_tsdmesg | awk -v uptime_ts=$uptime_ts 'BEGIN {    now_ts = systime();    start_ts = now_ts - uptime_ts;    #print "system start time seconds:", start_ts;    #print "system start time:", strftime("[%Y/%m/%d %H:%M:%S]", start_ts); }{    print strftime("[%Y/%m/%d %H:%M:%S]", start_ts + substr($1, 2, length($1) - 2)), $0}'



关于dmesg的原始时间戳,是系统的产生mesg的系统uptime时间,故需要获取系统的启动时间;


关于系统uptime时间:

/proc/uptime详解

在Linux中,我们常常会使用到uptime命令去看看系统的运行时间,它与一个文件有关,就是/proc/uptime,下面对其进行详细介绍。

wzb@scala:~$ cat /proc/uptime6447032.12 48185264.69wzb@scala~$ cat /proc/cpuinfo  | grep processor | wc -l8


第一列输出的是,系统启动到现在的时间(以秒为单位),这里简记为num1;
第二列输出的是,系统空闲的时间(以秒为单位),          这里简记为num2。

注意,很多很多人都知道第二个是系统空闲的时间,

但是可能你不知道是,在SMP系统里,系统空闲的时间有时会是系统运行时间的几倍,这是怎么回事呢?
因为系统空闲时间的计算,是把SMP算进去的,就是所你有几个逻辑的CPU(包括超线程)。

系统的空闲率(%) = num2/(num1*N)  #其中N是SMP系统中的CPU个数。

从上面我的一台机器上的数据可知,
本机启动到现在的时间长度为:6447032.12 seconds = 74.6 days
空闲率为:48185264.69/(6447032.12*8)=93.4%

系统空闲率越大,说明系统比较闲,可以加重一些负载;

而系统空闲率很小,则可能考虑升级本机器硬件或者迁移部分负载到其他机器上。

Some docs from Redhat:
The first number is the total number of seconds the system has been up. 

The second number is how much of that time the machine has spent idle, in seconds.  (Jay’s comments: Please pay attention to SMP system.)

linux时间戳转换

1. 将日期转换成时间戳
$date +%s -d "04/24/2014 15:30:00"1398324600
2. 将时间戳转换成日期
$date -d @1398324600Thu Apr 24 15:30:00 CST 2014
3. 将当前日期转换成时间戳
$date +%s1398765730

dmesg 时间转换

dmesg 输出的格式不易查看,可以通过命令进行转换。

记录如下:

时间查看:

date -d "1970-01-01 UTC `echo "$(date +%s)-$(cat /proc/uptime|cut -f 1 -d' ')+12288812.926194"|bc ` seconds"

将系统的相对系统启动的时间戳转化为绝对时间:

dc.sh:

#!/bin/sh#related_ts=$1while read  related_ts; do    #date -d "1970-01-01 UTC `echo "$(date +%s) - $(cat /proc/uptime|cut -f 1 -d' ') + $related_ts" | bc ` seconds"    #date -d @`echo "$(date +%s) - $(cat /proc/uptime|cut -f 1 -d' ') + $related_ts" | bc `    /bin/date +"[%Y/%m/%d %H:%M:%S]" -d@`echo "$(date +%s) - $(cat /proc/uptime | cut -f 1 -d' ') + $related_ts" | bc `done






0 0
原创粉丝点击