dmesg時間轉(zhuǎn)換工具

最近公司疑難雜癥特別多,日志一打看完又一打,令我最心痛的是dmesg查看。

直接命令行你看到的是

[944273.286389] [31933]? 1005 31933? ? 13189? ? ? 144? ? ? 29? ? ? ? 0? ? ? ? ? ? 0 sftp-server

[944273.286390] [31982]? ? 0 31982? ? 37064? ? ? 332? ? ? 73? ? ? ? 0? ? ? ? ? ? 0 sshd

[944273.286392] [31984]? 1005 31984? ? 37413? ? ? 622? ? ? 73? ? ? ? 0? ? ? ? ? ? 0 sshd

[944273.286393] [31985]? 1005 31985? ? 13189? ? ? 144? ? ? 29? ? ? ? 0? ? ? ? ? ? 0 sftp-server

[944273.286395] [32005]? ? 0 32005? ? 37064? ? ? 332? ? ? 73? ? ? ? 0? ? ? ? ? ? 0 sshd

[944273.286396] [32007]? 1005 32007? ? 37064? ? ? 335? ? ? 72? ? ? ? 0? ? ? ? ? ? 0 sshd

[944273.286397] [32008]? 1005 32008? ? 28845? ? ? 96? ? ? 15? ? ? ? 0? ? ? ? ? ? 0 bash

[944273.286399] [32035]? 1005 32035? ? 26984? ? ? 26? ? ? 10? ? ? ? 0? ? ? ? ? ? 0 tail

[944273.286400] [32081]? ? 0 32081? ? 37064? ? ? 331? ? ? 74? ? ? ? 0? ? ? ? ? ? 0 sshd

[944273.286401] [32083]? 1005 32083? ? 37064? ? ? 334? ? ? 72? ? ? ? 0? ? ? ? ? ? 0 sshd

[944273.286402] [32084]? 1005 32084? ? 28845? ? ? 98? ? ? 15? ? ? ? 0? ? ? ? ? ? 0 bash

[944273.286404] [32110]? 1005 32110? ? 26984? ? ? 27? ? ? 11? ? ? ? 0? ? ? ? ? ? 0 tail

[944273.286405] [32116]? ? 0 32116? ? 37064? ? ? 333? ? ? 74? ? ? ? 0? ? ? ? ? ? 0 sshd

[944273.286406] [32118]? 1005 32118? ? 37413? ? ? 685? ? ? 73? ? ? ? 0? ? ? ? ? ? 0 sshd

[944273.286407] [32119]? 1005 32119? ? 13189? ? ? 160? ? ? 29? ? ? ? 0? ? ? ? ? ? 0 sftp-server

[944273.286409] Out of memory: Kill process 31583 (java) score 185 or sacrifice child

[944273.286447] Killed process 31583 (java) total-vm:3646416kB, anon-rss:719452kB, file-rss:0kB, shmem-rss:0kB


這樣的時間是對查看不太友好,所以需要轉(zhuǎn)化為直觀的時間,dmesg的原始時間戳,是系統(tǒng)的產(chǎn)生mesg的系統(tǒng)uptime時間,故需要獲取系統(tǒng)的啟動時間

下面這個腳本可以將如此的字符串轉(zhuǎn)發(fā)能夠輸入友好的時間方便我們查看日志


#!/bin/bash

uptime_ts=`cat?/proc/uptime?|?awk'{?print?$1}'`

#echo?$uptime_ts

dmesg?|?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);

}

{

printstrftime("[%Y/%m/%d?%H:%M:%S]",?start_ts?+?substr($1,?2,?length($1)?-?2)),?$0

}'

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容