因新工作需要使用GIT,之前主要在SVN上操作,GIT只是临时性,很多问题只是当时解决了,并没有记录。因此本博客正是出于此目的而写。
0 基本克隆一个仓库的步骤
首先,基于ssh-key本地生成公钥,如ssh-keygen -t rsa -C "[email protected]";
然后,在托管代码网站上添加个人公钥;
最后,git clone your_code_ssh_link 即可;
1 clone 时 Host key verification failed
如下图所示
此时,是因为在之前询问(yes/no)时可能直接回车,应该手动输入yes;
2 git仓库迁移
之前一直在维护一个repo,目前需要将之前的工作转移至新的repo上,还需要保留LOG。参考http://www.07net01.com/2015/09/933800.html
1). 从原地址克隆一份裸版本库,比如原本托管于 GitHub。
git clone --bare git://github.com/username/project.git
--bare 创建的克隆版本库都不包含工作区,直接就是版本库的内容,这样的版本库称为裸版本库。
2). 然后到新的 Git 服务器上创建一个新项目,比如
GitCafe。
3). 以镜像推送的方式上传代码到 GitCafe 服务器上。
cd project.git git push --mirror [email protected]/username/newproject.git
-- mirror 克隆出来的裸版本对上游版本库进行了注册,这样可以在裸版本库中使用git fetch命令和上游版本库进行持续同步。
4). 删除本地代码
cd .. rm -rf project.git
5). 到新服务器 GitCafe 上找到 Clone 地址,直接 Clone 到本地就可以了。
git clone [email protected]/username/newproject.git
这种方式可以保留原版本库中的所有内容
3 Git中的AutoCRLF选项
背景:近期由于在windows下clone后的repo在vmware里的ubuntu下用。但是CMAKE-GUI始终报错。后来查原因,定位在于ubuntu下的cmake-gui读properties文件无法正确解析,因为其中的\r\n的问题。解决:一开始在安装时,就需要注意CR-LF的选项。如果已经安装了,则可以设置AutoCRLF选项。
#提交时转换为LF,检出时转换为CRLF
git config --global core.autocrlf true
#提交时转换为LF,检出时不转换
git config --global core.autocrlf input
#提交检出均不转换
git config --global core.autocrlf false
建议会用input选项。
详细可以参考http://www.cnblogs.com/flying_bat/p/3324769.html
4 Git-Stash
背景:本地在master分支更改,并且没有commit,所以在pull master时出现了conflict。解决:使用stash;首先,将本地修改存储 git stash;然后 pull内容 git pull;最后 还原git stash pop;
事实上更合理的做法应该是在本地new branch
5 git reset --hard 补救
背景:由于需要查看之前的提交,所以使用了git reset --hard 但是最后想回来发现git log 已经不能显示最近的git commit hash。
解决:使用git reflog可以显示已经被删除的commit的hash值 ,所以重新 找到需要回到的再使用 git reset --hard即可。如果你因为reset等操作丢失一个提交的时候,你总是可以把它找回来。除非你的操作已经被git当做垃圾处理掉了,一般是30天以后。
详细可以参考:http://www.cnblogs.com/mliudong/archive/2013/04/08/3007303.html