github远程仓库

实验环境:
1 centos7.3主机linux

一:注册GitHub帐号

二:添加远程库

一:建立SSH Key

在用户主目录下,看看有没有.ssh目录,若是有,再看看这个目录下有没有id_rsa和id_rsa.pub这两个文件,若是已经有了,可直接跳到下一步。若是没有,打开Shell,建立SSH Key:git

ssh-keygen -t rsa -C "youremail@example.com”

你须要把邮件地址换成你本身的邮件地址,而后一路回车,使用默认值便可github

若是一切顺利的话,能够在用户主目录里找到.ssh目录,里面有id_rsa和id_rsa.pub两个文件,这两个就是SSH Key的秘钥对,id_rsa是私钥,不能泄露出去,id_rsa.pub是公钥,能够放心地告诉任何人。centos

二:添加ssh—key

登录GitHub,打开“Account settings”,“SSH Keys”页面:
而后,点“Add SSH Key”,填上任意Title,在Key文本框里粘贴id_rsa.pub文件的内容:服务器

clipboard.png
为何GitHub须要SSH Key呢?由于GitHub须要识别出你推送的提交确实是你推送的,而不是别人冒充的,而Git支持SSH协议,因此,GitHub只要知道了你的公钥,就能够确认只有你本身才能推送。ssh

固然,GitHub容许你添加多个Key。假定你有若干电脑,你一下子在公司提交,一下子在家里提交,只要把每台电脑的Key都添加到GitHub,就能够在每台电脑上往GitHub推送了。url

最后友情提示,在GitHub上免费托管的Git仓库,任何人均可以看到喔(但只有你本身才能改)。因此,不要把敏感信息放进去。centos7

三:添加远程库

如今的情景是,你已经在本地建立了一个Git仓库后,又想在GitHub建立一个Git仓库,而且让这两个仓库进行远程同步,这样,GitHub上的仓库既能够做为备份,又可让其余人经过该仓库来协做,真是一举多得。spa

首先,登录GitHub,而后,在右上角找到“Create a new repo”按钮,建立一个新的仓库:code

clipboard.png

在Repository name填入linuxhit,其余保持默认设置,点击“Create repository”按钮,就成功地建立了一个新的Git仓库:

四:关联至本地仓库

目前,在GitHub上的这个linuxhit仓库仍是空的,GitHub告诉咱们,能够从这个仓库克隆出新的仓库,也能够把一个已有的本地仓库与之关联,而后,把本地仓库的内容推送到GitHub仓库。

如今,咱们根据GitHub的提示,在本地的linuxhit仓库下运行命令

git remote add origin git@github.com:pipijiujiu/Linux.git

clipboard.png

请千万注意,把上面的pipijiujiu替换成你本身的GitHub帐户名,不然,你在本地关联的就是个人远程库,关联没有问题,可是你之后推送是推不上去的,由于你的SSH Key公钥不在个人帐户列表中。

添加后,远程库的名字就是origin,这是Git默认的叫法,也能够改为别的,可是origin这个名字一看就知道是远程库。

五:克隆远程仓库至本地

网页上进入远程仓库,复制远程仓库的url:

clipboard.png

在本地主机上使用如下命令:
git clone git@github.com:pipijiujiu/Linux.git

远程仓库已经clone本地仓库

clipboard.png

六:本地库的全部内容推送到远程库上

git push -u origin master

clipboard.png

把本地库的内容推送到远程,用git push命令,其实是把当前分支master推送到远程。

因为远程库是空的,咱们第一次推送master分支时,加上了-u参数,Git不但会把本地的master分支内容推送的远程新的master分支,还会把本地的master分支和远程的master分支关联起来,在之后的推送或者拉取时就能够简化命令。

推送成功后,能够马上在GitHub页面中看到远程库的内容已经和本地如出一辙:

clipboard.png

七:SSH警告

当你第一次使用Git的clone或者push命令链接GitHub时,会获得一个警告:

clipboard.png
这是由于Git使用SSH链接,而SSH链接在第一次验证GitHub服务器的Key时,须要你确认GitHub的Key的指纹信息是否真的来自GitHub的服务器,输入yes回车便可。

Git会输出一个警告,告诉你已经把GitHub的Key添加到本机的一个信任列表里了:

clipboard.png

若是你实在担忧有人冒充GitHub服务器,输入yes前能够对照GitHub的RSA Key的指纹信息是否与SSH链接给出的一致。

相关文章
相关标签/搜索