Git —— 目前世界上最先进的分布式版本控制系统,高端大气上档次!
三、远程仓库
Git是分布式版本控制系统,同一个Git仓库,可以分布到不同的机器上。怎么分布呢?最早,肯定只有一台机器有一个原始版本库,此后,别的机器可以“克隆”这个原始版本库,而且每台机器的版本库其实都是一样的,并没有主次之分。
实际情况往往是这样,找一台电脑充当服务器的角色,每天24小时开机,其他每个人都从这个“服务器”仓库克隆一份到自己的电脑上,并且各自把各自的提交推送到服务器仓库里,也从服务器仓库中拉取别人的提交。
Git的服务器可以自己搭建,不过现阶段,为了学Git先搭个服务器绝对是小题大作。好在这个世界上有个叫GitHub的神奇的网站,从名字就可以看出,这个网站就是提供Git仓库托管服务的,所以,只要注册一个GitHub账号,就可以免费获得Git远程仓库。
接下来自行注册GitHub账号。由于你的本地Git仓库和GitHub仓库之间的传输是通过SSH加密的,所以你需要配置SSH keys,请参考上传项目到GitHub详细教程里的第三部分
为什么GitHub需要SSH Key呢?因为GitHub需要识别出你推送的提交确实是你推送的,而不是别人冒充的,而Git支持SSH协议,所以,GitHub只要知道了你的公钥,就可以确认只有你自己才能推送。当然,GitHub允许你添加多个Key。假定你有若干电脑,你一会儿在公司提交,一会儿在家里提交,只要把每台电脑的Key都添加到GitHub,就可以在每台电脑上往GitHub推送了。
最后友情提示,在GitHub上免费托管的Git仓库,任何人都可以看到喔(但只有你自己才能改)。所以,不要把敏感信息放进去。如果你不想让别人看到Git库,有两个办法,一个是交点保护费,让GitHub把公开的仓库变成私有的,这样别人就看不见了(不可读更不可写)。另一个办法是自己动手,搭一个Git服务器,因为是你自己的Git服务器,所以别人也是看不见的。
1、添加远程仓库
现在,你已经在本地创建了一个Git仓库了(即GitTest
),又想在GitHub创建一个Git仓库,并且让这两个仓库进行远程同步,这样,GitHub上的仓库既可以作为备份,又可以让其他人通过该仓库来协作
首先,登录GitHub创建一个新的仓库,创建时只填一个仓库名GitTest
,其他不用管,直接点Create repository
按钮
$ git remote add origin git@github.com:YoungerLi/GitTest.git
添加后,远程库的名字就是origin
,这是Git默认的叫法,也可以改成别的,但是origin
这个名字一看就知道是远程库。下一步,就可以把本地库的所有内容推送到远程库上
$ git push -u origin master
由于远程库是空的,我们第一次推送master
分支时,加上了-u
参数,Git不但会把本地的master
分支内容推送的远程新的master
分支,还会把本地的master
分支和远程的master
分支关联起来,在以后的推送或者拉取时就可以简化命令。
2、查看远程仓库
如果想查看你已经配置的远程仓库服务器,可以运行 $ git remote
命令,它会列出每一个远程服务器的简写,刚才我们已经关联了一个远程仓库了,名字是origin
,所以现在执行$ git remote
$ git remote
origin
koke
可以看到输出一个origin
,这说明现在只有一个名字为origin
的远程仓库,你还可以添加多个。
如果你想看到更多信息,可以使用-v
选项,这样就会每个输出仓库对应的URL
$ git remote -v
origin git@github.com:YoungerLi/GitTest.git (fetch)
origin git@github.com:YoungerLi/GitTest.git (push)
koke git://github.com/koke/GitTest.git (fetch)
koke git://github.com/koke/GitTest.git (push)
3、从远程仓库拉取数据
$ git fetch origin
这个命令会访问远程仓库,从中拉取所有你还没有的数据。 执行完成后,你将会拥有那个远程仓库中所有分支的引用,可以随时合并或查看。
必须注意 $ git fetch
命令会将数据拉取到你的本地仓库 - 它并不会自动合并或修改你当前的工作。 当准备好时你必须手动将其合并入你的工作。
4、拉取数据并合并
$ git pull
5、推送数据到远程仓库
$ git push origin master
当你想分享你的项目时,必须将其推送到上游。 这个命令很简单:git push [remote-name] [branch-name]
。 当你想要将 master
分支推送到 origin
服务器时(克隆时会自动帮你设置好这两个名字),那么运行这个命令就可以将你所做的上传到服务器。
如果服务器有新的数据(别人上传的)你还没拉取下来,这个命令会被拒绝,你必须先拉取新的数据下来之后再上传你的(相当于SVN中先更新后提交)
6、远程仓库的重命名
如果想要重命名引用的名字可以运行 $ git remote rename
去修改一个远程仓库的简写名。 例如,想要将 koke
重命名为 kk
,可以这样做
$ git remote rename koke kk
$ git remote
origin
kk
7、远程仓库的移除
如果因为一些原因想要移除一个远程仓库,你已经从服务器上搬走了或不再想使用某一个特定的镜像了,又或者某一个贡献者不再贡献了,可以使用 $ git remote rm
$ git remote rm kk
$ git remote
origin
8、从远程仓库克隆
以上讲的都是先创建一个本地Git仓库,再在GitHub上创建远程仓库,然后再关联两者。假如我们回到最初,先创建一个远程仓库,然后再从远程仓库克隆到本地。
首先,在GitHub上创建一个仓库
克隆命令是
$ git clone URL
,URL的获取见上图,执行克隆命令之前请将终端的目录cd到你喜欢的目录下
$ git clone git@github.com:YoungerLi/gitAnother.git
执行完毕,你就可以看到在你喜欢的目录下多出了一个文件夹,文件夹内包含一个README.md文件,这就是本地仓库了。
如果有多个人协作开发,那么每个人各自从远程克隆一份就可以了。