1
1

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 1 year has passed since last update.

git reflog がすごい

Posted at

git reflog

reflogは、gitで行った操作の履歴をみることができます。
さらに、resetを使用して、gitの操作を操作することができます。

gitの操作とは、どういう意味か

例えば、

  • git revert
    git revertは、特定のコミットを打ち消すコミットを新しく作成するコマンド。
    PRなどをマージ後に取り消したいときに使うお馴染みの操作。
    git revert {commit id}

  • git reset --head HEAD^
    コミットを取り消すコマンド。
    pushする前であれば、間違えてしまったコミットをやり直したり、取り消したりすることができる操作。
    git reset --head HEAD^

上記のコマンドは、コミットに対して操作しています。

git reflogでは操作のログを確認することができます。

% git reflog
e821293 (HEAD -> master) HEAD@{0}: revert: Revert "Merge commit 'edc11a9e0fcfefe8f2a25b6c48eb383a0bca07dc' into feature/test2"
bdeff3a (feature/test2) HEAD@{1}: merge feature/test2: Fast-forward
edc11a9 (feature/test4, feature/test3) HEAD@{2}: checkout: moving from feature/test4 to master
edc11a9 (feature/test4, feature/test3) HEAD@{3}: checkout: moving from master to feature/test4
edc11a9 (feature/test4, feature/test3) HEAD@{4}: checkout: moving from feature/test3 to master
edc11a9 (feature/test4, feature/test3) HEAD@{5}: checkout: moving from master to feature/test3
edc11a9 (feature/test4, feature/test3) HEAD@{6}: checkout: moving from feature/test2 to master
bdeff3a (feature/test2) HEAD@{7}: merge edc11a9e0fcfefe8f2a25b6c48eb383a0bca07dc: Merge made by the 'recursive' strategy.
ad76b54 HEAD@{8}: checkout: moving from master to feature/test2
edc11a9 (feature/test4, feature/test3) HEAD@{9}: commit: add test
d567f03 HEAD@{10}: checkout: moving from feature/test2 to master

revertmergecheckoutcommitなど、リポジトリ内でgit操作した履歴が表示されています。

gitの操作の操作をする

先ほどのgit reflogで表示された履歴から、git reset --hard HEAD@{n}でそれよりあとに行った操作を取り消すことができます。

上の例で、「feature/test2ブランチをmasterにFast-forwardでマージした」部分まで、操作を戻したいとします。

git reset --hard HEAD@{1}を実行すると、

% git reflog               
bdeff3a (HEAD -> master, feature/test2) HEAD@{0}: reset: moving to HEAD@{1}
e821293 HEAD@{1}: revert: Revert "Merge commit 'edc11a9e0fcfefe8f2a25b6c48eb383a0bca07dc' into feature/test2"
bdeff3a (HEAD -> master, feature/test2) HEAD@{2}: merge feature/test2: Fast-forward
edc11a9 (feature/test4, feature/test3) HEAD@{3}: checkout: moving from feature/test4 to master
edc11a9 (feature/test4, feature/test3) HEAD@{4}: checkout: moving from master to feature/test4
edc11a9 (feature/test4, feature/test3) HEAD@{5}: checkout: moving from feature/test3 to master
edc11a9 (feature/test4, feature/test3) HEAD@{6}: checkout: moving from master to feature/test3
edc11a9 (feature/test4, feature/test3) HEAD@{7}: checkout: moving from feature/test2 to master
bdeff3a (HEAD -> master, feature/test2) HEAD@{8}: merge edc11a9e0fcfefe8f2a25b6c48eb383a0bca07dc: Merge made by the 'recursive' strategy.
ad76b54 HEAD@{9}: checkout: moving from master to feature/test2
edc11a9 (feature/test4, feature/test3) HEAD@{10}: commit: add test

直前(HEAD@{0})にあった、「revert: Revert "Merge commit 'edc11a9e0fcfefe8f2a25b6c48eb383a0bca07dc' into feature/test2"」のマージコミットをリバートした操作が取り消されていることがわかります。

 % git log
commit bdeff3acf061a8d7793c5f5ad95e3f7e39bf1d86 (HEAD -> master, feature/test2)
Merge: ad76b54 edc11a9
Author: bebeken <xxx>
Date:   Sat Sep 11 16:09:24 2021 +0900

    Merge commit 'edc11a9e0fcfefe8f2a25b6c48eb383a0bca07dc' into feature/test2

commit edc11a9e0fcfefe8f2a25b6c48eb383a0bca07dc (feature/test4, feature/test3)
Author: bebeken <xxx>
Date:   Sat Sep 11 16:08:45 2021 +0900

    add test


また、git logでも、リバートのコミットが消えていることがわかります。

私の場合・・・

今回の操作だと、ひとつ前の操作を取り消しただけでしたが、もっと盛大にやらかした場合は便利だと思います。
私の場合は、master/親ブランチ/作業ブランチのマージ順番をローカルで誤って、めちゃくちゃにしてしまったのでそれらの操作を丸々取り消したということで、git reflogに感動しました。

gitの基本コマンドは歴史を作っていくイメージですが、git reflogはもっと上の歴史を操作する神コマンドと感じました。

ちなみに、git log -gでも、reflogが見れるみたいでした。

% git log -g
commit bdeff3acf061a8d7793c5f5ad95e3f7e39bf1d86 (HEAD -> master, feature/test2)
Reflog: HEAD@{0} (bebeken <xxx>)
Reflog message: reset: moving to HEAD@{1}
Merge: ad76b54 edc11a9
Author: bebeken <xxx>
Date:   Sat Sep 11 16:09:24 2021 +0900

    Merge commit 'edc11a9e0fcfefe8f2a25b6c48eb383a0bca07dc' into feature/test2

commit e82129307f7db21eb9eccf5dc89fe3acd9a3366f
Reflog: HEAD@{1} (bebeken <xxx>)
Reflog message: revert: Revert "Merge commit 'edc11a9e0fcfefe8f2a25b6c48eb383a0bca07dc' into feature/test2"
Author: bebeken <xxx>
Date:   Sun Mar 19 20:17:15 2023 +0900

    Revert "Merge commit 'edc11a9e0fcfefe8f2a25b6c48eb383a0bca07dc' into feature/test2"
    
    This reverts commit bdeff3acf061a8d7793c5f5ad95e3f7e39bf1d86, reversing
    changes made to ad76b54e8c26013e18fd9ed891285829b44a92f6.
1
1
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
1
1

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?