git如何回滚代码
方法一: 使用 git reset 命令
命令可以将当前分支的 HEAD 指针指向指定的提交,从而回退代码到指定版本。 该命令有三种模式:–soft、–mixed 和 --hard。它们的区别在于回退代码的程度不同。 --mixed (默认):将 HEAD 指针和暂存区都回退到指定提交,但不改变工作区的内容。 --soft 仅将 HEAD 指针回退到指定提交,不改变暂存区和工作区的内容。 --hard 将 HEAD 指针、暂存区和工作区都回退到指定提交,会丢失最新的代码修改,慎用。
命令:
# 查看提交历史 git log # 回退到指定提交(使用 --soft 模式) git reset --soft <commit> # 查看状态,确认回退操作是否正确 git status # 提交回退后的代码 git commit -m "回退到 <commit>" # 将修改的代码推送到远程仓库 git push origin <branch>
#如果不行,就用强制推送:
git push -f origin <branch>
方法二:使用 git revert 命令
git revert 命令可以将指定提交的修改反向应用到当前分支上,相当于
撤销指定提交的修改
。
这种方式比使用 git reset 命令更加安全,因为它不会改变提交历史,而是创建一个新的提交来撤销之前的修改。
# 查看提交历史 git log # 撤销指定提交,这样会创建一个新的提交来撤销之前的修改 git revert <commit> # 提交撤销操作 git commit -m "回退到版本 <commit>" # 推送到远程仓库 git push origin <branch>
#如果不行,就用强制推送:
git push -f origin <branch>
方法三:使用 git checkout 命令
git checkout 命令可以将当前分支的 HEAD 指针指向指定的提交,并将工作区的内容替换成指定提交的内容。这种方式
不改变提交历史,但会直接覆盖工作区的内容,慎用
。
# 查看提交历史 git log # 切换到指定提交 git checkout <commit> # 提交回退后的代码 git commit -m "回退到版本 <commit>" # 切回到原来的分支 git checkout <branch> # 推送当前分支到远程仓库 git push origin <branch> #<branch> 表示当前分支的名称,例如 master。这个命令会将本地分支的提交推送到远程仓库,并将远程分支更新为与本地分支一致。
常见的错误及其解决办法如下:
【1】error: failed to push some refs to ‘git@github.com:/.git’ 原因:这个错误通常是由于本地分支和远程分支的提交历史不一致导致的。 解决办法:先执行 git pull 命令将远程分支的代码拉取到本地,然后再执行 git push 命令推送代码。 【2】error: src refspec does not match any 解决:这个错误通常是由于本地分支不存在或者拼写错误导致的。 解决办法:先执行 git branch 命令查看本地分支列表,确认分支名是否正确,如果不存在则需要先创建分支。 【3】error: failed to push some refs to ‘git@github.com:/.git’ 解决:这个错误通常是由于权限不足导致的。 解决办法:确认当前用户是否有权限推送代码到远程仓库,如果没有则需要联系管理员进行授权。
原文链接:https://blog.csdn.net/weixin_53791978/article/details/132160078
分类:
gitlab相关
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 分享4款.NET开源、免费、实用的商城系统
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 记一次.NET内存居高不下排查解决与启示
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了
2023-09-06 英语常用短语