0
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?

Git プッシュ後のリベース

Posted at

内容

Gitでプッシュ後にリベースする方法を記載してます。

経緯

最近ブランチの共有が何回かありました。

  • この部分作ってあるから後よろしくね。という感じでプッシュされたブランチをローカルに落として残りを自分が対応する。※マージはされてない
  • 自分が途中まで作ったけど別作業入ったので、プッシュだけして他の人が残りを対応することになったけど、早く終わったので続きを自分が対応する。

など

前までいたPJでは中途半端に作業が終わるのであればきりがいいとこまでやってマージし、残りを他の人が対応という感じでした。
Gitを触り始めたころプッシュ後にリベースやマージをやって別ブランチの変更内容がコミット履歴に入ってきてコミット履歴が見づらいとなったことがあり(あったはず)、プッシュ後のリベース・マージは個人的に抵抗がありました。
対策は1個持ってたのですが、別の方法も気になったので動作確認してみたという感じです。

そもそもリベースとは

マージは何となくイメージ付くと思います。
ローカルブランチから最新のdevelpブランチを取り込むことで、他の人が変更した内容をローカルブランチにも取り込むことができるという感じです。
リベースはマージしつつ、ローカルのコミットをまとめてくれるというものです。

これが最新を取り込む前の状態です。
image.png

「コミット」と記載がある場所が最新のmainです。
※developに置き換えてください

  1. ブランチA・Bを作成
  2. ブランチAで「a-1」コミット
  3. ブランチBで「b-1」コミットし、マージ
  4. ブランチAで「a-2」コミット

マージだとコミット履歴は下図になります。
image.png

リベースだとコミット履歴は下図になります。
※ブランチ名違いますがやってることは最新を取り込む前の状態と同じ内容です。
image.png

リベースを使うことでローカルブランチ(ブランチX)でのコミットがばらばらにならずに、まとまっているのを確認できます。

動作確認

ここからプッシュ後にマージやリベースをしてみます。

プッシュ後にリベース

  1. 最新を取り込む前の状態にする。
    image.png

  2. ブランチ1をプッシュする。
    image.png

  3. ブランチ1にいる状態で最新のmainをリベースする。
    image.png

  4. ブランチ1をプッシュする。
    image.png

結果

image.png

コミット履歴がよくわからんことになった。

プッシュ後にマージ

  1. 最新を取り込む前の状態にする。
    image.png

  2. ブランチAをプッシュする。
    image.png

  3. ブランチAにいる状態で最新のmainをマージしてプッシュする。
    image.png

結果

image.png

マージのコミットが入ってきた。
期待していたのと違ってた。プッシュ後にマージしたら他の変更差分もブランチa-1コミットみたいに表示されて、ローカルコミットと他ブランチのコミットが混ざってたような記憶があるんだけど、今回みたいにマージしましたよみたいな感じで見やすいコミット履歴ではなかった気がする。あと変更ファイルが1件(x1.txt)になっているけど、記憶だとコミット履歴が混ざるためx2.txtも含まれて2件になるはず。
何かの手順が抜けていたか夢でも見てたのかもしれない。

プッシュ後にリモートブランチを削除してリベース

  1. 最新を取り込む前の状態にする。
    image.png

  2. ブランチXをプッシュする。
    image.png

  3. ブランチXのリモートブランチ(ローカルでないほうのブランチ)を削除する。
    image.png

  4. ブランチXにいる状態で最新のmainをマージする。
    image.png

  5. ブランチXをプッシュする。

image.png

image.png

結果

最新を取り込みつつコミット履歴が整理されていて、Github側のプッシュ内容もローカルコミットのみ表示されている。

プッシュ後にリモートブランチを削除してマージ

結果

普通にマージするのと変わらず

image.png

プッシュ後に別ブランチを作成してリベース

  1. 最新を取り込む前の状態にする。
    image.png

  2. ブランチX1をプッシュする。
    image.png

  3. ブランチX1にいる状態でブランチX2を作成する。
    image.png

  4. ブランチX2にいる状態で最新のmainをマージしてプッシュする。
    image.png

結果

image.png

コミット履歴がローカルの差分だけ表示される。

まとめ

プッシュ後にコミット履歴を気にしないならマージ
コミット履歴を気にするならリモートブランチを削除してリベースするか、
プッシュ元の派生ブランチからリベースすることでコミット履歴に他の差分が入らないようになります。

自分は派生ブランチ作成派です。履歴きれいになるし、不要なリモートブランチを最後にまとめて消せるため。

0
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
0
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?