Git入門與練習(三)

2021-08-15 12:09:22 字數 2991 閱讀 9730

我們還是新建乙個test.txt後add並commit。

你通過右鍵檔案刪除了test.txt或命令列$ rm test.txt。

現在你有兩個選擇:

1、誤刪來了test.txt想還原

status一下:

$ git status

on branch master

changes not staged for commit:

(use

"git add/rm ..."

to update what will be committed)

(use

"git checkout -- ..."

to discard changes in working directory)

deleted: test.txt

提示你可以git checkout -- 撤銷工作區的改變

於是你$ git checkout -- test.txt

發現工作區剛被刪除的test.txt神奇的還原了。git checkout -- 其實就是將版本庫的版本覆蓋到工作區中,無論工作區中的檔案時修改還是刪除,都能「一鍵還原」,當然還原的是版本庫中該檔案的最新版本。

2、你確實想刪除test.txt,工作區的你已經刪除了,剩下的就是刪除版本庫中的test.txt

$ git rm file可以幫你做到

$ git rm test.txt

rm 'test.txt'

$ git status

on branch master

changes to be committed:

(use

"git reset head ..."

to unstage)

deleted: test.txt

status一下你會發現rm之後是將版本庫中的test放入了stage中,檔案狀態是被刪除,因此別忘了commit一下,完成刪除命令:

$ git commit -m "delete test.txt"

[master 6d08c02] delete test.txt

1file changed, 0 insertions(+), 0 deletions(-)

delete mode 100644 test.txt

這樣算是徹底刪除了test.txt

到目前為止,我們已經掌握了如何在git倉庫裡對乙個檔案進行時光穿梭,你再也不用擔心檔案備份或者丟失的問題了。

可是有用過集中式版本控制系統svn的童鞋會站出來說,這些功能在svn裡早就有了,沒看出git有什麼特別的地方。

沒錯,如果只是在乙個倉庫裡管理檔案歷史,git和svn真沒啥區別。為了保證你現在所學的git物超所值,將來絕對不會後悔,同時為了打擊已經不幸學了svn的童鞋,本章開始介紹git的殺手級功能之一(注意是之一,也就是後面還有之二,之三……):遠端倉庫。

git是分布式版本控制系統,同乙個git倉庫,可以分布到不同的機器上。怎麼分布呢?最早,肯定只有一台機器有乙個原始版本庫,此後,別的機器可以「轉殖」這個原始版本庫,而且每台機器的版本庫其實都是一樣的,並沒有主次之分。

你肯定會想,至少需要兩台機器才能玩遠端庫不是?但是我只有一台電腦,怎麼玩?

其實一台電腦上也是可以轉殖多個版本庫的,只要不在同乙個目錄下。不過,現實生活中是不會有人這麼傻的在一台電腦上搞幾個遠端庫玩,因為一台電腦上搞幾個遠端庫完全沒有意義,而且硬碟掛了會導致所有庫都掛掉,所以我也不告訴你在一台電腦上怎麼轉殖多個倉庫。

實際情況往往是這樣,找一台電腦充當伺服器的角色,每天24小時開機,其他每個人都從這個「伺服器」倉庫轉殖乙份到自己的電腦上,並且各自把各自的提交推送到伺服器倉庫裡,也從伺服器倉庫中拉取別人的提交。

完全可以自己搭建一台執行git的伺服器,不過現階段,為了學git先搭個伺服器絕對是小題大作。好在這個世界上有個叫github的神奇的**,從名字就可以看出,這個**就是提供git倉庫託管服務的,所以,只要註冊乙個github賬號,就可以免費獲得git遠端倉庫。

第1步:建立ssh key。在使用者主目錄下,看看有沒有.ssh目錄,如果有,再看看這個目錄下有沒有id_rsa和id_rsa.pub這兩個檔案,如果已經有了,可直接跳到下一步。如果沒有,開啟shell(windows下開啟git bash),建立ssh key:

$ ssh-keygen -t rsa -c "[email protected]"

你需要把郵件位址換成你自己的郵件位址,然後一路回車,使用預設值即可,由於這個key也不是用於軍事目的,所以也無需設定密碼。

如果一切順利的話,可以在使用者主目錄裡找到.ssh目錄,裡面有id_rsa和id_rsa.pub兩個檔案,這兩個就是ssh key的秘鑰對,id_rsa是私鑰,不能洩露出去,id_rsa.pub是公鑰,可以放心地告訴任何人。

第2步:登陸github,開啟「account settings」,「ssh keys」頁面。

然後,點「add ssh key」,填上任意title,在key文字框裡貼上id_rsa.pub檔案的內容:

點「add key」,你就應該看到已經新增的key。

為什麼github需要ssh key呢?因為github需要識別出你推送的提交確實是你推送的,而不是別人冒充的,而git支援ssh協議,所以,github只要知道了你的公鑰,就可以確認只有你自己才能推送。

當然,github允許你新增多個key。假定你有若干電腦,你一會兒在公司提交,一會兒在家裡提交,只要把每台電腦的key都新增到github,就可以在每台電腦上往github推送了。

最後友情提示,在github上免費託管的git倉庫,任何人都可以看到喔(但只有你自己才能改)。所以,不要把敏感資訊放進去。

如果你不想讓別人看到git庫,有兩個辦法,乙個是交點保護費,讓github把公開的倉庫變成私有的,這樣別人就看不見了(不可讀更不可寫)。另乙個辦法是自己動手,搭乙個git伺服器,因為是你自己的git伺服器,所以別人也是看不見的。這個方法我們後面會講到的,相當簡單,公司內部開發必備。

確保你擁有乙個github賬號後,我們就即將開始遠端倉庫的學習。

Git入門與高階

什麼是git git 是 linux 發明者 linus 開發的 款新時代的版本控制系統,用於管理源 為什麼要管理源 為了防止源 丟失,本地 丟失 我的伺服器還有啊 大家同時開發專案相互不影響,需要發版本時可以將分別開發的 合併在一起 開發到一半,發現上線的版本有bug需要緊急修復 隨著功能越來越多...

Git入門與使用

4 git與svn比較 二 git工作流程 三 git四個工作區域 四 分支 五 git常用命令 版本控制 revision control 是指對軟體開發過程中各種程式 配置檔案及說明文件等檔案變更的管理,是軟體配置管理的核心思想之一。svnsvn是subversion的簡稱,是乙個開放源 的集中...

Git 入門 Git 與 SVN 區別

一.git 是什麼?git 是目前世界上最先進的分布式版本控制系統 二.基礎知識 有中心的 scm software configuration management 無中心的 scm 三.svn 與 git 異同?相同 能記錄檔案的所有更改記錄。這樣是為了大量更改後,但是最後覺得還是原來的版本 好...