1. 程式人生 > >iOS開發環境 - Git教程2.0:添加遠程倉庫

iOS開發環境 - Git教程2.0:添加遠程倉庫

lan -128 new 右上角 服務器 pos 需要 下一步 warn

添加遠程庫

1 - 你已經在本地創建了一個Git倉庫後,又想在GitHub創建一個Git倉庫,並且讓這兩個倉庫進行遠程同步,這樣,GitHub上的倉庫既可以作為備份,又可以讓其他人通過該倉庫來協作,真是一舉多得

2 - 開始添加

  (1)首先,登陸 GitHub,然後,在右上角找到『Create a new repo』按鈕,創建一個新的倉庫:

技術分享

  (2)在 Repository name 填入 learngFirstGit,其他保持默認設置,點擊『Create repository』按鈕,就成功地創建了一個新的Git倉庫:

技術分享

  (3)目前,在 GitHub 上的這個 learngFirstGit

倉庫還是空的,GitHub 告訴我們,可以從這個倉庫克隆出新的倉庫,也可以把一個已有的本地倉庫與之關聯,然後,把本地倉庫的內容推送到GitHub倉庫

   技術分享

  (4)現在,我們根據 GitHub 的提示,在本地 markGit倉庫下運行命令:請千萬註意,把下面的 Beisongshi 替換成你自己的 GitHub 賬戶名,否則,你在本地關聯的就是我的遠程庫!可是,你會發現關聯後你推送是推不上去的,因為你的 SSH Key 公鑰不在我的賬戶列表中。添加後,遠程庫的名字就是 origin,這是 Git 默認的叫法,也可以改成別的,但是 origin 這個名字一看就知道是遠程庫。

1 $ git remote add origin [email protected]
/* */:BeisongShi/learngFirstGit.git

  (5)下一步,就可以把本地庫的所有內容推送到遠程庫上

1 $ git push -u origin master
2 The authenticity of host github.com (192.30.255.113) cant be established.
3 RSA key fingerprint is SHA256:nThbg6kXUpJWGl7E1IGOCspRomTxdCARLviKw6E5SY8.
4 Are you sure you want to continue connecting (yes/no)? 

  是的,出現了警告!不要問我為什麽,因為我也不知道。命令行 yes 繼續連接即可,good luck!以下是連接成功的輸出

 1 $ git push -u origin master
 2 The authenticity of host github.com (192.30.255.113) cant be established.
 3 RSA key fingerprint is SHA256:nThbg6kXUpJWGl7E1IGOCspRomTxdCARLviKw6E5SY8.
 4 Are you sure you want to continue connecting (yes/no)? yes
 5 Warning: Permanently added github.com,192.30.255.113 (RSA) to the list of known hosts.
 6 Counting objects: 28, done.
 7 Delta compression using up to 4 threads.
 8 Compressing objects: 100% (26/26), done.
 9 Writing objects: 100% (28/28), 2.94 KiB | 0 bytes/s, done.
10 Total 28 (delta 10), reused 0 (delta 0)
11 remote: Resolving deltas: 100% (10/10), done.
12 To github.com:BeisongShi/learngFirstGit.git
13  * [new branch]      master -> master
14 Branch master set up to track remote branch master from origin.

  把本地庫的內容推送到遠程,用 git push 命令,實際上是把當前分 支master 推送到遠程。

  由於遠程庫是空的,我們第一次推送 master 分支時,加上了-u參數,Git 不但會把本地的 master 分支內容推送的遠程新的 master 分支,還會把本地的 master 分支和遠程的 master 分支關聯起來,在以後的推送或者拉取時就可以簡化命令。

  (6)推送成功後,可以立刻在 GitHub 頁面中看到遠程庫的內容已經和本地一模一樣:

技術分享

  (7)恭喜你,從現在起,只要本地作了提交,就可以通過命令:

1 $ git push origin master

  把本地 master 分支的最新修改推送至 GitHub,現在,你就擁有了真正的分布式版本庫!

SSH警告

1 - 當你第一次使用Git的clone或者push命令連接GitHub時,會得到一個警告:

1 The authenticity of host github.com (xx.xx.xx.xx) cant be established.
2 RSA key fingerprint is xx.xx.xx.xx.xx.
3 Are you sure you want to continue connecting (yes/no)?

  (1)這是因為 Git 使用 SSH 連接,而S SH 連接在第一次驗證 GitHub 服務器的 Key 時,需要你確認 GitHub的Key 的指紋信息是否真的來自 GitHub的 服務器,輸入 yes 回車即可。

2 - 此時,Git 會輸出一個警告,告訴你已經把GitHub的Key添加到本機的一個信任列表裏了:

1 Warning: Permanently added github.com (RSA) to the list of known hosts.

註:這個警告只會出現一次,後面的操作就不會有任何警告了。如果你實在擔心有人冒充GitHub服務器,輸入yes前可以對照GitHub的RSA Key的指紋信息是否與 SSH 連接給出的一致

  布式版本系統的最大好處之一是在本地工作完全不需要考慮遠程庫的存在,也就是有沒有聯網都可以正常工作,而 SVN 在沒有聯網的時候是拒絕幹活的!而Git當有網絡的時候,再把本地提交推送一下就完成了同步,真是太NB了!

iOS開發環境 - Git教程2.0:添加遠程倉庫