git 详解-提升篇

git 冷门使用

承接上一篇 《git 进阶篇》,简单讲解 git 冷门使用方法。

码农常规使用工具 git 偶尔也有非常规操作。例如:提交代码时同事已经更新,但又不想回退本地补丁;或者已经提交补丁需要变更提交日志信息。

作者:炭烤毛蛋 ,点击博主了解更多。


提示:更多分享内容持续更新中。

文章目录

  • [git 冷门使用](#git 冷门使用)
  • [1. 本地代码发生修改,同步时报错](#1. 本地代码发生修改,同步时报错)
  • [2. 历史提交记录中部分信息填写错误需要修改](#2. 历史提交记录中部分信息填写错误需要修改)
  • [3. 提交记录中的日志信息修改](#3. 提交记录中的日志信息修改)
  • Tips
  • 结语

1. 本地代码发生修改,同步时报错

bash 复制代码
git push origin master
! [rejected] master -> master (fetch first)

修改方式

bash 复制代码
git pull --rebase origin master

2. 历史提交记录中部分信息填写错误需要修改

  • 逐个修改提交记录
bash 复制代码
git rebase -i HEAD~n

将n替换为你想要修改的提交数量

依次对每个要修改的提交执行,以为替换开发者名字和邮箱为例。

bash 复制代码
git commit --amend --author="New Name <new_email@example.com>"

将New Name替换为新的姓名,new_email@example.com替换为新的邮箱地址。

每个提交修改完成后,使用以下命令继续rebase。

bash 复制代码
git rebase --continue

当rebase操作完成后 commit_id 发生改变,需要强制推送修改后的提交历史到远程仓库。

  • 批量替换需要修改信息
    如果你要批量修改已经提交的开发者名字和邮箱信息,可以使用git filter-repo工具。
    运行以下命令来安装git-filter-repo包:
bash 复制代码
pip install --user git-filter-repo
  • 编写 mailmap替换文件
    这里的mailmap是一个文本文件,用于指定旧的开发者名字和邮箱地址以及对应的新的开发者名字和邮箱地址。你需要创建一个mailmap文件,并按照以下格式填写内容:
bash 复制代码
new_name <new_email> old_name <old_email> 

每一行表示一个映射关系,将旧的名字和邮箱地址映射为新的名字和邮箱地址。

  • 启用批量修改
    遍历所有提交记录,根据mailmap文件中的映射关系,对所有的提交记录进行批量修改。

    bash 复制代码
    git filter-repo --mailmap mailmap

监测执行结果

bash 复制代码
git filter-repo

修改完成后,同样需要强制推送修改后的提交历史到远程仓库。

也可以按照指定提交记录区间进行更替。

bash 复制代码
git filter-repo --mailmap mailmap --refs COMMIT_ID...

COMMIT_ID 提交之后记录进行修改。
请注意,这种方法会改变提交历史,可能会对其他开发者的工作造成影响。因此,在执行这些操作之前,请确保与团队中的其他开发者进行沟通,并确认他们都能够适应提交历史的更改。此外,强烈建议在修改提交历史之前,先备份你的仓库以防万一。

3. 提交记录中的日志信息修改

要修改 Git 提交记录中的日志信息,可以使用 git commit --amend 命令。

  • 查找提交补丁哈希值
bash 复制代码
git log

查看最近的提交记录,找到你想修改的提交的哈希值(commit hash)。

  • 更改提交信息
bash 复制代码
git commit --amend -m "commit info"

附加参数 -m "新的提交信息" 来修改提交的日志信息。将 "新的提交信息" 替换为你想要的新信息。
请注意:Git 会使用新的日志信息创建一个新的提交对象,并覆盖原始提交。这将改变提交的哈希值,因此如果你已经将这个提交推送到远程仓库,你可能需要在推送之前使用 git push --force 命令来强制更新远程分支。

Tips

内容持续更新中。

结语

不枉博主详细讲解,欢迎订阅博主--炭烤毛蛋

相关推荐
zh路西法2 小时前
【tmux入门】终端分屏、SSH远程守护与一键启动脚本
linux·运维·ssh·bash
徐子元竟然被占了!!3 小时前
Git学习
git·学习·elasticsearch
承渊政道4 小时前
【MySQL数据库学习】(MySQL内置函数)
数据库·学习·mysql·ubuntu·bash·数据库开发·数据库系统
l1o3v1e4ding4 小时前
windows安装Claude Code,并接入Deepseek-v4模型 ,提供离线安装包
git·npm·node.js·claude code·cc-switchcc
allway215 小时前
How to Echo Multiline to a File in Bash [3 Methods]
开发语言·chrome·bash
Dontla15 小时前
git bash打开Claude code报错:Claude Code on Windows requires git-bash.(别把git装其他位置,严格按照默认安装)找不到claude code
windows·git·bash
weixin_4624462315 小时前
手把手教你用 Bash 脚本自动更新 /etc/hosts —— 自动绑定网卡 IP 与节点名
开发语言·tcp/ip·bash
一个梦醒了15 小时前
安装git bash选项推荐
开发语言·git·bash
呆萌的代Ma18 小时前
Git不强行推送,撤销最近几次的提交
git
Drone_xjw21 小时前
Kylin 系统下使用 Shell 脚本定期清理历史文件
bash·kylin