git修改push过的commit信息及用户名和邮箱

先声明:该操作会改变历史记录,所以需要谨慎执行,尤其是在团队协作的环境下

首先,打开终端或命令行,并且切换到目标Git仓库目录下

  1. 定位要修改的commit:找到需要修改的记录的commit ID。

  2. 使用交互式rebase :如果你要修改的commit不是最近的一次,可以使用以下命令,其中commit_id是你要修改的commit的ID的前一个commit的ID

    复制代码
    git rebase -i commit_id

    如果需要修改的是最近的commit,则可以使用:

    复制代码
    git rebase -i HEAD~n

    其中n是你需要回退的commit数量

  3. 选择要修改的commit :在打开的编辑器中,将需要修改的某commit前面的pick改为edit,然后保存并退出编辑器

  4. 修改用户名和邮箱:现在你可以使用以下命令修改用户名和邮箱:

    复制代码
    git commit --amend --author="新用户名 <新邮箱地址>"
  5. 执行上述命令后会进入一个编辑文档,若需修改commit信息就敲I键进入编辑模式,在最上方看到上次的commit内容修改成新的(下方一堆"#"内容不用管),然后分别ESC:wq键保存退出,若不修改直接编辑保存退出即可

  6. 完成rebase:使用以下命令完成rebase过程:

    复制代码
    git rebase --continue

    如果有更多的commit需要修改,重复步骤4,5和6

  7. 强制推送到远程仓库:修改完成之后,你需要强制推送到远程仓库。这个操作会覆盖远程仓库的历史,所以需确保这是你想要的结果

    复制代码
    git push --force

请记住,在强制推送之前,你应该提醒你的团队成员,因为这将重写远程仓库的历史。所有的团队成员都将需要根据新的历史进行操作,可能包括使用git pull --rebase来同步本地仓库

相关推荐
程序猿chen17 小时前
《JVM考古现场(十六):太初奇点——从普朗克常量到宇宙弦的编译风暴》
jvm·git·后端·程序人生·金融·java-ee·量子计算
死磕java的孤行者19 小时前
Git 分布式版本控制工具
分布式·git·elasticsearch
java搬砖工-苤-初心不变1 天前
解决 Git 通过 SSH 克隆仓库时自动转换为 HTTPS 的问题
git·https·ssh
Naomi5212 天前
自定义汇编语言(Custom Assembly Language) 和 Unix & Git
服务器·开发语言·git·unix
@BreCaspian2 天前
Git 从入门到精通(开源协作特别版)
git·开源
谢尔登2 天前
【已解决】Webstorm 每次使用 git pull/push 都要输入令牌/密码登录
ide·git·webstorm
紫阡星影2 天前
TortoiseGit多账号切换配置
git·gitee·tortoisegit
予早2 天前
git kex_exchange_identification 相关问题
git
鸠摩智首席音效师2 天前
如何完整迁移 Git 仓库 ?
git
诚诚程程成2 天前
git配置github
git·github