検索
ホームページよくある問題git rebase を使用して Git のブランチをマージする方法

リベースとは何ですか? rebaseコマンドの使い方は? git rebaseコマンドの使い方を勉強しましょう。

Git のさまざまなブランチからの変更を統合するには、マージとリベースという 2 つの主な方法があることがわかっています。実際、git rebase と git merge は同じことを行います。どちらも、あるブランチから別のブランチに変更をマージするように設計されていますが、方法が若干異なります。

マージ コマンドの例

git checkout feature
git merge master

このようにして、機能ブランチの新しいマージ コミットは 2 つのブランチの履歴を結び付けます

マージ良い点は、安全な操作であることです。既存のブランチは変更されません

feature ブランチは、上流の変更がマージされるたびに外部マージ コミットを導入します。上流ブランチが非常にアクティブな場合、多かれ少なかれブランチ履歴が汚染されます

Rebase コマンドの例

git checkout feature
git rebase master

フィーチャー ブランチ全体をマスター ブランチに移動しますその後、master ブランチ上のすべての新しいコミットが効果的にマージされます。

ただし、rebase は元のブランチ上のコミットごとに新しいコミットを作成し、プロジェクト履歴を書き換えますが、マージはしません。

2 つのブランチをリベースする場合、生成された「リプレイ」をターゲット ブランチに適用する必要はなく、別のブランチを指定して適用することもできます。機能ブランチ サーバーを作成し、サーバーにいくつかの機能を追加し、C3 と C4 を送信しました。次に、C3 から機能ブランチ クライアントを作成し、クライアントにいくつかの機能を追加して、C8 と C9 を送信しました。最後に、サーバー ブランチに戻り、C10 を再度コミットします。

git rebase を使用して Git のブランチをマージする方法

クライアントの変更をメイン ブランチにマージして公開したいが、当面はサーバーの変更をマージしたくないとします。なぜなら、それらはまだより包括的にテストする必要があるからです。現時点では、 git rebase コマンドの --onto オプションを使用して、クライアント ブランチにあるがサーバー ブランチ (つまり、C8 と C9) にはない変更を選択し、マスター ブランチでそれらを再生できます。

$ git rebase --onto master server client

上記のコマンドは、「クライアント ブランチを取り出し、クライアント ブランチとサーバー ブランチの共通の祖先以降の変更を見つけて、マスター ブランチでそれらを再生します。」を意味します。これを理解するのは少し複雑ですが、エフェクトは非常にクールです。

git rebase を使用して Git のブランチをマージする方法

これで、マージ マスター ブランチを早送りできるようになりました。

$ git checkout master
$ git merge client

git rebase を使用して Git のブランチをマージする方法

次に、変更をサーバー ブランチに統合することにします。 git rebase [basebranch] [topicbranch] コマンドを使用して、機能ブランチ (つまり、この例ではサーバー) をターゲット ブランチ (つまり、マスター) に直接リベースします。これにより、最初にサーバー ブランチに切り替えてから、そのブランチ上で rebase コマンドを実行するという複数の手順が省略されます。

interesting-rebase-4 (1).png

$ git rebase master server

開発におけるリベースの使用シナリオ

リベースはチームの Git ワークフローに多かれ少なかれ適用できます

ローカル クリーンアップ

対話型リベースを時々実行すると、機能ブランチ内のすべてのコミットが焦点を絞った意味のあるものであることを確認できます。コードを記述するときに孤立したコミットが作成されることを心配する必要はありません。後で間違いなく修正できるためです。

次のコマンドは、最新の 3 つのコミットを対話的にリベースします。

git checkout feature
git rebase -i HEAD~3

実際には、ブランチは移動されません。次の 3 つのコミットをマージするだけです。

インタラクティブ リベースは、ローカル ブランチにのみ影響するため、ワークフローに git rebase を導入する優れた方法です。他の開発者は、あなたが行った結果のみを見ることができます。これは、非常に整然とした追跡しやすいブランチ履歴です。

ただし、繰り返しになりますが、これはプライベート ブランチでのみ使用できます。同じ機能ブランチで他の開発者と作業する場合、ブランチはパブリックになり、履歴を書き換えることはできません。

以上がgit rebase を使用して Git のブランチをマージする方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
github是什么github是什么Mar 24, 2023 pm 05:46 PM

​GitHub是一个面向开源及私有软件项目的托管平台,可以让开发者们在这里托管自己的代码,并进行版本控制。GitHub主打的是开源项目与协作,通过这个平台上的开源项目,开发者们可以查看其他开发者的项目源代码,并进行交流和学习。

git中push -u是什么意思git中push -u是什么意思Jul 01, 2022 am 10:36 AM

在git中,“push -u”的意思是将本地的分支版本上传到远程合并,并且记录push到远程分支的默认值;当添加“-u”参数时,表示下次继续push的这个远端分支的时候推送命令就可以简写成“git push”。

如何在GitLab上进行第一次登录并更改密码如何在GitLab上进行第一次登录并更改密码Mar 24, 2023 pm 05:46 PM

GitLab是一种基于Web的Git版本控制库管理软件,旨在帮助开发团队更好地协同工作,提高工作效率。当您第一次登录GitLab时,系统会提示您要更改初始密码以确保账户安全。本文将为大家介绍如何在GitLab上进行第一次登录并更改密码。

git的pack文件有什么用git的pack文件有什么用Jun 30, 2022 pm 05:41 PM

在git中,pack文件可以有效的使用磁盘缓存,并且为常用命令读取最近引用的对象提供访问模式;git会将多个指定的对象打包成一个成为包文件(packfile)的二进制文件,用于节省空间和提高效率。

git中pull失败了怎么办git中pull失败了怎么办Jun 30, 2022 pm 04:47 PM

git中pull失败的解决方法:1、利用“git reset --hard”强制覆盖掉自己的本地修改;2、利用“git stash”推送一个新的储藏,拉取之后利用“git stash pop”将修改保存到暂存区;3、若依然出现问题,则将文件保存到暂存区并提交注释即可。

git分支能改名字吗git分支能改名字吗Jun 16, 2022 pm 05:55 PM

git分支能改名字。改名方法:1、利用git中的branch命令修改本地分支的名称,语法为“git branch -m 旧名字 新名字”;2、利用“git push origin 新名字”命令,在删除远程分支之后将改名后的本地分支推送到远程;3、利用IDEA直接操作修改分支名称即可。

git怎么删除某个分支git怎么删除某个分支Jun 24, 2022 am 11:11 AM

git删除某个分支的方法:1、利用“git branch --delete dev”命令删除本地分支;2、利用“git push origin --delete branch”命令删除远程分支;3、利用“git branch --delete --remotes”命令删除追踪分支。

用三行代码使你的git提交记录变干净用三行代码使你的git提交记录变干净Feb 28, 2023 pm 04:19 PM

本篇文章给大家带来了关于git的相关知识,其中主要跟大家聊一聊怎么让你的git记录保持整洁,感兴趣的朋友下面一起来看一下吧,希望对大家有帮助。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

EditPlus 中国語クラック版

EditPlus 中国語クラック版

サイズが小さく、構文の強調表示、コード プロンプト機能はサポートされていません

SublimeText3 英語版

SublimeText3 英語版

推奨: Win バージョン、コードプロンプトをサポート!

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

強力な PHP 統合開発環境