Git troubleshooting

Posted geekhao

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Git troubleshooting相关的知识,希望对你有一定的参考价值。

Git troubleshooting 解决方案

1. 版本撤销及恢复

  • 问题描述:当我们使用了git reset --hard commit_id命令,将工作区的提交穿越到你指定的commit里,这个时候你会发现git log根本没有记录这之后的提交记录,此时如果想回到穿越前的状态,就缺失了相应的提交记录信息
  • 解决办法:Git提供了一个命令git reflog用来记录你的每一次改变目录树的命令,使用好他就可以很方便的恢复你最近的提交记录,然后使用git reset --hard commit_id命令,就能回次提交后的状态了。
    建议: 如果只是想把此提交给找回来,恢复他,那还是不要用reset的方式,可以用git cherry-pick commitid单独取一个commit到当前分支或者用merge来做合并
    更多翻车现场抢救方案,参考: https://mp.weixin.qq.com/s/58W1ljewwvextw05_OKE1w

2. gitlab SSH 配置

  • 问题描述:在使用ssh key作为gitlab鉴权秘钥时,虽然已经将本地的.ssh/id_rsa.pub文件中的内容添加到gitlab账户下,但是依然无法使用git对仓库中的项目进行任何操作,报错内容为:
ssh_dispatch_run_fatal: Connection to 172.65.251.78 port 22: message authentication code incorrect
fatal: Could not read from remote repository.

Please make sure you have the correct access rights and the repository exists.`

并且同样的秘钥配置到github是可以正常使用的

3. 使用tag快速管理版本

  • 问题描述:
  • 解决办法:

4. 分支操作

以上是关于Git troubleshooting的主要内容,如果未能解决你的问题,请参考以下文章

VSCode自定义代码片段15——git命令操作一个完整流程

VSCode自定义代码片段15——git命令操作一个完整流程

如何管理在每个 git 版本中添加私有代码片段?

使用 Git 来管理 Xcode 中的代码片段

markdown Git代码片段

GitGit 分支管理 ( 克隆远程分支 | 克隆 master 分支 git clone | 查看远程分支 git branch -a | 克隆远程分支 git checkout -b )(代码片段