根据我最近使用git的一些经历,git是基于分支的版本控制工具,分支有远程分支和本地分支。
一、开发流程
- 从远程服务器的master,clone一份项目文件到本地,然后本地master的基础上branch一个新的本地分支xname(或者branch一个已有的远程分支),然后checkout切换到这个本地分支上,开始开发;
- 开发过程中可以不断的commit到本地,可以分阶段做版本标记(俗称打tag);
- 开发完成之后,把本地分支xname ,push origin到远程分支xname上;(也可以push origin v0.1.2 把某个本地tag推送到服务器上)
- 远程分支xname和master合并。
二、常用命令
安装完成git之后,在文件夹右键菜单可以找到git bash命令行工具。也可以配置下环境变量使用windows的cmd命令行工具。
windows的cmd工具,配置一下之后,我觉得还蛮好用的。
(找到git的安装目录,然后系统环境变量path添加一个“D:\Program Files\Git\cmd”,命令行就可以运行git命令了)
进入目录
cd e:
cd cs
返回根目录
cd ../
列出本目录下文件夹
ls
当前下创建文件夹
mkdir
删除文件夹
rd xx
删除文件
del xx
————————以下为git命令——————————
查看本机配置
git config --list
git基本配置
http://magicalboy.com/git-configuration/
配置用户信息
$ git config --global user.name "xxx"
$ git config --global user.email xx@xx.com
创建本机key
ssh-keygen -t rsa -C “xx@xx.com” (默认会在C/user/..下面创建一个.ssh的文件夹,内有一个公钥文件和一个私钥文件,公钥要自己复制放到服务器上)
下载远程master代码
git clone git@xxx.git
拉取远端某分支代码
git pull origin xname
列出所有本地分支
git branch
列出远端分支
git branch -r
列出本地+远端分支
git branch -a
创建分支
git branch xname
切换分支
git checkout xname
创建并切换分支
git checkout -b xname
进入分支查看分支的改动
git status
GUI查看当前分支的修改
gitk
提交所有修改到本地
git commit -a -m "注释内容,必须要有"
(如果有新增加的文件,需要先add)
提交修改到远程分支
$ git push origin xname:xname
删除已经合并过的本地分支
git branch -d xname
强制删除某个本地分支
git branch -D xname
删除远程分支
git push origin :xname
冒号前面的空格不能少,原理是把一个空分支push到server上,相当于删除该分支。
等同于
$ git push origin --delete xname
列出所有tag
git tag
打tag
git tag -a tagName -m "注释"
将tag提交到服务器
git push origin v0.1.2(对应到小乌龟上就是push的时候,把Include tags勾上)
将本地所有tag提交到服务器
git push origin --tags
三、git可视化工具
git hash的乱码搞得我非常的恶心,装了一个小乌龟git,TortoiseGit,用了两天之后发现,贼好用,强烈推荐大家使用。
举例:删除某个远程分支。
还是按照原来那句删除远程分支的命令行的思路
git没有删除远程分支的命令,可以用push一个空分支来实现删除的目的
那 对应到小乌龟上 就是这样啦
---------------------------------------------------------------------------
四、git小乌龟和git bash如何同时使用的问题
因为在交叉使用中出现了问题,排查之后发现git小乌龟和git bash命令行工具,他们使用的密钥不是一个类型的。详细可以参考这个:http://zengrong.net/post/1722.htm
也就是说,如果想同时使用这两个工具的话,需要分别为他们创建一对密钥。
git bash:用上面列的命令可以生成公钥和私钥;
TortoiseGit:需要使用它自己的puttygen工具生成一对密钥;详细可以参考这个:http://jingyan.baidu.com/article/63f236280f7e750209ab3d60.html
如果参照教程还是有问题,需要在git bash中git config --list 查看一下"remote.origin.puttykeyfile"的值是否和刚才用puttygen生成的一致。
五、git小乌龟在win8系统下git clone load puttykey 不可用
本来自认为自己已经完全掌握小乌龟的使用了,没想到今天的实习生来了之后,又出现一个新问题,就是他的win8系统,clone代码的时候, clone load puttykey 这个选项不可用。百度了一下之后,发现原来是git小乌龟没有找到ssh client,需要在git setting-network里指定一下ssh client的程序位置。
如下:Settings > Network > SSH:SSH Client = C:\Program Files (x86)\TortoiseGit\bin\TortoiseGitPLink.exe
此问题参考:http://blog.snsgou.com/post-58.html