设为首页 收藏本站
查看: 1491|回复: 0

[经验分享] git revert 后悔了 还原修改前的版本 + git 常用命令

[复制链接]

尚未签到

发表于 2018-1-12 23:06:10 | 显示全部楼层 |阅读模式
  昨天手残 然后在GitHub for windows 上点了revert 然后就给重置了 更手残的是又给同步了 .  但是 GitHub 会保留之前的版本 . 只要删掉本次修改就可.
  解决方案:  gitshell ->> git revert HEAD
  还原已经提交的修改
  此次操作之前和之后的commit和history都会保留,并且把这次撤销作为一次最新的提交
  git revert HEAD                  撤销前一次 commit
  git revert HEAD^               撤销前前一次 commit
  git revert commit-id (比如:fa042ce57ebbe5bb9c8db709f719cec2c58ee7ff)撤销指定的版本,撤销也会作为一次提交进行保存。
  git revert是提交一个新的版本,将需要revert的版本的内容再反向修改回去,版本会递增,不影响之前提交的内容。
  另外 附上git 常用命令.
  查看、添加、提交、删除、找回,重置修改文件
  git help <command> # 显示command的help
  git show # 显示某次提交的内容 git show $id
  git co -- <file> # 抛弃工作区修改
  git co . # 抛弃工作区修改
  git add <file> # 将工作文件修改提交到本地暂存区
  git add . # 将所有修改过的工作文件提交暂存区
  git rm <file> # 从版本库中删除文件
  git rm <file> --cached # 从版本库中删除文件,但不删除文件
  git reset <file> # 从暂存区恢复到工作文件
  git reset -- . # 从暂存区恢复到工作文件
  git reset --hard # 恢复最近一次提交过的状态,即放弃上次提交后的所有本次修改
  git ci <file> git ci . git ci -a # 将git add, git rm和git ci等操作都合并在一起做                                    git ci -am "some comments"
  git ci --amend # 修改最后一次提交记录
  git revert <$id> # 恢复某次提交的状态,恢复动作本身也创建次提交对象
  git revert HEAD # 恢复最后一次提交的状态
  查看文件diff
  git diff <file> # 比较当前文件和暂存区文件差异 git diff
  git diff <id1><id1><id2> # 比较两次提交之间的差异
  git diff <branch1>..<branch2> # 在两个分支之间比较
  git diff --staged # 比较暂存区和版本库差异
  git diff --cached # 比较暂存区和版本库差异
  git diff --stat # 仅仅比较统计信息
  查看提交记录
  git log git log <file> # 查看该文件每次提交记录
  git log -p <file> # 查看每次详细修改内容的diff
  git log -p -2 # 查看最近两次详细修改内容的diff
  git log --stat #查看提交统计信息
  tig
  Mac上可以使用tig代替diff和log,brew install tig
  Git 本地分支管理
  查看、切换、创建和删除分支
  git br -r # 查看远程分支
  git br <new_branch> # 创建新的分支
  git br -v # 查看各个分支最后提交信息
  git br --merged # 查看已经被合并到当前分支的分支
  git br --no-merged # 查看尚未被合并到当前分支的分支
  git co <branch> # 切换到某个分支
  git co -b <new_branch> # 创建新的分支,并且切换过去
  git co -b <new_branch> <branch> # 基于branch创建新的new_branch
  git co $id # 把某次历史提交记录checkout出来,但无分支信息,切换到其他分支会自动删除
  git co $id -b <new_branch> # 把某次历史提交记录checkout出来,创建成一个分支
  git br -d <branch> # 删除某个分支
  git br -D <branch> # 强制删除某个分支 (未被合并的分支被删除的时候需要强制)
  分支合并和rebase
  git merge <branch> # 将branch分支合并到当前分支
  git merge origin/master --no-ff # 不要Fast-Foward合并,这样可以生成merge提交
  git rebase master <branch> # 将master rebase到branch,相当于: git co <branch> && git rebase master && git co master && git merge <branch>
  Git补丁管理(方便在多台机器上开发同步时用)
  git diff > ../sync.patch # 生成补丁
  git apply ../sync.patch # 打补丁
  git apply --check ../sync.patch #测试补丁能否成功
  Git暂存管理
  git stash # 暂存
  git stash list # 列所有stash
  git stash apply # 恢复暂存的内容
  git stash drop # 删除暂存区
  Git远程分支管理
  git pull # 抓取远程仓库所有分支更新并合并到本地
  git pull --no-ff # 抓取远程仓库所有分支更新并合并到本地,不要快进合并
  git fetch origin # 抓取远程仓库更新
  git merge origin/master # 将远程主分支合并到本地当前分支
  git co --track origin/branch # 跟踪某个远程分支创建相应的本地分支
  git co -b <local_branch> origin/<remote_branch> # 基于远程分支创建本地分支,功能同上
  git push # push所有分支
  git push origin master # 将本地主分支推到远程主分支
  git push -u origin master # 将本地主分支推到远程(如无远程主分支则创建,用于初始化远程仓库)
  git push origin <local_branch> # 创建远程分支, origin是远程仓库名
  git push origin <local_branch>:<remote_branch> # 创建远程分支
  git push origin :<remote_branch> #先删除本地分支(git br -d <branch>),然后再push删除远程分支
  Git远程仓库管理
  GitHub
  git remote -v # 查看远程服务器地址和仓库名称
  git remote show origin # 查看远程服务器仓库状态
  git remote add origin git@ github:robbin/robbin_site.git # 添加远程仓库地址
  git remote set-url origin git@ github.com:robbin/robbin_site.git # 设置远程仓库地址(用于修改远程仓库地址) git remote rm <repository> # 删除远程仓库
  创建远程仓库
  git clone --bare robbin_site robbin_site.git # 用带版本的项目创建纯版本仓库
  scp -r my_project.git git@ git.csdn.net:~ # 将纯仓库上传到服务器上
  mkdir robbin_site.git && cd robbin_site.git && git --bare init # 在服务器创建纯仓库
  git remote add origin git@ github.com:robbin/robbin_site.git # 设置远程仓库地址
  git push -u origin master # 客户端首次提交
  git push -u origin develop # 首次将本地develop分支提交到远程develop分支,并且track
  git remote set-head origin master # 设置远程仓库的HEAD指向master分支
  也可以命令设置跟踪远程库和本地库
  git branch --set-upstream master origin/master
  git branch --set-upstream develop origin/develop
  转自:http://www.cnblogs.com/cspku/articles/Git_cmds.html

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-434452-1-1.html 上篇帖子: git仓库迁移的两种解决方案 下篇帖子: Git冲突和解决冲突
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表