Git使用积累

因新工作需要使用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

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章