开发过程中,git常用命令

场景 1:仅本地提交未推送(未执行 git push

如果提交仅在本地,未推送到远程仓库:

  1. 撤回最后一次提交并保留修改

    bash 复制代码
    git reset --soft HEAD~1
    • HEAD~1 表示撤回最近一次提交,保留修改到工作区。
    • 重新修改代码后,执行 git addgit commit
  2. 撤回提交并丢弃修改(慎用):

    bash 复制代码
    git reset --hard HEAD~1

场景 2:已推送提交到远程仓库

如果提交已推送到远程分支(如 origin/main),需分情况处理:

方法 1:新增提交覆盖旧提交(推荐,安全)

使用 git revert 创建新提交来撤销之前的提交:

  1. 撤销指定提交

    bash 复制代码
    git revert <commit-hash>  # 替换为要撤回的提交哈希值
    • 这会生成一个新的提交,内容与原提交相反。

    • 解决可能的冲突后,推送新提交:

      bash 复制代码
      git push origin 分支名
    • 优点 :不修改历史,适合公共分支(如 main)。

方法 2:强制修改历史(谨慎!)

如果确定需要彻底删除旧提交(仅限个人分支或团队允许时):

  1. 本地回退到指定提交

    bash 复制代码
    git reset --hard <commit-hash>  # 回退到要保留的提交
  2. 强制推送覆盖远程分支

    bash 复制代码
    git push -f origin 分支名
    • 风险:会覆盖远程历史,导致其他协作者代码冲突。
    • 操作前建议
      • 通知团队其他成员。
      • 备份分支:git branch backup-branch

场景 3:修改最后一次提交(未推送或允许强制推送)

如果只是修改最后一次提交的内容或提交信息:

  1. 修改最后一次提交

    bash 复制代码
    git commit --amend  # 修改提交内容或信息
  2. 强制推送 (如果已推送过):

    bash 复制代码
    git push -f origin 分支名

操作流程示例

假设你误提交了文件并已推送到远程分支 feature/login

bash 复制代码
# 1. 本地回退到上一个提交(保留修改)
git reset --soft HEAD~1

# 2. 修改代码,重新提交
git add .
git commit -m "修复:正确的提交信息"

# 3. 强制推送覆盖远程分支
git push -f origin feature/login

注意事项

  1. 强制推送 (-f) 的风险

    • 会覆盖远程分支的历史记录,可能导致团队协作混乱。
    • 仅在个人分支或团队允许时使用。
  2. 公共分支(如 main)的处理

    • 优先使用 git revert 代替 git reset,避免修改历史。
  3. 备份当前状态

    • 操作前创建备份分支:git branch backup-branch

总结

场景 操作命令
撤回本地未推送的提交 git reset --soft HEAD~1 → 修改后重新提交
安全撤销远程提交 git revert <commit-hash> → 解决冲突 → git push
强制修改远程提交历史 git reset --hard <commit-hash>git push -f
修改最后一次提交 git commit --amendgit push -f(若已推送)

操作前请确保理解风险,并在团队协作中提前沟通!

相关推荐
司徒小夜5 小时前
处理git没做修改,但是文件显示变更的情况
git
m0_749317526 小时前
vscode里如何用git
ide·git·vscode
Hello.Reader7 小时前
Git 安装全攻略Linux、macOS、Windows 与源码编译
linux·git·macos
王景程8 小时前
SELinux是什么以及如何编写SELinux策略
git·github
Chuncheng's blog8 小时前
如何基于Mihomo Party http端口配置git与bash命令行代理
git·http·bash
Tom Boom8 小时前
Git常用命令完全指南:从入门到精通
大数据·git·elasticsearch·docker·自动化测试框架
不爱学英文的码字机器10 小时前
[Git] 文件删除
git
DZSpace11 小时前
git stash命令用法
git
Vowwwwwww11 小时前
GIT历史存在大文件的解决办法
前端·git·后端
@BreCaspian12 小时前
Git 推送失败解决教程——error: failed to push some refs to
大数据·git·elasticsearch