实验环境:
1 centos7.3主机linux
在用户主目录下,看看有没有.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
登录GitHub,打开“Account settings”,“SSH Keys”页面:
而后,点“Add SSH Key”,填上任意Title,在Key文本框里粘贴id_rsa.pub文件的内容:服务器
为何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
在Repository name填入linuxhit,其余保持默认设置,点击“Create repository”按钮,就成功地建立了一个新的Git仓库:
目前,在GitHub上的这个linuxhit仓库仍是空的,GitHub告诉咱们,能够从这个仓库克隆出新的仓库,也能够把一个已有的本地仓库与之关联,而后,把本地仓库的内容推送到GitHub仓库。
如今,咱们根据GitHub的提示,在本地的linuxhit仓库下运行命令
git remote add origin git@github.com:pipijiujiu/Linux.git
请千万注意,把上面的pipijiujiu替换成你本身的GitHub帐户名,不然,你在本地关联的就是个人远程库,关联没有问题,可是你之后推送是推不上去的,由于你的SSH Key公钥不在个人帐户列表中。
添加后,远程库的名字就是origin,这是Git默认的叫法,也能够改为别的,可是origin这个名字一看就知道是远程库。
网页上进入远程仓库,复制远程仓库的url:
在本地主机上使用如下命令:
git clone git@github.com:pipijiujiu/Linux.git
远程仓库已经clone本地仓库
git push -u origin master
把本地库的内容推送到远程,用git push命令,其实是把当前分支master推送到远程。
因为远程库是空的,咱们第一次推送master分支时,加上了-u参数,Git不但会把本地的master分支内容推送的远程新的master分支,还会把本地的master分支和远程的master分支关联起来,在之后的推送或者拉取时就能够简化命令。
推送成功后,能够马上在GitHub页面中看到远程库的内容已经和本地如出一辙:
当你第一次使用Git的clone或者push命令链接GitHub时,会获得一个警告:
这是由于Git使用SSH链接,而SSH链接在第一次验证GitHub服务器的Key时,须要你确认GitHub的Key的指纹信息是否真的来自GitHub的服务器,输入yes回车便可。
Git会输出一个警告,告诉你已经把GitHub的Key添加到本机的一个信任列表里了:
若是你实在担忧有人冒充GitHub服务器,输入yes前能够对照GitHub的RSA Key的指纹信息是否与SSH链接给出的一致。