Git 遠(yuǎn)程倉(cāng)庫(kù)

2022-03-23 16:03 更新

Git 并不像 SVN 那樣有個(gè)中心服務(wù)器。

目前我們使用到的 Git 命令都是在本地執(zhí)行,如果你想通過(guò) Git 分享你的代碼或者與其他開(kāi)發(fā)人員合作。 你就需要將數(shù)據(jù)放到一臺(tái)其他開(kāi)發(fā)人員能夠連接的服務(wù)器上。

本例使用了 Github 作為遠(yuǎn)程倉(cāng)庫(kù),你可以先閱讀我們的 Github 簡(jiǎn)明教程。


添加遠(yuǎn)程庫(kù)

要添加一個(gè)新的遠(yuǎn)程倉(cāng)庫(kù),可以指定一個(gè)簡(jiǎn)單的名字,以便將來(lái)引用,命令格式如下:

git remote add [shortname] [url]

本例以Github為例作為遠(yuǎn)程倉(cāng)庫(kù),如果你沒(méi)有Github可以在官網(wǎng)https://github.com/注冊(cè)。

由于你的本地Git倉(cāng)庫(kù)和GitHub倉(cāng)庫(kù)之間的傳輸是通過(guò)SSH加密的,所以我們需要配置驗(yàn)證信息:

使用以下命令生成SSH Key:

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

后面的your_email@youremail.com改為你在github上注冊(cè)的郵箱,之后會(huì)要求確認(rèn)路徑和輸入密碼,我們這使用默認(rèn)的一路回車(chē)就行。成功的話(huà)會(huì)在~/下生成.ssh文件夾,進(jìn)去,打開(kāi)id_rsa.pub,復(fù)制里面的key。

回到github上,進(jìn)入 Account Settings(賬戶(hù)配置),左邊選擇SSH Keys,Add SSH Key,title隨便填,粘貼在你電腦上生成的key。


為了驗(yàn)證是否成功,輸入以下命令:

$ ssh -T git@github.com
Hi WongJay! You've successfully authenticated, but GitHub does not provide shell access.

以下命令說(shuō)明我們已成功連上 Github。

之后登錄后點(diǎn)擊" New repository " 如下圖所示:


之后在在Repository name 填入 w3cschool.cn(遠(yuǎn)程倉(cāng)庫(kù)名) ,其他保持默認(rèn)設(shè)置,點(diǎn)擊"Create repository"按鈕,就成功地創(chuàng)建了一個(gè)新的Git倉(cāng)庫(kù):


創(chuàng)建成功后,顯示如下信息:

以上信息告訴我們可以從這個(gè)倉(cāng)庫(kù)克隆出新的倉(cāng)庫(kù),也可以把本地倉(cāng)庫(kù)的內(nèi)容推送到GitHub倉(cāng)庫(kù)。

現(xiàn)在,我們根據(jù)GitHub的提示,在本地的倉(cāng)庫(kù)下運(yùn)行命令:

$ ls
README
W3Cschool教程測(cè)試.txt
test.txt
$ git remote add origin git@github.com:WongJay/w3cschool.cn.git
$ git push -u origin master
Counting objects: 21, done.
Delta compression using up to 4 threads.
Compressing objects: 100% (15/15), done.
Writing objects: 100% (21/21), 1.73 KiB | 0 bytes/s, done.
Total 21 (delta 4), reused 0 (delta 0)
To git@github.com:WongJay/w3cschool.cn.git
 * [new branch]      master -> master
Branch master set up to track remote branch master from origin.

以下命令請(qǐng)根據(jù)你在Github成功創(chuàng)建新倉(cāng)庫(kù)的地方復(fù)制,而不是根據(jù)我提供的命令,因?yàn)槲覀兊腉ithub用戶(hù)名不一樣,倉(cāng)庫(kù)名也不一樣。

接下來(lái)我們返回 Github 創(chuàng)建的倉(cāng)庫(kù),就可以看到文件已上傳到Github上:


查看當(dāng)前的遠(yuǎn)程庫(kù)

要查看當(dāng)前配置有哪些遠(yuǎn)程倉(cāng)庫(kù),可以用命令:

git remote
$ git remote
origin
$ git remote -v
origin  git@github.com:WongJay/w3cschool.cn.git (fetch)
origin  git@github.com:WongJay/w3cschool.cn.git (push)

執(zhí)行時(shí)加上 -v 參數(shù),你還可以看到每個(gè)別名的實(shí)際鏈接地址。


提取遠(yuǎn)程倉(cāng)庫(kù)

Git 有兩個(gè)命令用來(lái)提取遠(yuǎn)程倉(cāng)庫(kù)的更新。

1、從遠(yuǎn)程倉(cāng)庫(kù)下載新分支與數(shù)據(jù):

git fetch

該命令執(zhí)行完后需要執(zhí)行g(shù)it merge 遠(yuǎn)程分支到你所在的分支。

2、從遠(yuǎn)端倉(cāng)庫(kù)提取數(shù)據(jù)并嘗試合并到當(dāng)前分支:

git pull

該命令就是在執(zhí)行 git fetch 之后緊接著執(zhí)行 git merge 遠(yuǎn)程分支到你所在的任意分支。

假設(shè)你配置好了一個(gè)遠(yuǎn)程倉(cāng)庫(kù),并且你想要提取更新的數(shù)據(jù),你可以首先執(zhí)行 git fetch [alias] 告訴 Git 去獲取它有你沒(méi)有的數(shù)據(jù),然后你可以執(zhí)行 git merge [alias]/[branch] 以將服務(wù)器上的任何更新(假設(shè)有人這時(shí)候推送到服務(wù)器了)合并到你的當(dāng)前分支。

接下來(lái)我們?cè)?Github 上點(diǎn)擊"w3cschoolW3Cschool教程測(cè)試.txt" 并在線(xiàn)修改它。之后我們?cè)诒镜馗滦薷摹?/p>

$ git fetch origin
Warning: Permanently added the RSA host key for IP address '192.30.252.128' to the list of known hosts.
remote: Counting objects: 3, done.
remote: Compressing objects: 100% (2/2), done.
remote: Total 3 (delta 1), reused 0 (delta 0), pack-reused 0
Unpacking objects: 100% (3/3), done.
From github.com:WongJay/w3cschool.cn
   7d2081c..f5f3dd5  master     -> origin/master

以上信息"7d2081c..f5f3dd5 master -> origin/master" 說(shuō)明 master 分支已被更新,我們可以使用以下命令將更新同步到本地:

$ git merge origin/master
Updating 7d2081c..f5f3dd5
Fast-forward
 "w3cschool\350\217\234\351\270\237\346\225\231\347\250\213\346\265\213\350\257\225.txt" | 1 +
 1 file changed, 1 insertion(+)

推送到遠(yuǎn)程倉(cāng)庫(kù)

推送你的新分支與數(shù)據(jù)到某個(gè)遠(yuǎn)端倉(cāng)庫(kù)命令:

git push [alias] [branch]

以上命令將你的 [branch] 分支推送成為 [alias] 遠(yuǎn)程倉(cāng)庫(kù)上的 [branch] 分支,實(shí)例如下。

$ git merge origin/master
Updating 7d2081c..f5f3dd5
Fast-forward
 "w3cschool\350\217\234\351\270\237\346\225\231\347\250\213\346\265\213\350\257\225.txt" | 1 +
 1 file changed, 1 insertion(+)
bogon:w3cschoolcc WongJay$ vim w3cschoolW3Cschool教程測(cè)試.txt 
bogon:w3cschoolcc WongJay$ git push origin master
Everything up-to-date

刪除遠(yuǎn)程倉(cāng)庫(kù)

刪除遠(yuǎn)程倉(cāng)庫(kù)你可以使用命令:

git remote rm [別名]
$ git remote -v
origin  git@github.com:WongJay/w3cschool.cn.git (fetch)
origin   git@github.com:WongJay/w3cschool.cn.git (push)
$ git remote add origin2 git@github.com:WongJay/w3cschool.cn.git
$ git remote -v
origin   git@github.com:WongJay/w3cschool.cn.git (fetch)
origin   git@github.com:WongJay/w3cschool.cn.git (push)
origin2   git@github.com:WongJay/w3cschool.cn.git (fetch)
origin2  git@github.com:WongJay/w3cschool.cn.git (push)
$ git remote rm origin2
$ git remote -v
origin  git@github.com:WongJay/w3cschool.cn.git (fetch)
origin   git@github.com:WongJay/w3cschool.cn.git (push)
以上內(nèi)容是否對(duì)您有幫助:
在線(xiàn)筆記
App下載
App下載

掃描二維碼

下載編程獅App

公眾號(hào)
微信公眾號(hào)

編程獅公眾號(hào)