本地Git和远程Git托管平台进行互动
你的本地Git仓库和GitHub仓库之间的传输是通过SSH加密
的
如何创建SSH-keys
-
创建SSH Key。在用户主目录下,看看有没有
.ssh目录
,如果有,再看看这个目录下有没有id_rsa和id_rsa.pub这两个文件,如果已经有了,可直接跳到下一步。如果没有,打开Shell(Windows下打开Git Bash),创建SSH Key: -
$ ssh-keygen -t rsa -C "youremail@example.com"
你需要把邮件地址换成你自己的邮件地址,然后一路回车,使用默认值即可,由于这个Key也不是用于军事目的,所以也无需设置密码。
如果一切顺利的话,可以在用户主目录里找到.ssh目录,里面有id_rsa和id_rsa.pub两个文件,这两个就是SSH Key的秘钥对,id_rsa是私钥,不能泄露出去,id_rsa.pub是公钥,可以放心地告诉任何人。
远程仓库如何确认是我自己推送的?
因为GitHub需要识别出你推送的提交确实是你推送的,而不是别人冒充的,而Git支持SSH协议,所以,GitHub只要知道了你的公钥,就可以确认只有你自己才能推送。
如何拥有真正的分布式版本库
- 将本地库和远程库关联起来
$ git remote add origin git@github.com:michaelliao/learngit.git
添加后,远程库的名字就是origin,这是Git默认的叫法,也可以改成别的,但是origin这个名字一看就知道是远程库。
当然远程库的名字可以是任何东西,但是最好要一眼看明白是什么东西
origin只是远程库的名字,远程库的名字可以不是默认的,应该也是可以有多个远程库的
远程库的地址要告诉Git,要让Git用ssh协议来和指定的远程库进行连接,实现本地库和远程库之间的通信
- 从现在起,只要本地作了提交,就可以通过命令
$ git push origin maste
使用该命令进行远程提交
关于SSH警告
当你第一次使用Git的clone或者push命令连接GitHub时,会得到一个警告:
The authenticity of host 'github.com (xx.xx.xx.xx)' can't be established.
RSA key fingerprint is xx.xx.xx.xx.xx.
Are you sure you want to continue connecting (yes/no)?
这是因为Git使用SSH连接,而SSH连接在第一次验证GitHub服务器的Key时,需要你确认GitHub的Key的指纹信息是否真的来自GitHub的服务器,输入yes回车即可。
Git会输出一个警告,告诉你已经把GitHub的Key添加到本机的一个信任列表里了:
Warning: Permanently added ‘github.com’ (RSA) to the list of known hosts.
这个警告只会出现一次,后面的操作就不会有任何警告了。
如果你实在担心有人冒充GitHub服务器,输入yes前可以对照GitHub的RSA Key的指纹信息是否与SSH连接给出的一致。
关于谁给公钥的问题
A想给B传东西
- A把自己的公钥给了B
- A每次找B的时候出示自己的私钥
- B如果不信任A,可以找A公示一下的公钥
这就要求A必须把自己的公钥公示给所有人,任何人都可以质疑A的真实性。
删除远程库
如果添加的时候地址写错了,或者就是想删除远程库,可以用git remote rm <name>
命令。使用前,建议先用git remote -v查看远程库信息:
$ git remote -v
origin git@github.com:michaelliao/learn-git.git (fetch)
origin git@github.com:michaelliao/learn-git.git (push)
然后,根据名字删除,比如删除origin:
$ git remote rm origin
此处的“删除”其实是解除了本地和远程的绑定关系,并不是物理上删除了远程库。远程库本身并没有任何改动。要真正删除远程库,需要登录到GitHub,在后台页面找到删除按钮再删除。
小结
-
要关联一个远程库,使用命令
git remote add origin git@server-name:path/repo-name.git;
-
关联一个远程库时必须给远程库指定一个名字,origin是默认习惯命名;
-
关联后,使用命令
git push -u origin master
第一次推送master分支的所有内容; -
此后,每次本地提交后,只要有必要,就可以使用命令git push origin master`推送最新修改;
分布式版本系统的最大好处之一是在本地工作完全不需要考虑远程库的存在,也就是有没有联网都可以正常工作,而SVN在没有联网的时候是拒绝干活的!当有网络的时候,再把本地提交推送一下就完成了同步,真是太方便了!