几个月以前想在GitHub托管一个项目,听说非常好用,便一睹为快。殊不知在上面点了半天,也不知道个所以然,搜索了半天也没有一个足够清晰的教程。如果现在的你和我当时一样confuse。希望当你阅读完这篇文章的时候,至少在使用上没有任何困难,并且也被Git的魅力吸引,渐渐喜欢上它,那我的目的就达到了。
**Git Tutorials **
想要学会如何使用GitHub,首先要我们要明白Git的原理和一些简单的操作使用,接下来我们就开始Git之旅吧:
Git-开源的分布式版本控制系统,它的功能通俗点说就是可以用来方便的管理我们不同项目的各个版本,可以在不同的机器上对一个项目进行维护,修改。之所以称其为分布式,是因为我们每个人都可以Download一个仓库到自己的本地上, 对其进行修改,然后提交到远程仓库去。
- MsysGit 的安装(本篇以window环境为例)
根据你的操作系统是32位,还是64位的下载一个对应版本MsysGit,因为MsysGit是安装最简单的一个,所以别的就不推荐了,免得过于烦人。
- 初始化工作
假设你已经安装好了MsysGit,我们开始第一步吧:首先打开Git Bash,我们看到一个类似Window控制台的界面。我们接下来要做的感觉有点像是一个迷路的人进了警察局填单的过程:
-
首先得填填你的名字啊,邮箱吧
$ git config --global user.name "JIANLAM"
$ git config --global user.email "mrkinlam7@Gmail.com"大家英文好,当然知道这段代码的意思就是:Git 配置 --全局变量:用户的名字/邮箱,所以把你自己的名字邮箱填上去吧(别填成我的哦),那我怎么知道我填进去有没有被记录在里面呢,那就用这行命令,就能得到一个系统配置的清单,包括后面的缩写配置都会被记录在这里。
$ git config --list
接下来警察得问你家住哪里吧
我们用命令pwd看看自己所在的位置,原来我们在C盘的用户文件,志坚下面。为了方便操作,我们到桌面去,cd 到桌面Desktop,然后我们在桌面创建一个folder(文件夹),并cd到里面去,这和window下操作很像吧,如果你要倒退就可以用命令:
$ cd ..
- 我们的第一个仓库
为什么这个folder取名为lovepoems呢,有句话说的好:生活不只有苟且,还有诗和远方。
想学Git的朋友想必心怀远方,那怎么能少了诗呢。我们接下来就来创建一个仓库(Repository又称为版本库),这个仓库用来堆我们的情诗。输入命令:$ git init
下面的提示我们说:你初始化了一个空的Git仓库在lovepoens的.git文件下,这个.git文件是一个隐藏的文件,里面有管理我们仓库的重要文件,所以没什么事不要碰它,到此我们的仓库就建好了,是不是很简单呢。
- 添加与提交
我们来写第一行情书,来到lovepoems仓库下。创建一个txt文本,名字叫MyDarling,内容用NotePad编辑的(推荐大家使用),如下:
关于这段肉麻的一行情书,我们看看仓库本人怎么说:
由于我们把lovepoems创建为一个仓库,里面一旦有文件被修改,创建,删除等,仓库就会立刻察觉到。我们看到右边多了一个蓝色的英文 master 表示我们现在在主分支,分支是什么鬼,后面再说吧。我们用命令
$ git status
查看目前仓库的状态,它说在分支master上,有一个未被追踪的文件,然后它很热心的提出,你可以使用 $ git add <file>
的方式把它添加到准备要提交的队列中去。
好吧,你是仓库你说了算:
我们把MyDarling文件添加进去,然后用命令
$ git status
看看它说啥,它说有一个新文件MyDarling准备提交。
接下来我们把文件给提交了:
我们用命令$ git commit -m " sth want to say"
去提交我们的MyDarling文件,其中-m的意思就是Message, 就有点像是一个标签,关于你这次提交想说的一些提示性的讯息。我们同样用熟悉的命令 $ git status
来看看仓库的状态,它说没东西可提交了,工作区的文件很干净。其实翻译为干净还是太奇怪了,应该说工作区的文件没什么异样。
接下来我们来看看Git 的workflow(工作流程):
我们看到一共分为三个部分,第一个是 Working copy 工作副本->就是你本地的电脑;第二个是** Staging area ** 暂存区域(或者叫Index)->就是准备被提交的区域;第三个图中画的不全,是一个被HEAD指针锁定的Master分支,我们上面说了刚刚创建的仓库Repository就包涵了这个Master分支。既然图画的不全,我们自己来画一个:
图中我们可以清晰的看到整个流程,我们假设在工作区有个readMe.txt文件,接下来我们就把它添加到暂存区,接着再提交到Master这个主分支。而一旦我们添加到Repository仓库之后,仓库就会tracked(追踪)这个文件,以后这个文件要是有什么变化,我们就可以马上知道。
现在我们来写多两首诗,分别叫prettygirl 和 Goodbye:
要是有女程序媛看完以后,肯定说典型的渣男!!~额,反正我不是。好了,诗写完了自我感觉不错,把它加到仓库吧。满满的一屏命令行,先 $ clear
清一下屏吧:
老规矩,先看看仓库什么状况,用命令: $ git status
,果然有我们刚刚写的两首一行情诗没被添加进去,接着我们可以用$ git add .
把所有文件都添加到 Staging area 暂存区中去,再看看状态,它说有两个文件已经准备提交了。
那就提交呗,多大点事:
我们把它提交,并且难过的留下了一个标记,"my heart is broken"。其实大家应该发现了,我们添加的时候可以添加很多个,提交的时候就一次性把所有东西都提交了。而且这两步是必不可少的,大家要留心了。
到此为止,我们看看仓库都有些什么东西: $ git log
我们看到自己的讯息,时间,还有两次提交的版本名字,还有一个commit id。
---写于15.5.2016
- Git的时光倒流
上面的日志确实还行,够详细,但是太多了,我们用
$ git log --pretty=oneline
来展示漂亮的一行。
好了,现在只有commit id号和版本留下的标志。昨晚一宿没睡想了想,她是一个好女孩啊,被她看见了,太伤她心了,渣男一只。还是回到上一个版本的节奏吧。那要怎么做呢:
我们其实一直在HEAD指向的Master分支上,前面大家都知道了,即HEAD指向的当前版本->my heart is broken。HEAD表示上一个版本,HEAD^表示上上一个版本,如果你有commit id 号,直接表示也可以,因为它是唯一的标识。当你用命令$ git reset --hard HEAD^
,HEAD指针就会指向下一个版本,我们来具体试试:
我们首先看看自己的位置,在lovepoems文件夹下。用命令$ ls
看看该folder下都有啥:好,确实是我们写的3首一行情诗。接着我们就要回退版本啦,玩过英雄联盟的人应该觉得,有点像艾克大招不是么。敲下命令$ git reset --hard HEAD^
,然后神奇的发现我们仓库下就只有MyDarling这个文件了!它也提示我们,恭喜你回到过去,你现在所处的位置是上一个版本,my first love pomes。
有人说,如果哪天女朋友把我lol符文全部融了,我要拿出那个伤心欲绝的版本刺激她该怎么做呢:
我们用命令
$ git reflog
就可以查看所有做过的操作,我们看到最下面的两个就是我们一开提交的两个版本,前面有个commit id号,这次我们用它来转换版本:
这样我们就又返回到最新的版本了,并且知道这个方法后就可以任意穿梭时空了,还有就是commit id可以不写全,写几个数字就可以了。上面的
$git reset --hard xxx
中reset我知道重设的意思,那--hard是什么呢,我也不知道,看看官方文档怎么说:在 Git参考文档中找到reset里面--hard的介绍:
它说重新设置暂存区和工作区,任何对追踪文件修改的提交都会被丢弃。哦,原来是这样。大家想深入学习Git的这也不失为一种学习方式,本文只是为如何使用Github做铺垫,想成为Git大师还得靠大家自己努力呢。
- 撤销 ( Unstage )
每个成功程序猿的背后都有一个厉害的程序媛,你女朋友也会用Git啊,某天她看到你写的情诗被深深的打动了,决定也写一行情诗给你:
她微信截了图给你,你收到以后整个人都不好了,首先你是处女座,其次这诗太美了,无力吐槽。你坐在地铁上,琢磨着该怎么撤销它:
假如她只是在工作区修改了,那好办啊,手动删了那句或者输入命令$ git checkout -- MyDarling.txt
不就撤销了吗。那如果添加到暂存区了,或者提交了怎么办,可以输入$ git reset HEAD MyDarling.txt
先返回到上一个区域,然后再用$ git checkout -- MyDarling.txt
命令,修改的内容也就顺利撤销了。
其中
$cat xxx.txt
是查看某文件的内容。
- 文件管理
灾难终于告一段落了,可以专心写诗了。某天灵感来了,觉得这个MyDarling的名字好像跟诗没什么关系,于是把它改成了onlyYou。我们看看仓库怎么说:
大概意思是说,你想改名字啊,可以啊,先把MyDarling.txt 通过
$ git rm <file>
的形式删除,然后在把onlyYou.txt添加进来。好呗,试试看:
它提示我们已经重命名了,果然成功了!
- 移动
每次都要这样弄,不是很容易作死自己吗,这里介绍一个更简单的方法:
我们使用$ git mv xx.txt xxx.txt
的命令,xx.txt是更改名字前的文件,xxx.txt是更改名字后的文件,我们看到果然也成功了。如果你要把这个修改后的文件移动某个目录下只要在前面加个文件夹名就好了,$ git mv xx.txt file/xxx.txt
- 文件的删除
某天你喜欢的女生跑去跟别的男生开黑了,从那天起,你的天空仿佛失去了颜色,不再相信爱情了,想把写过的诗给删了:
删了,什么都没了:
某天你发现原来那个是她弟,希望又来了,想把诗找回来。所幸我们早已同步给了仓库,就相当于我们本地一份,仓库一份。从它那里拿回来就好了:
果然回来了,当然如果你要狠心点把仓库的文件都删了,就可以用$ git rm xx.txt
这个时候你本地Working copy的文件也会被删了,最后提交一下就可以了。
- 分支
之前我们遗留下来一个问题,什么叫分支。不知道大家有没有看过《心灵想要大声呼喊》里面要表演一个音乐舞台剧,敲定以后,大家就开始分工合作了,有人要弄服装设计,有人要弄舞台灯光,有人要设计舞蹈,有人要学唱歌,这就是分支。等到家都弄得差不多了,在把大家的汇总,那这个舞台剧就形成了。
假如现在出版社要我写一些更感性的诗,那我可以这样做:
命令
$ git branch xx
可以创建一个分支,再用$ git checkout xx
进入这个分支。如果嫌麻烦,你也可以用这句命令,一个顶两个:git checkout -b xx
创建并进入该分支
在添加一句诗,最后提交就完事了,我们看到果然修改成我要的样子了。
我们现在回到主分支master上:
我们神奇的发现onlyYou.txt文件里面的内容并没有发生任何改变。这就认证了我们的设想,只要没有汇总,主分支上是不会受到其他分支影响的。主编看了下我的诗觉得写得不错,于是决定采用这首诗:
用命令
$ git merge xx
合并分支,我们看到onlyYou.txt文件,果然多了最新写的诗,最后用命令$ git branch -d xx
删除分支即可。
帮大家总结了一下,如图:
-
缩写
$ git config --global alias.st status $ git config --global alias.co checkout $ git config --global alias.ci commit $ git config --global alias.br branch
我们一开始配置全局变量,也是这样的格式,这里配置的是缩写,因为繁琐的输入,你可能会厌倦了commit这样长的输入,所以我们可以通过上面的设置把它简化成ci, 这样以后你要提交的时候,就可以写成这种形式:
& git ci -m"xxxx"
还有一个命令要告诉大家的就是,可以查看工作区和暂存区文件的不同,做了哪些修改:
$ git diff <file>
远程仓库
好了,到此Git就介绍完了,大家对它是不是有更多的理解了呢。下一篇,我们就要来讲讲如何使用GitHub了。如果你觉得对你有所帮助,那就给我一点点鼓励,谢谢!~祝大家学习,工作愉快。
已经跟新了,请参考:
GitHub正确打开方式-协同项目