Git は、現在最も人気のあるバージョン管理ツールの 1 つです。そのパワーと柔軟性は開発者やチームに好まれており、Git はプロジェクトのすべての変更と履歴を追跡できます。ただし、開発が進むにつれて、一部の古いバージョンを削除する必要がある場合があります。この記事では、古いバージョンを削除して Git 履歴をクリーンアップする方法について説明します。
Git Reset コマンドを使用すると、古いバージョンを簡単に削除できます。これにより、HEAD (現在のブランチ) が削除する古いバージョンを指すようになります。 Git Reset は実際には HEAD が古いバージョンを指すため、そのバージョン以降に行われた変更はすべて失われることに注意してください。
HEAD が古いバージョンを指すようにするコマンドは次のとおりです:
git reset <commit>
ここで、bc59094fbd619487e70ee0dbb7ee2c82 は削除する古いバージョン番号です。たとえば、最新の 2 つのコミットを削除する場合、コマンドは次のようになります。
git reset HEAD~2
これにより、HEAD は最後から 3 番目のコミットを指します。
単純なコマンドは HEAD をリセットしますが、コミットは削除しません。本当にコミットを削除したい場合は、「--hard」オプションを使用する必要があります:
git reset --hard <commit>
これはリターンのない操作であることに注意してください。このコミットに切り替えて復元する必要がある場合は、バックアップを作成してください。
Git Revert を使用すると、古いバージョンに加えられた変更を元に戻す新しいコミットが作成されます。これは、コミットを削除せず、新しいコミットを作成して古いバージョンの変更を元に戻すため、より安全なアプローチです。
コミットを取り消すコマンドは次のとおりです:
git revert <commit>
ここで、bc59094fbd619487e70ee0dbb7ee2c82 は取り消したい古いバージョン番号です。たとえば、最近の 2 つのコミットを元に戻すには、次のように入力します。
git revert HEAD~2..HEAD
これにより、3 番目から最後のコミットから最新のコミットまでのすべての変更を元に戻す新しいコミットが作成されます。
上記の 2 つの方法は、履歴を変更する 1 つの方法です。共有ブランチで Git Reset または Git Revert を使用すると、他のユーザーに履歴エラーが発生する可能性があります。ここで Git リベースが登場します。
Git Rebase は、コミットを整理して新しい履歴を形成する方法です。あるブランチのコミットを別のブランチのコミットに統合することで、ブランチ履歴をクリーンアップし、古いバージョンを削除します。
コマンドは次のとおりです:
git rebase -i <commit>
ここで、-i フラグは、削除するコミットを選択できる対話型リフローをオンにします。たとえば、最新の 2 つのコミットを削除するには、次のように入力します。
git rebase -i HEAD~2
次に、エディターのコミットのリストを次のように変更します。
pick abcdefg commit message d eeeeee commit message d fffffff commit message
最初の 2 つの項目を「Pick」に設定し、残りの項目を「Pick」に設定します。どちらの項目も「d」(削除)に設定されます。保存してエディターを閉じると、Git は新しい履歴レコードを再作成します。
概要
上記は、Git を使用して古いバージョンを削除する 3 つの方法です。各方法はさまざまなシナリオに適しており、独自の長所と短所があります。特定の状況に基づいて、最適な方法を選択してください。どちらの方法を選択する場合でも、コードを復元する必要がある場合に復元できるように、コミットを削除する前に必ずバックアップを作成してください。
以上がgit で以前のバージョンを削除する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。