因为你的本地仓库和GitHub仓库之间的传输是经过SSH加密的,因此须要一下设置:git
在用户主目录下,看看有没有.ssh目录,若是有,再看看这个目录下有没有id_rsa
和id_rsa.pub
这两个文件,若是已经有了,可直接跳到下一步。若是没有,打开Shell(Windows下打开Git Bash),建立SSH Key:github
ssh-keygen -t rsa -C "youremail@example.com"
你须要把邮件地址换成你本身的邮件地址,而后一路回车,使用默认值便可。服务器
建立完成后能够在用户主目录里找到.ssh
目录,里面有id_rsa
和id_rsa.pub
两个文件,这两个就是SSH Key的秘钥对,id_rsa
是私钥,不能泄露出去,id_rsa.pub
是公钥。ssh
点击“SH and GPG keys” “New SSH key”this
填上任意Title,在Key文本框里粘贴id_rsa.pub
文件的内容:加密
点“Add Key”,你就应该看到已经添加的Key:.net
GitHub容许你添加多个Key。假定你有若干电脑,你一下子在公司提交,一下子在家里提交,只要把每台电脑的Key都添加到GitHub,就能够在每台电脑上往GitHub推送了。在GitHub上免费托管的Git仓库,任何人均可以看到,但只有你本身才能改。因此,不要把敏感信息放进去。code
若是不想让别人看到Git库,有两个办法,一个是交费,让GitHub把公开的仓库变成私有的,这样别人就看不见了。另外一个办法是本身动手,搭一个Git服务器,由于是你本身的Git服务器,因此别人也是看不见的。blog
你本地已经建立Git仓库,又想在GitHub建立一个Git仓库,而且让这两个仓库进行远程同步。开发
首先登陆GitHub,点击“Create a new repository” 建立一个新仓库
在Repository name填入 learngit,其余保持默认,点击“Create repository”,成功建立一个新库
目前,在GitHub上的这个learngit
仓库仍是空的,GitHub告诉咱们,能够从这个仓库克隆出新的仓库,也能够把一个已有的本地仓库与之关联,而后,把本地仓库的内容推送到GitHub仓库。
如今,咱们根据GitHub的提示,在本地的learngit
仓库下运行命令:
bogon:learngit lwenhao$ git remote add origin https://github.com/liuwenhaoCN/learngit.git bogon:learngit lwenhao$
记得把liuwenhaoCN
换成你本身的GitHub帐户名。
把本地库的全部内容推送到远程库上:
git push -u origin master
bogon:learngit lwenhao$ git push -u origin master Username for 'https://github.com': liuwenhaoCN Password for 'https://liuwenhaoCN@github.com': Counting objects: 26, done. Delta compression using up to 12 threads. Compressing objects: 100% (21/21), done. Writing objects: 100% (26/26), 2.15 KiB | 1.07 MiB/s, done. Total 26 (delta 6), reused 0 (delta 0) remote: Resolving deltas: 100% (6/6), done. To https://github.com/liuwenhaoCN/learngit.git * [new branch] master -> master Branch 'master' set up to track remote branch 'master' from 'origin'. bogon:learngit lwenhao$
由于我本地就存在id_rsa.pub
,可能会让你输入一次用户名和密码。
用git push
命令,其实是把当前分支master
推送到远程。
因为远程库是空的,咱们第一次推送master
分支时,加上了-u
参数,Git不但会把本地的master
分支内容推送的远程新的master
分支,还会把本地的master
分支和远程的master
分支关联起来,在之后的推送或者拉取时就能够简化命令。
推送成功后,能够马上在GitHub页面中看到远程库的内容:
从如今开始,只要本地作了提交,就能够经过:
git push origin master
把本地master
分支的最新修改推送至GitHub
如今,假设咱们从零开发,那么最好的方式是先建立远程库,而后,从远程库克隆。
首先,登录GitHub,建立一个新的仓库,名字叫TestGit
:
勾选Initialize this repository with a README
,GitHub会自动建立一个README.md
文件。
如今,远程库已经准备好了,下一步是用命令git clone
克隆一个本地库:
git clone https://github.com/liuwenhaoCN/TestGit.git
注意把Git库地址换成你本身的。
bogon:~ lwenhao$ git clone https://github.com/liuwenhaoCN/TestGit.git Cloning into 'TestGit'... remote: Enumerating objects: 3, done. remote: Counting objects: 100% (3/3), done. remote: Total 3 (delta 0), reused 0 (delta 0), pack-reused 0 Unpacking objects: 100% (3/3), done. bogon:~ lwenhao$
进入TestGit文件夹,而且查看README.md
bogon:~ lwenhao$ cd TestGit/ bogon:TestGit lwenhao$ ls README.md bogon:TestGit lwenhao$ cat README.md # TestGit bogon:TestGit lwenhao$
若是有多我的协做开发,那么每一个人各自从远程克隆一份就能够了。