到目前为止,我们已经掌握了如何在Git仓库里对一个文件进行时光穿梭,你再也不用担心文件备份或者丢失的问题了
可是用过集中式版本控制系统SVN的童鞋们会站出来说,这些功能在SVN里早就有了,没看出Git有什么特别的地方。
没错,如果只是在一个仓库管理文件历史,Git和SVN真没啥区别,为了保证你现在所学的Git物超所值,将来绝对不会后悔,同时为了打击那些已经不幸学了SVN的童鞋,这里开始介绍Git的杀手级功能之一:远程仓库
Git是分布式版本控制系统,同一个Git仓库,可以分布到不同的机器上,怎么分布呢?最早,肯定只有一台机器有一个原始版本库,此后,别的机器可以“克隆”这个原始版本,而且每台机器的版本库其实都是一样的,并没有主次之分。
你肯定会想,至少需要两台机器才能玩远程库不是?但是我只有一台电脑,怎么玩?
其实一台电脑上也是可以克隆多个版本库的,只要不在同一个目录下。不过,现实生活中是不会有人这么傻的在一台电脑上搞几个远程库玩,因为一台电脑上搞几个远程库完全没有意义,而且硬盘挂了会导致所有库都挂掉,所以这里也不会讲在一台电脑上怎么克隆多个仓库。
实际情况往往是这样的,找一台电脑充当服务器的角色,每天24小时开机,其他每个人都从这个“服务器”仓库克隆一份到自己电脑上,并且各自把各自的提交推送到服务器仓库里,也从服务器仓库中拉取别人的提交。
完全可以自己搭建一台运行Git的服务器,不过现阶段,为了学Git先搭个服务器绝对是小题大做,好在这个世界上有个叫GitHub的神奇的网站,从名字就可以看出,这个网站就是提供Git仓库托管服务的,所以,只要注册一个GitHub账号,就可以免费获得Git远程仓库。https://www.cnblogs.com/cxq0017/p/9636083.html 这里已经讲解了怎么注册GitHub账号已经怎么使用的问题
在继续阅读后续的内容前,请自行注册GitHub账号,由于你的本地Git仓库和GitHub仓库之间的传输是通过SSH加密的,所以需要一点设置:
第一步:创建SSH Key。在用户主目录下(C:UsersAdministrator),看看有没有.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是公钥,可以放心的告诉任何人。
第2步:登录GitHub,打开“settings”,“SSH and GPG keys”
然后点击“New SSH key”填上任意Title,在Key文本框里粘贴上id_rsa.pub文件里的内容
点击Add SSH key,你就应该看到已经添加的Key
为什么GitHub需要SSH Key呢》因为GitHub需要识别出你推送的提交确实是你推送的,而不是别人冒充的,而Git支持SSH协议,所以,GitHub只要知道了你的公钥,就可以确认只有你自己才能推送。
当然,GitHub允许你添加多个Key,假定你有若干电脑,你一会在公司提交,一会在家里提交,只要把每台电脑的key都添加到GitHub,就可以在每台电脑上往GitHub推送了。
最后,在GitHub上免费托管的Git仓库,任何人都可以看到(但是只有你自己修改),所以不要把敏感信息放进去。
如果你不想让别人看到你的Git库,有两个办法,一个是交点保护费,让GitHub把公开的仓库变成私有的,这样别人就看不见了(不可读更不可写)。另一个办法就是自己动手,搭建一个Git服务器,因为是你自己的Git服务器,所以别人也是看不见的。