【 git log 】コマンド(応用編その1)――コミットログを表示するLinux基本コマンドTips(387)

本連載は、Linuxのコマンドについて、基本書式からオプション、具体的な実行例までを紹介していきます。今回はGitについて、コミットログを表示する「git log」コマンドです。

» 2020年04月10日 05時00分 公開
[西村めぐみ@IT]

この記事は会員限定です。会員登録(無料)すると全てご覧いただけます。

「Linux基本コマンドTips」のインデックス

Linux基本コマンドTips一覧

 本連載は、Linuxのコマンドについて、基本書式からオプション、具体的な実行例までを紹介していきます。今回は基礎編に続き、Gitについてコミットログを表示する「git log」コマンドです。表示対象を指定するさまざまな方法を解説します。

git/git logコマンドとは?

 「git」は「Git」という分散型バージョン管理システム用のコマンドです。Gitは元々Linuxカーネルのソースコードを管理するために作られた「バージョン管理システム」で、現在は多くのソフトウェアやWebサイトのソースコード、ドキュメントの管理などに用いられています。

 ソースコードを管理する際、最新版だけを保存するやり方はうまくいきません。開発中のさまざまなタイミングで状態を管理し、必要に応じて比較、参照したり、元に戻したりできるようにする仕組みが「バージョン管理システム」です。

 Gitでは、テスト版など複数に枝分かれした状態も管理できます。複数のメンバーによる開発を前提としており、開発中の各時点におけるコメントや、コメントへの返信なども管理できるようになっています。

gitのサブコマンドとGitの仕組み

 gitコマンドはほとんどの場合、「サブコマンド」と組み合わせて利用します。今回紹介する「git log」はコミット時のログ(コミットログ)を表示するコマンドです(本連載ではgitとサブコマンドの組み合わせをコマンドとして紹介します)。

 gitコマンドが扱う「リポジトリ(repository)」とは、ソースコードや変更履歴、コメントなどを一括して保管する場所です。リポジトリには、自分のPC上に作る「ローカルリポジトリ」と、「GitHub」などのWebサービス上に作る「リモートリポジトリ」があり、両者を連携させることで複数の開発者による開発を1本にまとめることができます。

 既存のリポジトリ(リモートリポジトリ)にあるソースコードなどを入手したい場合は、まず、「git clone」(連載第381回)でリポジトリを自分の環境に複製します(※1)。リモートリポジトリの内容がバージョンアップされたら「git pull」(連載第382回)コマンドで最新版を取得します。開発に参加するのではなく、単に最新版を取得したいという場合は、「git clone」と「git pull」を利用すればよいでしょう。

※1 特定のファイルだけが欲しい場合、例えばGitHub(github.com)にあるリポジトリであれば「Raw」というボタンで表示されるURLを使い、「wget」コマンドなどを使ってダウンロードできる。この他、プロジェクト全体をダウンロードするためのリンクも用意されている([Clone or download]ボタン→「Download ZIP」)。



 保管場所であるリポジトリに対し、ファイルの編集などを行う場所を「ワークツリー」あるいは「ワーキングエリア」などと呼びます。「git clone」や「git pull」で取得した最新版のファイルはワークツリーに配置されます。つまり「作業ディレクトリ」です。

 ワークツリー(作業ディレクトリ)で編集した結果をリポジトリに反映する操作を「コミット」と呼びます。「git add」(連載第384回)コマンドでコミットしたいファイルを「インデックス」あるいは「ステージングエリア」と呼ばれる領域に追加します。インデックスにはファイルの変更箇所などが記録されます。

 インデックスの内容は「git commit」コマンドでローカルリポジトリにコミットされ、「git push」コマンドでローカルリポジトリの内容をリモートリポジトリに反映します。従って、「git add」や「git commit」などを行わなければ、自分の環境で編集した内容がリポジトリに影響を与えることはありません。自由に編集し、テストできます。なお、ワークツリーのファイルを過去の任意のコミット状態に戻すことも可能です。

 Gitには、この他、開発中のソースコードやドキュメントを、「テスト版」「○○版」……のように枝分かれさせたり、それらを合流させたりする機能もあります。枝分かれしたそれぞれのバージョンを「ブランチ」(branch)と呼び、ブランチを合流させることを「マージ」(merge)と呼びます。



コマンドの書式

git [オプション] サブコマンド [サブコマンドごとのオプションや引数]

git log [オプション] [対象……]

※ 「対象」にはファイル名やブランチ、タグ、コミットのハッシュ値などが指定可能。[ ]は省略可能な引数を示しています。




gitの主なオプション

短いオプション 長いオプション 意味
-C パス カレントディレクトリではなく指定したディレクトリで実行したものとする
--bare リポジトリを「bareリポジトリ」(ワーキングディレクトリが存在しない、管理だけを目的としたリポジトリ)として扱う
-c 設定=値 設定値を指定する(設定は「git config」で確認可能)
-p --paginate 全ての出力を「less」コマンドまたは環境変数PAGERで指定されたコマンドで表示する
-P --no-pager 「less」コマンドで表示しない(「-p」の指定を打ち消す)
--exec-path=パス gitの実行ファイルのパスを指定する(「--exec-path」のみの場合、実行ファイルのパスを表示する)
--html-path gitのHTML形式のドキュメントがインストールされたパスを表示する
--man-path gitのmanファイルのパスを表示する
--info-path gitのinfoファイルのパスを表示する

gitのサブコマンド

コマンド 実行内容
clone リポジトリのクローンを作成する
init リポジトリを新規作成する、または既存のリポジトリを初期化する
remote リモートリポジトリを関連付けする
fetch リモートリポジトリの内容を取得する
pull リモートリポジトリの内容を取得し、現在のブランチに取り込む(「fetch」と「merge」を行う)
push ローカルリポジトリの変更内容をリモートリポジトリに送信する
add ファイルをインデックスに追加する(コミットの対象にする)
rm ファイルをインデックスから削除する
mv ファイルやディレクトリの名前を変更する
reset ファイルをインデックスから削除し、特定のコミットの状態まで戻す
status ワークツリーにあるファイルの状態を表示する
show ファイルの内容やコミットの差分などを表示する
diff コミット同士やコミットと作業ツリーの内容を比較する
commit インデックスに追加した変更をリポジトリに記録する
tag コミットにタグを付ける、削除する、一覧表示する
log コミット時のログを表示する
grep リポジトリで管理されているファイルをパターン検索する
branch ブランチを作成、削除、一覧表示する
checkout 作業ツリーを異なるブランチに切り替える
merge 他のブランチやコミットの内容を現在のブランチに取り込む
rebase コミットを再適用する(ブランチの分岐点を変更したり、コミットの順番を入れ替えたりできる)
config 現在の設定を取得、変更する

git logの主なオプション(フォーマット関連)

短いオプション 長いオプション 意味
--graph ログとともに、枝分かれやマージの様子を示すグラフを表示する
--reverse ログを逆順(古い順)に表示する(--graphとは同時に指定できない)
--decorate=表示 refs部分の表示方法を「short」「full」「auto」「no」のいずれかで指定する(※2)。「full」は接頭辞(refs/heads/、refs/tags/、refs/remotes/)付きで表示、「short」は接頭辞を付けずに表示(デフォルト)、「auto」は画面表示の際は表示、それ以外のときは非表示、「no」常に非表示になる
--no-decorate 「--decorate=no」相当の指定となる
--stat ログとともに、どのファイルが何カ所変更されたのかを表示する
--name-only ログとともに、変更されたファイルの名前のみを表示する
--shortstat ログとともに、追加、修正、削除の個数のみを表示する
--name-status ログとともに、変更されたファイルの変更情報(追加、修正、削除のいずれか)を表示する
-p、-u --patch 差分の内容を表示する
--abbrev-commit コミットのハッシュ値を、特定できる範囲の省略形(デフォルトは先頭7バイト分)で表示する
--no-abbrev コミットのハッシュ値を全て表示する(40バイト)
--abbrev=バイト数 コミットのハッシュ値を指定したバイト数分だけ表示する
--parents 親コミット(変更元)のハッシュ値も一緒に表示する
--pretty 表示フォーマットを「oneline」「short」「medium」(デフォルト)、「full」「fuller」で指定する。「--pretty=format:」で書式を指定可能(連載第388回)
--date 日付の書式(連載第388回)
--oneline 各コミットを1行で簡潔に表示する(「--pretty=oneline --abbrev-commit」相当)

※2 .git/refsは「参照先」を管理するディレクトリ。例えば、「.git/refs/heads/master」ファイルには、最新のコミットのハッシュ値が保存されている。「--branches」「--tags」「--remotes」はそれぞれ「.git/refs/branches/」「.git/refs/brances/tags/」「.git/refs/brances/remotes/」にあるファイル名を指定するため、シェルのパス名展開と同じ「*」記号などを使用できる。



git logの主なオプション(表示対象関連)

短いオプション 長いオプション 意味
-個数、-n 個数 --max-count=個数 表示するコミットの個数を指定する
--skip=個数 先頭からスキップするコミットの個数を指定する
--since=日付、--after=日付 指定した日付以降のコミットを表示する。「--since=2020/4/1」のような指定の他、「--since="2 days ago"」のような指定も可能
--until=日付、--before=日付 指定した日付までのコミットを表示する
-L 対象 「-l :関数名:ファイル名」または「-L 開始位置,終了位置:ファイル名」で、指定した関数の変更履歴を表示する。関数名や位置の指定には正規表現を使用可能
--merges マージしたときのコミットを表示する
--no-merges マージしたときのコミットを除いて表示する
--first-parent 最初に親となったコミットを表示する(マージコミットのマージ元を除外する)
--all 全てのブランチを表示する
--branches 「refs/heads」の全てのブランチを指定する。「--branches=パターン」で対象を指定できる(※2)
--tags 「refs/tags」の全てのタグを指定する。--tags=パターンで対象を指定できる(※2)
--remotes 「refs/remotes」の全てのリモートブランチを指定する。--remotes=パターンで対象を指定できる(※2)
--grep=文字列 コミットメッセージに指定した文字列を含んでいるコミットを表示する。正規表現によるパターン指定が可能
-i --regexp-ignore-case 正規表現の指定で大小文字を区別しない
--basic-regexp 正規表現の指定で基本正規表現を使用する(デフォルト)
-E --extended-regexp 正規表現の指定で拡張正規表現を使用する
--invert-grep 正規表現の指定で当てはまらなかったものを表示する
-F --fixed-strings 正規表現の指定を固定文字列として扱う(正規表現として解釈しない)
-P --perl-regexp 正規表現の指定でPerl互換の動作とする
--author=文字列 コミットのAuthor欄(名前とメールアドレス)に、指定した文字列を含んでいるコミットを表示する。正規表現によるパターン指定が可能


表示対象を期間で指定する

 「git log --since 日付」や「git log --until 日付」で、コミットログから表示する日付の範囲を指定できます(画面1)。「2020/4/10」のような指定の他に「2 days ago」や「3 years ago」のような指定も可能です(画面2)。

 コミットを表示する際は、通常新しい順に出力します。ここで「--reverse」オプションを指定すると古い順に表示できます。一番古い日付から確認したい場合は「git log --reverse」とするとよいでしょう。なお、「-10」(-n 10)のような件数の指定は、常に新しいコミットからのカウントとなります。

コマンド実行例

git log --since 日付

(指定した日付以降のコミットログを表示する)

git log --until 日付

(指定した日付以前のコミットログを表示する)

git log --since 日付1 --until 日付2

(日付1から日付2までの期間のコミットログを表示する)

git log --since 2020/2/1 --until 2020/2/29

(2020年2月のコミットを表示する)

git log --since 2020/2/1 --until 2020/2/29 --reverse

(2020年2月のコミットを逆順で表示する)

git log --since "3 years ago" --oneline

(過去3年分のコミットを1行に1件ずつ表示する)

git log --reverse

(コミットを逆順で表示する。一番古いコミットが先頭になる)


画面1 画面1 2020年2月のコミットログを表示したところ
画面2 画面2 過去3年間のコミットログを1行に1件ずつ表示したところ


表示対象をファイル名で指定する

 「git log ファイル名」で、指定したファイルを変更したときのコミットログを表示します(画面3)。ファイル名は複数指定可能です。

コマンド実行例

git log ファイル

(指定したファイルを変更したコミットを表示する)

git log file1 file2

(file1とfile2を変更したコミットを表示する)

git log --stat file1 file2

(file1とfile2を変更したコミットについて、各ファイルについてどのように変更されたかを表示する。変更、追加、削除の件数を表示する)

git log --oneline file1 file2

(file1とfile2を変更したコミットを1行に1件ずつ一覧表示する)


画面3 画面3 指定したファイルのコミットログを表示したところ


表示対象をブランチやコミットで指定する

 「git log ブランチ」で、指定したブランチのログを表示できます。リモートのブランチも指定可能です(画面4、※3)。

※3 どのようなブランチがあるのかは「git branch -a」で確認可能。現在参照しているブランチを緑色で「* ブランチ名」と表示する。ローカルにあるブランチを白、リモートリポジトリのみに存在するブランチを赤で表示する。



 ブランチではなく特定のコミットを表示したい場合は、タグまたはコミットのハッシュ値を使って「git log ハッシュ値」のように指定します(画面5)。この場合、一番古いコミットから指定したコミットまでを表示するため、「-件数」(-n 件数)で表示件数を絞るか、「--since」で表示を開始する日付を指定するとよいでしょう。

 ハッシュ値は40バイトと長い文字列です。コミットが特定できれば40桁全てを指定する必要はありません。例えば「git log --oneline」では、ハッシュ値を最低7桁表示します。特定するためにさらに桁数が必要な場合は8桁、9桁と桁数を増やして表示します(※4)。このため「--oneline」で表示するハッシュ値だけでコミットを特定できます。

※4 「git log --abbrev-commit」でも確認可能。



 なお、「git log ハッシュ値1..ハッシュ値2」のように範囲を指定できますが、このときハッシュ値1で指定したコミットを範囲に含みません。ハッシュ値1も含めたい場合は、「git log ハッシュ値1^..ハッシュ値2」のように指定してください(※5)。

※5 リビジョンの範囲指定について、詳しくは「man gitrevisions」を参照。



 この他、マージしたときのコミットだけを表示する「--merges」や、逆にマージしたときのコミットを除く「--no-merges」など、さまざまなオプションでコミットを指定することが可能です。

コマンド実行例 ※6

git log HEAD^..HEAD

(現在のコミットとその親《変更元》のコミットを表示する)

git log タグ1..タグ2

(タグ1の次からタグ2までのコミットを表示する。古いタグを先に指定する)

git log タグ1^..タグ2

(タグ1からタグ2までのコミットを表示する。古いタグを先に指定する)

git log ハッシュ値 -1

(指定したハッシュ値のコミットから1件分を表示する、※7)

git log ハッシュ値1^..ハッシュ値2

(ハッシュ値1のコミットからハッシュ値2のコミットまで表示する。古いコミットを先に指定する)

※6 範囲指定した場合、コメントのみのコミットや、マージした際のコミットなど、コミットの状況によって表示件数が異なる。
※7 「git show ハッシュ値」で指定したハッシュ値のコミット内容を表示できる。




画面4 画面4 現在のコミットとその親(変更元)のコミットを表示したところ
画面5 画面5 ハッシュ値を指定してコミットを表示したところ


表示対象をメッセージ内の文字列やコミットした人で指定する

 「--author=文字列」オプションで、コミットした人の名前やメールアドレス、「--grep=文字列」オプションでコミット時のメッセージに書かれている文字列で、コミットを指定できます。どちらも正規表現を使った指定が可能です。

 大文字と小文字を区別したくない場合は「-i」(--regexp-ignore-case)オプションを指定し、拡張正規表現を使いたい場合は「-E」(--extended-regexp)オプションを利用します(※8)。

※8 1回以上の文字の繰り返しを表す「+」など、利用できるメタ文字を増やした正規表現を拡張正規表現と呼ぶ。「grep」コマンドで、「grep -E」とすると拡張正規表現を使うことができる。



 さらに、--grepや--authorの条件に合致しなかったコミットを表示したい場合は「--invert-grep」を指定します。

コマンド実行例

git log --grep=文字列

(コミットメッセージ内に文字列を含んでいるコミットログを表示する)

git log --author=文字列

(コミットした人の名前やメールアドレスに指定した文字列が含まれているコミットログを表示する)

git log --author=文字列 --invert-grep

(--authorで指定した以外の人によるコミットログを表示する)

git log --grep="pull request" -i

(コミットメッセージに「pull request」《大文字小文字の区別なし》を含むコミットを表示する)

git log --oneline --grep="pull request" -i -10

(コミットメッセージに「pull request」《大文字小文字の区別なし》を含むコミットを10件分、1行に1件ずつ表示する)


画面6 画面6 メッセージ内の文字列を指定してコミットログを表示したところ


筆者紹介

西村 めぐみ(にしむら めぐみ)

元々はDOSユーザーで「DOS版UNIX-like tools」を愛用。ソフトハウスに勤務し生産管理のパッケージソフトウェアの開発およびサポート業務を担当、その後ライターになる。著書に『図解でわかるLinux』『らぶらぶLinuxシリーズ』『Accessではじめるデータベース超入門[改訂2版]』『macOSコマンド入門』など。地方自治体の在宅就業支援事業にてMicrosoft Officeの教材作成およびeラーニング指導を担当。会社などの"PCヘルパー"やピンポイント研修なども行っている。


Copyright © ITmedia, Inc. All Rights Reserved.

RSSについて

アイティメディアIDについて

メールマガジン登録

@ITのメールマガジンは、 もちろん、すべて無料です。ぜひメールマガジンをご購読ください。