进击云原生

V2

2022/11/26阅读:48主题:山吹

修改 Git 已经提交记录的 用户名 和邮箱

修改 Git 已经提交记录的 用户名 和邮箱

有关 Git 和版本控制的常见问题。

如何更改提交的作者姓名/电子邮件?

在我们进入解决方案之前,让我们找出您到底想要完成什么:

  • 在提交之前更改作者信息
  • 在提交后更改作者信息(即历史提交)

让我们详细看看这两种情况。

更改您的 Git 作者身份

在 Git 中可以通过三种方式更改提交者身份。所有这些方法只影响未来的提交,而不影响过去的提交!

全局更改提交者姓名和电子邮件

您可以使用 --global 标志运行git config命令;这将确保您未来的所有提交都使用给定的信息:

$ git config --global user.name "John Doe"
$ git config --global user.email "john@doe.org"

更改单独存储库的提交者姓名和电子邮件

如果你只想在某个存储库中工作时使用特殊设置,你可以简单地省略 --global 标志。这使得配置仅在该存储库中有效:

$ git config user.name "John Doe"
$ git config user.email "john@doe.org"

提醒: 在 Tower 中更改提交者信息 如果您使用的是Tower Git 客户端,您可以创建和管理多个“提交者身份”~ 一个用于工作,一个用于业余项目,一个用于开源……然后您可以选择要在每个文件上使用的配置文件-存储库甚至是每次提交的基础!

为下一次提交更改作者信息

最后,使用 --author 标志,您还可以覆盖下一次提交的作者信息:

git commit --author="John Doe <john@doe.org>"

编辑过去提交的作者

编辑过去的提交重写历史!

无论我们如何精确地更改过去提交的信息,始终要牢记一件事:如果我们这样做,我们实际上是在重写提交历史
这一点不能掉以轻心:您将在这个过程中创建新的提交对象,这对您的合作者来说可能会成为一个严重的问题——因为他们可能已经在一些原始提交的基础上进行了新的工作。
因此,在重写提交历史之前请三思!

可以通过三种基本方法来编辑过去的提交:

对最后一次提交使用 --amend

如果您只想更改最后一次提交,Git 提供了一种非常简单的方法来执行此操作:

git commit --amend --author="John Doe <john@doe.org>"

这有效地用您的“编辑”版本替换了最后一次提交,更正了错误的作者信息。

使用交互式变基

Interactive Rebase 是 Git 中的瑞士军刀工具:它允许你做和改变几乎任何事情。然而,尽管它很强大,但这也意味着你很容易搬起石头砸自己的脚。小心使用它(并可能阅读它)!

第一步是识别最后一个“好的”提交并将其散列提供给 rebase 命令:

$ git rebase -i -p 0ad14fa5

您的编辑器将打开,要求您使用“edit”关键字标记您想要更改的所有提交。


Git 现在将引导您完成每个提交,让您有机会按照自己的意愿进行塑造:

Stopped at 5772b4bf2... Add images to about page
You can amend the commit now, with

    git commit --amend

Once you are satisfied with your changes, run

    git rebase --continue

现在,您的工作是更正作者信息,然后继续处理下一个相关的提交对象,直到您编辑了刚刚标记的所有提交:

$ git commit --amend --author="John Doe <john@doe.org>" --no-edit
$ git rebase --continue

使用 git filter-branch 批量修改

另一种方法是使用 Git 的“filter-branch”命令。它允许您使用脚本批处理(可能很大)数量的提交。

您可以在存储库中运行以下示例脚本(为新旧电子邮件和名称填写实际值):

$ git filter-branch --env-filter '
WRONG_EMAIL="wrong@example.com"
NEW_NAME="New Name Value"
NEW_EMAIL="correct@example.com"

if [ "$GIT_COMMITTER_EMAIL" = "$WRONG_EMAIL" ]
then
    export GIT_COMMITTER_NAME="$NEW_NAME"
    export GIT_COMMITTER_EMAIL="$NEW_EMAIL"
fi
if [ "$GIT_AUTHOR_EMAIL" = "$WRONG_EMAIL" ]
then
    export GIT_AUTHOR_NAME="$NEW_NAME"
    export GIT_AUTHOR_EMAIL="$NEW_EMAIL"
fi
'
 --tag-name-filter cat -- --branches --tags

与提到的其他方法一样,同样的警告适用于此方法:您正在使用此命令重写历史记录,并在此过程中创建新的提交对象!

push到仓库:

git push --force

警告 ⚠️: 您应该只在尚未发布/共享的存储库中执行此操作。在任何其他情况下,您都应该格外小心地使用它,并且只有在您了解副作用的情况下!

原文

改变作者和邮箱

分类:

后端

标签:

后端

作者介绍

进击云原生
V2

公众号:进击云原生