Linuxでログファイルの先頭に日付を追加する方法

この記事では、Linux環境で現在の日付をログファイルの先頭に追加する処理について解説します。具体的なコード例とその解説、さらに応用例も含めて紹介します。

目次

基本的な考え方

Linux環境においてログファイルに日付を追加するという処理は、システムの監視やデバッグに非常に有用です。特に、ファイルの先頭に日付を追加することで、ファイルがいつ更新されたのか一目でわかるようになります。

主要なコマンド

この処理には主に`date`コマンドと`sed`コマンドが用いられます。`date`コマンドは現在の日付と時間を取得するため、`sed`コマンドはテキストファイルを操作するためのコマンドです。

# 現在の日付を取得
date "+\%Y-\%m-\%d \%H:\%M:\%S"

# ファイルの先頭に行を追加
sed -i '1i 追加するテキスト' ファイル名

基本的なコード例

次に示すコードは、現在の日付をログファイル(`log.txt`)の先頭に追加するシェルスクリプトの例です。

# 現在の日付を取得
current_date=$(date "+\%Y-\%m-\%d \%H:\%M:\%S")

# ファイルの先頭に日付を追加
sed -i "1i $current_date" log.txt

コードの詳細解説

1. `current_date=$(date “+\%Y-\%m-\%d \%H:\%M:\%S”)`: この行で現在の日付と時間を取得しています。
2. `sed -i “1i $current_date” log.txt`: この行でログファイル`log.txt`の先頭に日付を追加しています。

応用例

例1:特定の条件でのみ日付を追加

次のコード例では、特定の条件(ここではファイルサイズが0でない場合)を満たす場合のみ日付を追加します。

file_size=$(stat -c%s "log.txt")

if [ $file_size -ne 0 ]; then
  current_date=$(date "+\%Y-\%m-\%d \%H:\%M:\%S")
  sed -i "1i $current_date" log.txt
fi

例2:複数のログファイルに日付を追加

複数のログファイルに日付を追加する場合は、次のようにforループを使用します。

for file in *.log; do
  current_date=$(date "+\%Y-\%m-\%d \%H:\%M:\%S")
  sed -i "1i $current_date" $file
done

例3:異なる形式の日付を追加

日付の形式を変更する場合、`date`コマンドの引数を調整します。

current_date=$(date "+\%d-\%m-\%Y")
sed -i "1i $current_date" log.txt

例4:日付とともに追加テキストを挿入

日付以外のテキストも一緒に追加したい場合、以下のようにします。

current_date=$(date "+\%Y-\%m-\%d \%H:\%M:\%S")
additional_text="Updated:"
sed -i "1i $additional_text $current_date" log.txt

まとめ

Linuxでログファイルの先頭に現在の日付を追加する処理は、`date`と`sed`コマンドを使えば簡単に実現できます。応用例もいくつか紹介しましたので、ぜひ参考にしてください。

created by Rinker
オライリージャパン
¥3,080 (2025/01/19 00:35:17時点 Amazon調べ-詳細)

コメント

コメントする

目次