設定 SSH Key 使得裝置可以有許可權存取賬戶裡面的程式碼倉庫
$ ssh-keygen -t rsa -C "[email protected]"
"[email protected]"
設定為自己GitHub賬戶的註冊郵箱$ cat ~/.ssh/id_rsa.pub
ssh-rsa 公開金鑰的內容 [email protected]
ssh-rsa
也拷貝下來接下來驗證一下,出現successfully字樣即為成功
$ ssh -T [email protected] Enter passphrase for key '/c/Users/MYPC/.ssh/id_rsa': Hi abc! You've successfully authenticated, but GitHub does not provide shell access.
$ git clone [email protected]:hirocastest/Hello-World.git
這裡會要求輸入 GitHub 上設定的空開金鑰的密碼,認證成功後,倉庫便會被 clone 到當前目錄中。
程式碼編寫完成之後,將程式碼新增到系統的暫存區
$ git add 資料夾/檔案
git commit 命令可以將當前暫存區中的檔案實際儲存到倉庫的歷史記錄中。通過這些記錄,我們就可以在工作樹中復原檔案。
$ git commit -m "記錄一行提交資訊"
之後只要執行 push
命令,GitHub 上的倉庫就會被更新
$ git push
clone
方法建立倉庫,不需要執行 init
操作。如果要把本地檔案設定為倉庫,那麼就需要進行 init 操作
$ mkdir git-tutorial $ cd git-tutorial $ git init
$ git status # On branch master # # Initial commit # nothing to commit (create/copy files and use "git add" to track)
結果現實,我們正處於 masteer 分支下,並且沒有可提交的內容
git log
命令可以檢視以往倉庫中提交的紀錄檔。包括什麼人在什麼時候進行了提交或合併
$ git log commit 5dbbff6e009abb8a6cc44187c93b694f94fbf82a (HEAD -> main, origin/main, origin/HEAD) Author: ywm <[email protected]> Date: Sun Feb 28 17:17:00 2021 +0800
只想現實提交資訊的第一行,可以在 git log
命令後加上 -- pretty=short
$ git log --pretty=short
執行 git diff
檢視當前工作書與暫存區的差別
$ git diff
可以建立多個分支,同時進行完全不同的作業。等分支作業完成之後再與 master 分支合併。通過靈活運用分支,可以讓多人同時高效的進行並行開發。
master 分支左側有 「*」(星號),表示這是我們當前所在的分支。
$ git branch * master
建立並切換到分支 feature-A
$ git checkout -b feature-A
實際上,上面那條命令,等價於下面兩條命令
$ git branch feature-A $ git checkout feature-A
切換回分支 mian
$ git checkout main
切換回上一個分支
$ git checkout -
通過實際操作可以證明:只要建立多個分支,就可以在不互相影響的情況下同時進行多個功能的開發
合併時加上 --no–ff 引數,可以儲存之前的分支歷史
$ git merge --no-ff feature
隨後編輯器會啟動,用於錄入合併提交的資訊
$ git log --graph
$ git reset --hard 目標時間點的hash值
通過 git reflog
檢視當前倉庫的操作紀錄檔,可以找到回溯歷史之前的雜湊值。只要不進行 git 的 GC(垃圾回收),就可以通過紀錄檔隨意調取近期的歷史狀態。即便開發者錯誤執行了 git 操作,基本也可以用 git reflog 命令恢復到原先的狀態。
$ git reflog
上面列印的是最近的操作,下面列印的是最舊的操作
如果對上一條提交資訊不滿意,可以使用 amend 引數進行修改
$ git commit --amend
在合併分支之前,如果發現已提交的內容中有些拼寫錯誤,不妨提交一個修改,然後將這個修改包含到前一個提交之中,壓縮成一個歷史記錄。
git rebase -i HEAD~2
可以選定檔期按分支中包含 HEAD 在內的兩個最新歷史記錄為物件,並在編輯器中開啟
在建立新倉庫的時候,建議不要勾選 README.md 檔案,這樣會使本地倉庫和遠端倉庫失去整合性。雖然到時候可以強制覆蓋,但防止這一情況發生,還是不要勾選,就建立一個空倉庫就好。
git remote 在先寫程式碼,後建立倉庫的情況下能較好的使用
$ git remote add origin [email protected]:github-book/git-tutorial.git
對於一般先創倉庫,後寫程式碼的,需要先 pull 下來倉庫,再對檔案進行修改
推播至 master 分支
$ git push -u origin master
-u 引數可以在推播的同時,將 origin 倉庫的 master 分支設定為本地倉庫當前分支的 upstream(上游),新增這個引數,將來執行 git pull 命令從遠端倉庫獲取內容的時候,本地倉庫的這個分支就可以直接從 origin 的 masteer 分支獲取內容,省去了另外新增引數的麻煩
除了 master 分支之外,還可以推播到其他分支
$ git checkout -b feature-D $ git push -u origin feature-D
$ git clone git倉庫地址
將原生的 feature-D 分支更新到最新狀態
$ git pull origin feature-D
推薦學習:《》
以上就是如何二十分鐘搞懂git的基礎使用的詳細內容,更多請關注TW511.COM其它相關文章!