サーバーがオンまたはオフになったときにsysadminsグループに電子メールを送信するスクリプトがあります。電子メールには、/var/log/messages
など、いくつかの重要なログダンプが含まれています/var/log/secure
。/var/log/boot.log
これ/var/log/boot.log
にはいくつかの特殊文字が含まれており、色やタブを指定するためのいくつかの特殊書式文字が含まれているため、電子メールで送信すると壊れて見えます。これらの特殊文字を削除して読むことができるようにするにはどうすればよいですか?
sedを使用して文字を削除できることを知っていますが、シンプルでエレガントなソリューションを探しています。
(/var/log/boot.log
CentOS 6.x以降)
私のダンプは次のとおりです/var/log/boot/.log
。
[root@vagrant ~]# cat -v /var/log/boot.log
^[%G Welcome to ^[[0;36mCentOS^[[0;39m ^M
Starting udev: ^[%G^[[60G[^[[0;32m OK ^[[0;39m]^M^M
Setting hostname vagrant: ^[[60G[^[[0;32m OK ^[[0;39m]^M^M
Setting up Logical Volume Management: 5 logical volume(s) in volume group "vgdynamic" now active^M
3 logical volume(s) in volume group "vgstatic" now active^M
^[[60G[^[[0;32m OK ^[[0;39m]^M^M
Checking filesystems^M
/dev/mapper/vgstatic-lvroot: clean, 8102/884736 files, 175959/3537920 blocks^M
/dev/sda1: clean, 44/32768 files, 17226/131072 blocks^M
/dev/mapper/vgdynamic-lvhome: clean, 10280/196608 files, 74141/786432 blocks^M
/dev/mapper/vgdynamic-lvopt: clean, 932/655360 files, 104046/2620416 blocks^M
/dev/mapper/vgstatic-lvtmp: clean, 12/131072 files, 25386/524288 blocks^M
/dev/mapper/vgstatic-lvusr: clean, 41785/262144 files, 236524/1048576 blocks^M
/dev/mapper/vgdynamic-lvvar: clean, 1989/393216 files, 93057/1572864 blocks^M
/dev/mapper/vgdynamic-lvvarlog: clean, 55/49152 files, 8030/196608 blocks^M
/dev/mapper/vgdynamic-lvaudit: clean, 14/65536 files, 73366/262144 blocks^M
^[[60G[^[[0;32m OK ^[[0;39m]^M^M
Remounting root filesystem in read-write mode: ^[[60G[^[[0;32m OK ^[[0;39m]^M^M
Mounting local filesystems: ^[[60G[^[[0;32m OK ^[[0;39m]^M^M
Enabling /etc/fstab swaps: ^[[60G[^[[0;32m OK ^[[0;39m]^M^M
Entering non-interactive startup^M
Calling the system activity data collector (sadc)... ^M
Starting monitoring for VG vgdynamic: 5 logical volume(s) in volume group "vgdynamic" monitored^M
^[[60G[^[[0;32m OK ^[[0;39m]^M^M
Starting monitoring for VG vgstatic: 3 logical volume(s) in volume group "vgstatic" monitored^M
^[[60G[^[[0;32m OK ^[[0;39m]^M^M
Bringing up loopback interface: ^[[60G[^[[0;32m OK ^[[0;39m]^M^M
Bringing up interface eth0: ^M
Determining IP information for eth0... done.^M
^[[60G[^[[0;32m OK ^[[0;39m]^M^M
Starting auditd: ^[[60G[^[[0;32m OK ^[[0;39m]^M^M
Starting system logger: ^[[60G[^[[0;32m OK ^[[0;39m]^M^M
Starting lwsmd: ^[[60G[^[[0;32m OK ^[[0;39m]^M^[[60G[^[[0;32m OK ^[[0;39m]^M^M
Mounting filesystems: ^[[60G[^[[0;32m OK ^[[0;39m]^M^M
Retrigger failed udev events^[[60G[^[[0;32m OK ^[[0;39m]^M^M
Starting the VirtualBox Guest Additions ^[[60G[^[[0;32m OK ^[[0;39m]^M^M
Starting VirtualBox Guest Addition service ^[[60G[^[[0;32m OK ^[[0;39m]^M^M
Starting sshd: ^[[60G[^[[0;32m OK ^[[0;39m]^M^M
Starting ntpd: ^[[60G[^[[0;32m OK ^[[0;39m]^M^M
Starting crond: ^[[60G[^[[0;32m OK ^[[0;39m]^M^M
Starting atd: ^[[60G[^[[0;32m OK ^[[0;39m]^M^M
[root@vagrant ~]#
答え1
まず、より複雑な(より長い)パターンで始める必要があります。制御文字で始まるだけで、残りの部分もプレーンテキストのパターンと一致する可能性があります。速度が最優先ではない場合、処理を複数のステートメントに分割すると、デバッグがより簡単になり、削除順序をより簡単に制御できます。
これカラーエスケープシーケンス^[
以下を使用して削除m
できますsed
。
sed -r "s/\x1B\[([0-9]{1,2}(;[0-9]{1,2})?)?[m//g"
他のモードは^[
(位置カーソル)で始まり、終了します。G
sed -r "s/\x1B\[.*G//g"
残りの制御文字は次のように一致する必要があります。
sed 's/[[:cntrl:]]//g'
次に結合:
sed -r "s/\x1B\[([0-9]{1,2}(;[0-9]{1,2})?)?m//g" /var/log/boot.log | \
sed -r "s/\x1B\[.*G//g" | \
sed 's/[[:cntrl:]]//g'
それが優雅なのか象なのかを見る人の意見が違います。
答え2
たぶんこのコマンドはdos2unix
あなたが探しているものかもしれません。