Heim  >  Artikel  >  Entwicklungswerkzeuge  >  Helfen Sie beim Löschen von Verlaufsdatensätzen in Git

Helfen Sie beim Löschen von Verlaufsdatensätzen in Git

PHPz
PHPzOriginal
2023-04-03 09:18:261717Durchsuche

Entwickler, die Git für das Projektmanagement verwenden, stoßen häufig auf Situationen, in denen sie historische Datensätze löschen müssen. Zum Beispiel, wenn sensible Informationen übermittelt werden oder das Gesetz die Entfernung bestimmter Inhalte vorschreibt. Da Git jedoch darauf ausgelegt ist, alle Änderungen aufzuzeichnen, ist das Löschen des Verlaufs keine leichte Aufgabe. In diesem Artikel werden einige Methoden vorgestellt, die Ihnen beim Löschen von Verlaufsdatensätzen in Git helfen.

  1. Git-Befehl verwenden

Sie können git reset und git push im Git-Befehl verwenden, um Verlaufsdatensätze zu löschen. Verwenden Sie zunächst den Befehl git log, um den Verlauf anzuzeigen. git resetgit push 删除历史记录。首先使用 git log 命令查看历史记录。

$ git log --oneline

这会列出当前分支上的所有提交记录,每个记录都有一个 SHA-1 标识符(第一列)和一个消息(后面的列)。

然后,使用 git reset 命令将当前分支重置到要删除的提交之前。例如,如果要删除最近的三个提交记录,则可以使用:

$ git reset HEAD~3

这样就将当前分支重置到了前三个提交记录之处,历史记录中的最后三个提交会被删除。

最后,使用 git push -f 命令强制推送到远程仓库,覆盖历史记录。这会使其他人在拉取更新时遇到问题,因此需要确保所有有权限的人知道此操作。

$ git push -f

使用此方法删除历史记录时,我们建议在执行之前备份代码库,以防万一。

  1. 使用 BFG Repo-Cleaner

另一个强大的工具是 BFG Repo-Cleaner。它是一个 Java 程序,可以在本地运行,删除 Git 仓库中的历史记录。

首先,安装 BFG Repo-Cleaner。可以使用 Homebrew 在 Mac 上安装:

$ brew install bfg

或者从官网下载并安装到计算机上:

$ wget http://search.maven.org/remotecontent?filepath=com/madgag/bfg/1.14.0/bfg-1.14.0.jar

然后,在 Git 仓库的根目录下运行以下命令(请确保在删除前备份代码库):

$ java -jar /path/to/bfg.jar --delete-files filename.txt.git
$ git reflog expire --expire=now --all && git gc --prune=now --aggressive
$ git push

其中,filename.txt.git 是包含要删除内容的文件名(例如 .git-credentials)。这里使用 BFG Repo-Cleaner 删除提交历史、refs 和 tags,然后重新压缩存储库。

需要注意的是,BFG Repo-Cleaner 可以删除仓库中的任何内容,因此需要小心操作。

  1. 创建一个新的 Git 仓库

最后一种方法是创建一个新的 Git 仓库,只包含要保留的提交记录。这种方法需要一些手动操作,但可以保留仓库的完整性,并且不会影响其他人在仓库上的工作。

首先,在原始 Git 仓库的根目录下创建一个新目录,用于保存新的 Git 仓库:

$ mkdir newrepo && cd newrepo

然后,将原始 Git 仓库的选择性提交记录复制到新目录中:

$ git clone /path/to/oldrepo --depth 1
$ cd oldrepo && git log --oneline

这样就可以将原始 Git 仓库的最后一个提交记录复制到新的 Git 仓库中。更新新仓库的远程 URL,然后将其推送到远程仓库。

$ git remote set-url origin git://new/repo.git
$ git push -u origin master

这样就创建了一个新的 Git 仓库,只包含选择性提交的记录。

总结

在 Git 中,删除历史记录是一个敏感的问题,需要小心谨慎操作。使用 git resetrrreee

Hier werden alle Commit-Datensätze im aktuellen Zweig aufgelistet, jeweils mit einer SHA-1-Kennung (erste Spalte) und einer Nachricht (spätere Spalten). 🎜🎜Dann verwenden Sie den Befehl git reset, um den aktuellen Zweig auf den Stand vor dem Commit zurückzusetzen, den Sie löschen möchten. Wenn Sie beispielsweise die letzten drei Commit-Datensätze löschen möchten, können Sie Folgendes verwenden: 🎜rrreee🎜 Dadurch wird der aktuelle Zweig auf die ersten drei Commit-Datensätze zurückgesetzt und die letzten drei Commits im Verlauf werden gelöscht. 🎜🎜Verwenden Sie abschließend den Befehl git push -f, um den Push zum Remote-Repository zu erzwingen und den Verlauf zu überschreiben. Dies kann für andere beim Abrufen von Updates zu Problemen führen. Sie müssen daher sicherstellen, dass jeder mit den entsprechenden Berechtigungen davon weiß. 🎜rrreee🎜Wenn Sie den Verlauf mit dieser Methode löschen, empfehlen wir für alle Fälle, die Codebasis vor der Ausführung zu sichern. 🎜
    🎜Verwenden Sie BFG Repo-Cleaner🎜🎜🎜Ein weiteres leistungsstarkes Tool ist BFG Repo-Cleaner. Es handelt sich um ein Java-Programm, das lokal ausgeführt werden kann, um den Verlauf in einem Git-Repository zu löschen. 🎜🎜Installieren Sie zunächst BFG Repo-Cleaner. Sie können es mit Homebrew auf einem Mac installieren: 🎜rrreee🎜 Oder laden Sie es von der offiziellen Website herunter und installieren Sie es auf Ihrem Computer: 🎜rrreee🎜 Führen Sie dann den folgenden Befehl im Stammverzeichnis des Git-Repositorys aus (bitte stellen Sie sicher, dass Sie zurückkommen). Aktualisieren Sie die Codebasis vor dem Löschen): 🎜rrreee🎜 Wobei filename.txt.git der Name der Datei ist, die den zu löschenden Inhalt enthält (z. B. .git-credentials). >). Hier wird BFG Repo-Cleaner verwendet, um den Commit-Verlauf, Refs und Tags zu entfernen und das Repository anschließend erneut zu komprimieren. 🎜🎜Es ist zu beachten, dass BFG Repo-Cleaner alle Inhalte im Repository löschen kann, daher müssen Sie es mit Vorsicht bedienen. 🎜
      🎜Erstellen Sie ein neues Git-Repository🎜🎜🎜Die letzte Methode besteht darin, ein neues Git-Repository zu erstellen, das nur die Commit-Datensätze enthält, die Sie behalten möchten. Diese Methode erfordert einige manuelle Arbeit, bewahrt jedoch die Integrität des Repositorys und hat keinen Einfluss auf die Arbeit anderer Personen am Repository. 🎜🎜Erstellen Sie zunächst ein neues Verzeichnis im Stammverzeichnis des ursprünglichen Git-Repositorys, um das neue Git-Repository zu speichern: 🎜rrreee🎜Dann kopieren Sie die selektiven Commit-Datensätze des ursprünglichen Git-Repositorys in das neue Verzeichnis: 🎜rrreee🎜Das ist es Sie können den letzten Commit-Datensatz des ursprünglichen Git-Repositorys in das neue Git-Repository kopieren. Aktualisieren Sie die Remote-URL des neuen Repositorys und übertragen Sie sie per Push an das Remote-Repository. 🎜rrreee🎜Dadurch wird ein neues Git-Repository erstellt, das nur selektiv festgeschriebene Datensätze enthält. 🎜🎜Zusammenfassung🎜🎜In Git ist das Löschen des Verlaufs ein heikles Thema und muss mit Vorsicht behandelt werden. Verwenden Sie den Befehl git reset, um einige aktuelle Commit-Datensätze zu löschen. Verwenden Sie BFG Repo-Cleaner, um den Commit-Verlauf einer bestimmten Datei oder eines bestimmten Ordners zu löschen. Schließlich können Sie optional Commit-Datensätze beibehalten, indem Sie ein neues Git-Repository erstellen. In jedem Fall müssen Sie für alle Fälle Ihre Codebasis sichern, bevor Sie sie löschen. 🎜

Das obige ist der detaillierte Inhalt vonHelfen Sie beim Löschen von Verlaufsdatensätzen in Git. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn