2011-05-26 21:55:11 +0000 2011-05-26 21:55:11 +0000
146
146

dmsg` の出力を `tail -f` することは可能か。

dmesg | tail -f

みたいなことをしたいのですが、うまくいきません。

Mac OS X v10.6.7 (Snow Leopard)を使用しています。そうすることで、tailは出力を監視するのではなく、終了してしまいます。

何か方法があるのか、それに相当するコマンドがあるのかな。

追伸、whileのループではダメだと思います。

回答 (11)

130
130
130
2011-05-26 22:04:06 +0000

おそらく、様々なログファイルからのメッセージの組み合わせを探しているのでしょう。試してみてください。

tail -f /var/log/{messages,kernel,dmesg,syslog}

…を試してみてください。それ以上でもそれ以下でも良いのであれば、見たいメッセージがどのログファイルに置かれているかを調べてみてください。

また、multitail を使って、一度に複数のログファイルをファイル化してカラーコード化したり、フィルタリングしたりすることも検討してみてください。

編集:これに答えたときにはあまり関係のないことでしたが、このページは多くのヒット数を獲得しているので、systemdを実行している新しいシステムにはこのような機能があることに言及する価値があると思いました。

dmesg -w
56
56
56
2011-06-11 22:42:51 +0000
  1. dmesgの出力を常時、即時に印刷したい
  2. Dmesg はカーネルリングバッファを印刷している (man dmesg 参照)
  3. カーネルリングバッファは特別な proc ファイル /proc/kmsg (man proc 参照)
  4. /proc/kmsg を直接読む、つまり cat /proc/kmsg を読む。

さて、親切な proc マニュアルを読むと、一度に一人のユーザ(特権を持っている必要があります)だけに /proc/kmsg を読ませるようにと厳しく警告されています。あなたが持っているどのような syslog 実装でも、これを行うべきであり、おそらく dmesg で動作するはずです。分からないが、マニュアルの言い換えをしただけで、私はここでは私の領域外にいる。だから、これは「とにかく@#$%%ingを動作させる」方法ですが、最初に次の2つのメソッドを考えてみてください。

Man page approved: watch + dmesg

私がsystemd init*で使っているlinuxボックスでは、dmesg.logはあまり書き込まれていません。カーネルログバッファを継続的に読むための最良の方法は、watchを使うことです。

watch 'dmesg | tail -50'

watch + dmesg + daemon + tail -f

もっと複雑な解決策としては、ウォッチを使ってdmesgの出力をファイルに書き込んで、それをtail -fするという方法があるかもしれません。おそらく、これはデーモンとして実行したいと思うでしょう。適切なデーモンはログを gzip して回転させることもできます。以下の bash コードはテストされておらず、動作しておらず、アイデアを伝えるためだけのものです。Brooks Mosesさんの回答には、作業用バージョンがあります。

watch 'dmesg >> /var/log/dmesg.log | tail -1'

0x1&

* tangent, なぜなら、これはアップルのデスクトップOSについての質問なので: systemdがあるときは、dmesgを気にしないでください; journalctl -xfを使ってください (たぶん、前の100行を表示するために-n 100を使う)

47
47
47
2014-03-28 14:27:08 +0000

Linux では、カーネルカーネル 3.5.0 以降で使用できます。

dmesg -w

systemd のシステムでも使用できます。

journalctl -kf
``` 0x1&
21
21
21
2012-07-20 21:45:27 +0000

以下は djeikyb の回答 の変形版で、実際にテストされており、いくつかのバグを修正しています。

watch 'sudo dmesg -c >> /tmp/dmesg.log; tail -n 40 /tmp/dmesg.log'

重要なトリックは、印刷後にリングバッファをクリアするdmesg -cを行っていることです。

これを行うには root である必要があります。また、出力をファイルにダンプしてtailにパイプする(これはうまくいきません)代わりに、新しく書き込まれたファイルから読み出すというバグフィックスもあります。

sudoだけを実行して、反復するたびにファイル全体を上書きすることもできますが、これは多くのI/Oを必要としますし、上書きの途中でコンピュータがクラッシュした場合にファイルを失うリスクもあります。

また、dmesg > /tmp/dmesg.logtail -fを永遠に実行するwhileループを使ってdmesg -cに近いことをすることもできます(Ben Harrisの回答を参照)。しかし、これは実際には実行中にカーネルメッセージバッファをクリアしているので、後で必要になった場合に備えてログファイルにパイプしておくと良いでしょう。

5
5
5
2012-11-05 13:45:51 +0000

この投稿を見る前にやってしまいました。

#!/usr/bin/env perl

use strict;
use warnings;

# "tail -f" for dmesg
# Keeps last printed line. Anything sorting "gt" will be newer

$|=1;

my $y = '';

while(1) {
    for my $k (`dmesg`) {
        if ($k gt $y) {
            print $k;
            $y = $k;
        }
    }
    sleep 1;
}
exit;
3
3
3
2013-03-05 08:26:53 +0000

組込み環境やプリブート環境のように、watch, tail, cat, dd などのコマンドが利用できない環境では、別の工夫が必要になるかもしれません。

while dmesg -c >> /tmp/dmesg.log; do sleep 0.1; done & tail -f /tmp/dmesg.log

これは、生成された出力を尾行しながら(&を使って)whileループを背景にしています。

mount -t tmpfs - /tmp 

# or 
mount -t ramfs - /tmp 

# or use /dev/shm instead of /tmp - which is available in newer environments

/tmp に書き込めない場合。

cat /tmp/dmesg.log

# or 
dd if=/tmp/dmesg.log 

# or
dd if=/tmp/dmesg.log 2>/dev/null
busybox dmesg -c

テールがない場合は、

busybox sleep

もしくは、dmesgがリンクされていないビジーボックス環境にいるかもしれません。

while dmesg -c; do echo >/dev/null; done

sleep の代わりに

while sleep 0.1; do cat -v /proc/kmsg; done

sleep が必要な場合もあります。

busybox ls

# or simply:

echo *

これは、他に何も読み込んでいない場合にのみ動作します。また、「/dev/kmsg」があるかもしれません。

ボーナスヒント:

何を持っているかわからず、"ls" を持っていない場合は、次のようにしてください。

3
3
3
2011-05-26 22:01:52 +0000
tail -f /var/log/messages
```ができるかもしれません。
3
3
3
2016-02-04 09:16:00 +0000

私は /root/.bashrc;

alias dwatch='watch -n 0.1 "dmesg | tail -n $((LINES-6))"'

でこのエイリアスを使用していますが、これは dmesg の後に続くもので、それがどのようなターミナルで呼ばれているかに応じて行を調整します。

0
0
0
2012-12-17 04:37:01 +0000

現在のUbuntu( Ubuntu 12.04 (Precise Pangolin)を使用しています)では、

tail -f /var/log/syslog
6< <( cat /var/log/syslog |grep -F 'kernel: '; sudo cat /proc/kmsg) cat /dev/fd/6

(sudoコマンドはsudo権限が必要です)

他のものも試してみてください。6< <( dmesg; sudo cat /proc/kmsg) cat /dev/fd/6

0
0
0
2016-01-22 22:49:10 +0000

このコードを使って、特別なカーネルイベントを探して「コールバック」プロセスにパイプしてみました。

while true ; do dmesg -c ; sleep .1 ; done \
| grep --line-buffered -o $pattern \
| ...
-3
-3
-3
2014-01-15 08:08:27 +0000

これは便利かもしれません。

dmesg | tail -f -

は、標準出力へのショートカットとして dmesg 演算子を使用して、- の出力を tail にパイプします。