因爲你的本地倉庫和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$
若是有多我的協做開發,那麼每一個人各自從遠程克隆一份就能夠了。