Git 版本控制教學 - 基本設定

Last updated on  Mar 22, 2023  in  Git 版本控制  by  Amo Chen  ‐ 5 min read

本文為 Git 版本控制教學系列文之一,介紹多種使用 Git 時所需的設定,以及常用的 gitignore 設定檔、 alias 指令等等。

First thing first.

利用Git進行版本控制之前,需要設定 user.nameuser.email 。主要原因在於能夠透過這兩個設定了解哪些更動是由哪位成員所做出的,並且提供email的聯絡方式,使得團隊成員彼此間能夠確保至少有一個聯絡的管道。

設定 user.nameuser.email 的指令如下所示︰

$ git config --global user.name "Your Name"
$ git config --global user.email [email protected]
  1. 上述指令加上 --global 代表全域設定
  2. 每一位成員送出新版本(push)時,就是依照上述 2 個設定紀錄於Git的日誌檔中

設定 user.nameuser.email 之後,可以使用 git config --list 查看設定確認是否有設定成功。

$ git config --list

上述指令顯示結果如下︰ :

[email protected]
user.name=you
core.repositoryformatversion=0
core.filemode=true
core.bare=false
core.logallrefupdates=true
core.ignorecase=true
core.precomposeunicode=false
...(略)...

而上述的設定的內容,其實是存在使用者的家目錄下的 .gitconfig 檔案內(~/.gitconfig ),因此直接更動這個檔案也可以更改設定。

設定預設的推送(Push)模式

從Git推送(Push)模式目前有 5 種:

  1. nothing
  2. matching
  3. upstream
  4. simple
  5. current

如果不指定的話,就可能就會顯示以下類似的訊息(依Git版本而異):

warning: push.default is unset; its implicit value is changing in
Git 2.0 from 'matching' to 'simple'. To squelch this message
and maintain the current behavior after the default changes, use:

  git config --global push.default matching

To squelch this message and adopt the new behavior now, use:

  git config --global push.default simple

See 'git help config' and search for 'push.default' for further information.
(the 'simple' mode was introduced in Git 1.7.11. Use the similar mode
'current' instead of 'simple' if you sometimes use older versions of Git)

那麼要選擇哪一種 Push 模式?

各位可以依照需求設定,詳細的各種模式說明可以使用以下指令查詢 push.default 的部份:

$ git help config

但一般建議各位使用 currentsimple 即可,使用 current 模式代表只將目前所在的分支推送至程式碼儲存庫(repository)。相較於其他的推送模式而言,較為安全與單純,設定使用 current 推送模式可以使用以下指令:

$ git config --global push.default current

設定不需版本控制的檔案

進行系統程式開發時,不免會遇到一些檔案需要針對自己的系統環境進行設定,例如設定資料庫帳號密碼,或是使用 vim 可能會留下 .swp 暫存檔,這些可能具敏感機密的檔案如果不在版本控制系統中設定忽略的規則,就可能會造成資安事件。

因此,團隊成員之間必須在專案開始前,討論並設定必須將哪些檔案排除在版本控制之外。Git 版本控制系統則提供 gitignore 的設定,可以將指定的檔案排除版本控制的範圍。

有 2 種方式設定 gitignore ,一是於專案資料夾內新增 .gitignore ,二是於使用者家目錄下新增 .gitignore ,建議 2 種方式都使用,原因在於讓被包含在專案的 .gitignore 只需設定專案內部版本控制需要忽略的檔案,使得其他團隊成員就算忘記建立 .gitignore 也能夠保有一定程度的安全性;而使用者家目錄下的 .gitignore 則是可依照各人開發習慣以及作業系統的不同進行設定,而不會影響團隊其他成員的 .gitignore

GitHub 也整理許多常用的 .gitignore 檔案給大家使用 GitHub - github/gitignore: A collection of useful .gitignore templates ,可以參閱該 repo 並選擇自己需要的檔案。

以下是在 macOS 使用者家目錄下新增 .gitignore 的指令及 .gitignore 檔案內容1

$ cd ~
$ git config --global core.excludesfile ~/.gitignore
$ touch .gitignore
$ vim .gitignore

macOS 可適用的 .gitignore 檔案內容 :

# Compiled source
*.com
*.class
*.dll
*.exe
*.o
*.so

# Packages
# it's better to unpack these files and commit the raw source
# git has its own built in compression methods
*.7z
*.dmg
*.gz
*.iso
*.jar
*.rar
*.tar
*.zip

# Logs and databases
*.log
*.sql
*.sqlite

# OS generated files
.DS_Store
.DS_Store?
._*
.Spotlight-V100
.Trashes
ehthumbs.db
Thumbs.db

# Editor generated files
*.swp
*~
  1. .gitignore 內的設定支援 glob 語法(簡化過的正規表示式)
  2. .gitignore 也可設定子目錄下的忽略規則,如 output/*.*

設定 Git 預設所使用的 diff 演算法(algorithm)

Git也使用了多種不同的diff演算法,用來進行不同版本間的程式碼或文字內容的比對,目前有 patience , minimal , histogram , myers 4 種 diff 演算法,預設使用 myers 演算法進行比對,此種演算法是使用貪婪(greedy)的方式進行比對,因此有時候比對結果會與我們預期的結果有出入,建議可以使用 patience 演算法做為預設的 diff 演算法。

設定預設 diff 演算法之指令為:

$ git config --global diff.algorithm patience

設定好用的 Git 指令縮寫

有些常用的 Git 指令可以利用別名(alias)的功能變成縮寫,可以有效增加工作效率,以下是一些常用的指令別名的設定:

$ git config --global alias.co checkout
$ git config --global alias.cob checkout -b
$ git config --global alias.ci commit
$ git config --global alias.cim commit -m
$ git config --global alias.di diff
$ git condif --global alias.dis diff --staged
$ git config --global alias.st status
$ git config --global alias.br branch

此外,有很多網路資源也各自整理了不少常用的指令縮寫,也建議各位可以針對需求增加。

下列章節將列出一些相對重要的指令別名設定。

設定檔案層級的更改忽略

將以下設定寫入至 .gitconfig[alias] 區塊內:

[alias]
assume = update-index --assume-unchanged
unassume = update-index --no-assume-unchanged
assumed = "!git ls-files -v | grep ^h | cut -c 3-"
unassumeall = "!git assumed | xargs git update-index --no-assume-unchanged"
assumeall = "!git st -s | awk {'print $2'} | xargs git assume"

上述設定的簡要說明如下:

.gitignore 設定檔的功能在於將檔案排除在版本控制的範疇之外,但是有些應用程式的開發不免需要設定檔,設定檔就不太適合列入 .gitignore 中,因為我們也需要將設定檔的預設項目列入到版本控制之中,但是每個團隊成員經常在開發過程也會針對各自的任務或開發環境不同,而變更設定檔,如果這些變更也被一併提交推送到程式儲存庫中,就可能變更了預設的設定檔的狀態,也可能造成其他成員在合併設定檔時的衝突。

針對這個問題,我們可以使用 git update-index 來變更設定檔的狀態,這也是我們設定 assume , unassume 等別名的原因。

例如將設定檔的狀態從「已更改(modified)」變更為「未更改」:

$ git update --assume-unchanged your_config
$ git assume your_config #此指令與上一指令相同

設定快照(snapshot)功能

將以下設定寫入至 .gitconfig[alias] 區塊內:

[alias]
snapshot = !git stash save "snapshot: $(date)" && git stash apply "stash@{0}"

這個快照功能實際上是使用 git stash 功能來達成的。簡單而言,就是將目前分支的所有變更以時間為名稱存一份起來,如此一來,就等於是達成了快照功能,你就能夠使用 git stash apply "快照名稱" 來回復到你所想要回到的那個時間點。

可以使用以下指令進行快照、列出所有快照、回復快照:

$ git snapshot #快照
$ git stash list #列出快照
$ git stash apply stash@{1} #回復快照

以上就是2個相對重要的功能,如果不懂的話,先有個認識即可,本文會在後續章節中再做一次介紹。

其他

設定偏好的文字編輯器 :

例如,設定 Vim 作為偏好的文字編輯器:

$ git config --global core.editor "vim"

設定 VS Code 作為篇好的文字編輯器:

$ git config --global core.editor "code --wait"

開啟Git文字輸出以彩色形式輸出

Git 預設輸出是沒有顏色的,我們可以讓Git在輸出時加上顏色讓我們更容易閱讀:

$ git config --global color.ui true
$ git config --global color.status always

macOS 使用者設定用 keychain 儲存 git server 帳密

macOS 使用者可以使用以下設定將 git server 帳密存在 keychain 中,如此一來就不用每次 push / clone 都要輸入帳號密碼:

$ git config --global credential.helper osxkeychain

客製化提交變更說明

Git 也提供 commit 的樣板(template)設定,只要編輯專案資料夾內的 .git/COMMIT_EDITMSG 即可:

$ vim your_project/.git/COMMIT_EDITMSG

建議格式:

[ticket: XXX] subject line

changelog here

更多其他設定可以參閱參考資料2

References

對抗久坐職業傷害

研究指出每天增加 2 小時坐著的時間,會增加大腸癌、心臟疾病、肺癌的風險,也造成肩頸、腰背疼痛等常見問題。

然而對抗這些問題,卻只需要工作時定期休息跟伸展身體即可!

你想輕鬆改變現狀嗎?試試看我們的 PomodoRoll 番茄鐘吧! PomodoRoll 番茄鐘會根據你所設定的專注時間,定期建議你 1 項辦公族適用的伸展運動,幫助你打敗久坐所帶來的傷害!

追蹤新知

看完這篇文章了嗎?還意猶未盡的話,追蹤粉絲專頁吧!

我們每天至少分享 1 篇文章/新聞或者實用的軟體/工具,讓你輕鬆增廣見聞提升專業能力!如果你喜歡我們的文章,或是想了解更多特定主題的教學,歡迎到我們的粉絲專頁按讚、留言讓我們知道。你的鼓勵,是我們的原力!

贊助我們的創作

看完這篇文章了嗎? 休息一下,喝杯咖啡吧!

如果你覺得 MyApollo 有讓你獲得實用的資訊,希望能看到更多的技術分享,邀請你贊助我們一杯咖啡,讓我們有更多的動力與精力繼續提供高品質的文章,感謝你的支持!