实际开发中,往往找一台电脑充当服务器的角色,每天24小时开机,其他每个人都从这个“服务器”仓库克隆一份到自己的电脑上,并且各自把各自的提交推送到服务器仓库里,也从服务器仓库中拉取别人的提交。
完全可以自己搭建一台运行Git的服务器,如gitlab, 也可以用github来托管你的代码,github需要注册账号,具体自己百度。
在继续阅读后续内容前,请自行注册GitHub账号。由于你的本地Git仓库和GitHub仓库之间的传输是通过SSH加密的,所以,需要一点设置:
1.创建SSH key, 打开git bash, 输入指令:ssh-keygen -t rsa -C "youremail@example.com"
:
注意ssh-keygen
中ssh
与-keygen
之间没有空格,上图第二个红线标注的地方就是密钥默认存放的位置,一直按回车就行了,全都采取默认的,生成成功就会显示上图的内容
2.上面这个指令会在默认的目录下生成两个文件:id_rsa
和id_rsa.pub
,一个是私钥,一个是公钥,用文本编辑器打开id_rsa.pub
,复制里面全部的内容。
3.登陆GitHub,打开“Account settings”,“SSH Keys”页面,(我演示的是自己搭建的gitlab,大同小异,自己去找一下):
4.点“Add SSH Key”,填上任意Title,在Key文本框里粘贴id_rsa.pub文件的内容(自己随便填一个title名字):
点击Add key,将会显示下面的内容:说明添加成功:
为什么GitHub需要SSH Key呢?因为GitHub需要识别出你推送的提交确实是你推送的,而不是别人冒充的,而Git支持SSH协议,所以,GitHub只要知道了你的公钥,就可以确认只有你自己才能推送。
当然,GitHub允许你添加多个Key。假定你有若干电脑,你一会儿在公司提交,一会儿在家里提交,只要把每台电脑的Key都添加到GitHub,就可以在每台电脑上往GitHub推送了。
下面我们就可以添加远程仓库了:
1.登陆GitHub,然后,在右上角找到“Create a new repo”按钮,创建一个新的仓库(在gitlab是右上角有个加号,我以gitlab为例,github自己找找,大同小异):
点击create project :
它会告诉你在你的机器上怎么设置,第一项就是全局设置,就是让别人知道你是谁,我们已经做过这件事了,直接跳过,第二项是如果你本地没有这个git库,你需要创建一个,上面我们也创建了,第三项是推送一个现有的库,因为我们已经创建过相对应的库,我们会选第三项。
2.我们先切换到本地仓库的路径下,然后执行git remote
的那条指令:
现在我们就可以把自己本地的库push上去:
这里有个小插曲,细心的人会发现上面的指令我爸127.0.1.1输成了127.0.0.1然后我输入指令:git push -u origin master
会有下面的提示:
这里就需要你来解决一下了,如果你直接输入:git remote add origin git@127.0.1.1:gary/git.git
会报下面的错误:
这种情况就需要你先删除远程的分支git remote rm origin
:
这时再次推送本地的分支就行了git push -u origin master
:
把本地库的内容推送到远程,用git push命令,实际上是把当前分支master推送到远程。
由于远程库是空的,我们第一次推送master分支时,加上了
-u
参数,Git不但会把本地的master分支内容推送的远程新的master分支,还会把本地的master分支和远程的master分支关联起来,在以后的推送或者拉取时就可以简化命令。
这里我用127.0.1.1发现推送不上去,我换成了我机器的ip就好了,然后yes就行了,回到gitlab中你会发现是这个样子:
从现在起,只要本地作了提交,就可以通过命令:
$ git push origin master
下面是如果你是一个新员工,刚来需要把数据从中央仓库里拉取下来,如何操作呢?
根据项目经理提供的地址,例如:git@172.21.15.82:gary/aaaa.git
,当然了,添加密钥是首先要干的事,请自行添加:
先切换到你要检出的目录,然后运行git clone
指令:
然后你去看看目录下会拉下来中央仓库的东西
如果有多个人协作开发,那么每个人各自从远程克隆一份就可以了。
你也许还注意到,GitHub给出的地址不止一个,还可以用http://127.0.1.1:9000/gary/aaaa.git这样的地址。实际上,Git支持多种协议,默认的git://使用ssh,但也可以使用https等其他协议。
使用https除了速度慢以外,还有个最大的麻烦是每次推送都必须输入口令,但是在某些只开放http端口的公司内部就无法使用ssh协议而只能用https。