搭建Git服務器,Git配置別名,使用碼雲
在遠程倉庫一節中,我們講了遠程倉庫實際上和本地倉庫沒啥不同,純粹為了7x24小時開機並交換大家的修改。
GitHub就是一個免費托管開源代碼的遠程倉庫。但是對於某些視源代碼如生命的商業公司來說,既不想公開源代碼,又舍不得給GitHub交保護費,那就只能自己搭建一臺Git服務器作為私有倉庫使用。
搭建Git服務器需要準備一臺運行Linux的機器,強烈推薦用Ubuntu或Debian,這樣,通過幾條簡單的apt
命令就可以完成安裝。
假設你已經有sudo
權限的用戶賬號,下面,正式開始安裝。
第一步,安裝git
:
$ sudo apt-get install git
第二步,創建一個git
用戶,用來運行git
服務:
$ sudo adduser git
第三步,創建證書登錄:
收集所有需要登錄的用戶的公鑰,就是他們自己的id_rsa.pub
文件,把所有公鑰導入到/home/git/.ssh/authorized_keys
文件裏,一行一個。
第四步,初始化Git倉庫:
先選定一個目錄作為Git倉庫,假定是/srv/sample.git
,在/srv
目錄下輸入命令:
$ sudo git init --bare sample.git
Git就會創建一個裸倉庫,裸倉庫沒有工作區,因為服務器上的Git倉庫純粹是為了共享,所以不讓用戶直接登錄到服務器上去改工作區,並且服務器上的Git倉庫通常都以.git
git
:
$ sudo chown -R git:git sample.git
第五步,禁用shell登錄:
出於安全考慮,第二步創建的git用戶不允許登錄shell,這可以通過編輯/etc/passwd
文件完成。找到類似下面的一行:
git:x:1001:1001:,,,:/home/git:/bin/bash
改為:
git:x:1001:1001:,,,:/home/git:/usr/bin/git-shell
這樣,git
用戶可以正常通過ssh使用git,但無法登錄shell,因為我們為git
用戶指定的git-shell
每次一登錄就自動退出。
第六步,克隆遠程倉庫:
現在,可以通過git clone
$ git clone git@server:/srv/sample.git
Cloning into ‘sample‘...
warning: You appear to have cloned an empty repository.
剩下的推送就簡單了。
管理公鑰
如果團隊很小,把每個人的公鑰收集起來放到服務器的/home/git/.ssh/authorized_keys
文件裏就是可行的。如果團隊有幾百號人,就沒法這麽玩了,這時,可以用Gitosis來管理公鑰。
這裏我們不介紹怎麽玩Gitosis了,幾百號人的團隊基本都在500強了,相信找個高水平的Linux管理員問題不大。
管理權限
有很多不但視源代碼如生命,而且視員工為竊賊的公司,會在版本控制系統裏設置一套完善的權限控制,每個人是否有讀寫權限會精確到每個分支甚至每個目錄下。因為Git是為Linux源代碼托管而開發的,所以Git也繼承了開源社區的精神,不支持權限控制。不過,因為Git支持鉤子(hook),所以,可以在服務器端編寫一系列腳本來控制提交等操作,達到權限控制的目的。Gitolite就是這個工具。
這裏我們也不介紹Gitolite了,不要把有限的生命浪費到權限鬥爭中。
小結
-
搭建Git服務器非常簡單,通常10分鐘即可完成;
-
要方便管理公鑰,用Gitosis;
-
要像SVN那樣變態地控制權限,用Gitolite。
----------------------------------------------------------------------------------------------------------------------------------------------
配置別名有沒有經常敲錯命令?比如git status
?status
這個單詞真心不好記。
如果敲git st
就表示git status
那就簡單多了,當然這種偷懶的辦法我們是極力贊成的。
我們只需要敲一行命令,告訴Git,以後st
就表示status
:
$ git config --global alias.st status
好了,現在敲git st
看看效果。
當然還有別的命令可以簡寫,很多人都用co
表示checkout
,ci
表示commit
,br
表示branch
:
$ git config --global alias.co checkout
$ git config --global alias.ci commit
$ git config --global alias.br branch
以後提交就可以簡寫成:
$ git ci -m "bala bala bala..."
--global
參數是全局參數,也就是這些命令在這臺電腦的所有Git倉庫下都有用。
在撤銷修改一節中,我們知道,命令git reset HEAD file
可以把暫存區的修改撤銷掉(unstage),重新放回工作區。既然是一個unstage操作,就可以配置一個unstage
別名:
$ git config --global alias.unstage ‘reset HEAD‘
當你敲入命令:
$ git unstage test.py
實際上Git執行的是:
$ git reset HEAD test.py
配置一個git last
,讓其顯示最後一次提交信息:
$ git config --global alias.last ‘log -1‘
這樣,用git last
就能顯示最近一次的提交:
$ git last
commit adca45d317e6d8a4b23f9811c3d7b7f0f180bfe2
Merge: bd6ae48 291bea8
Author: Michael Liao <[email protected]>
Date: Thu Aug 22 22:49:22 2013 +0800
merge & fix hello.py
甚至還有人喪心病狂地把lg
配置成了:
git config --global alias.lg "log --color --graph --pretty=format:‘%Cred%h%Creset -%C(yellow)%d%Creset %s %Cgreen(%cr) %C(bold blue)<%an>%Creset‘ --abbrev-commit"
來看看git lg
的效果:
為什麽不早點告訴我?別激動,咱不是為了多記幾個英文單詞嘛!
配置文件
配置Git的時候,加上--global
是針對當前用戶起作用的,如果不加,那只針對當前的倉庫起作用。
配置文件放哪了?每個倉庫的Git配置文件都放在.git/config
文件中:
$ cat .git/config
[core]
repositoryformatversion = 0
filemode = true
bare = false
logallrefupdates = true
ignorecase = true
precomposeunicode = true
[remote "origin"]
url = git@github.com:michaelliao/learngit.git
fetch = +refs/heads/*:refs/remotes/origin/*
[branch "master"]
remote = origin
merge = refs/heads/master
[alias]
last = log -1
別名就在[alias]
後面,要刪除別名,直接把對應的行刪掉即可。
而當前用戶的Git配置文件放在用戶主目錄下的一個隱藏文件.gitconfig
中:
$ cat .gitconfig
[alias]
co = checkout
ci = commit
br = branch
st = status
[user]
name = Your Name
email = your@email.com
配置別名也可以直接修改這個文件,如果改錯了,可以刪掉文件重新通過命令配置。
--------------------------------------------------------------------------------------------------------------------------------
使用碼雲
使用GitHub時,國內的用戶經常遇到的問題是訪問速度太慢,有時候還會出現無法連接的情況(原因你懂的)。
如果我們希望體驗Git飛一般的速度,可以使用國內的Git托管服務——碼雲(gitee.com)。
和GitHub相比,碼雲也提供免費的Git倉庫,並且,免費版本還包含私有庫。此外,還集成了代碼質量檢測、項目演示等功能。對於團隊協作開發,碼雲還提供了項目管理、代碼托管、文檔管理的服務,5人以下小團隊免費。
使用碼雲和使用GitHub類似,我們在碼雲上註冊賬號並登錄後,需要先上傳自己的SSH公鑰。選擇右上角用戶頭像 -> 菜單“修改資料”,然後選擇“SSH公鑰”,填寫一個便於識別的標題,然後把用戶主目錄下的.ssh/id_rsa.pub
文件的內容粘貼進去:
點擊“確定”即可完成並看到剛才添加的Key:
如果我們已經有了一個本地的git倉庫(例如,一個名為learngit的本地庫),如何把它關聯到碼雲的遠程庫上呢?
首先,我們在碼雲上創建一個新的項目,選擇右上角用戶頭像 -> 菜單“控制面板”,然後點擊“創建項目”:
項目名稱最好與本地庫保持一致:
然後,我們在本地庫上使用命令git remote add
把它和碼雲的遠程庫關聯:
git remote add origin git@gitee.com:liaoxuefeng/learngit.git
之後,就可以正常地用git push
和git pull
推送了!
如果在使用命令git remote add
時報錯:
git remote add origin git@gitee.com:liaoxuefeng/learngit.git
fatal: remote origin already exists.
這說明本地庫已經關聯了一個名叫origin
的遠程庫,此時,可以先用git remote -v
查看遠程庫信息:
git remote -v
origin git@github.com:michaelliao/learngit.git (fetch)
origin git@github.com:michaelliao/learngit.git (push)
可以看到,本地庫已經關聯了origin
的遠程庫,並且,該遠程庫指向GitHub。
我們可以刪除已有的GitHub遠程庫:
git remote rm origin
再關聯碼雲的遠程庫(註意路徑中需要填寫正確的用戶名):
git remote add origin git@gitee.com:liaoxuefeng/learngit.git
此時,我們再查看遠程庫信息:
git remote -v
origin git@gitee.com:liaoxuefeng/learngit.git (fetch)
origin git@gitee.com:liaoxuefeng/learngit.git (push)
現在可以看到,origin已經被關聯到碼雲的遠程庫了。通過git push
命令就可以把本地庫推送到Gitee上。
有的小夥伴又要問了,一個本地庫能不能既關聯GitHub,又關聯碼雲呢?
答案是肯定的,因為git本身是分布式版本控制系統,可以同步到另外一個遠程庫,當然也可以同步到另外兩個遠程庫。
使用多個遠程庫時,我們要註意,git給遠程庫起的默認名稱是origin
,如果有多個遠程庫,我們需要用不同的名稱來標識不同的遠程庫。
仍然以learngit
本地庫為例,我們先刪除已關聯的名為origin
的遠程庫:
git remote rm origin
然後,先關聯GitHub的遠程庫:
git remote add github git@github.com:michaelliao/learngit.git
註意,遠程庫的名稱叫github
,不叫origin
了。
接著,再關聯碼雲的遠程庫:
git remote add gitee git@gitee.com:liaoxuefeng/learngit.git
同樣註意,遠程庫的名稱叫gitee
,不叫origin
。
現在,我們用git remote -v
查看遠程庫信息,可以看到兩個遠程庫:
git remote -v
gitee git@gitee.com:liaoxuefeng/learngit.git (fetch)
gitee git@gitee.com:liaoxuefeng/learngit.git (push)
github git@github.com:michaelliao/learngit.git (fetch)
github git@github.com:michaelliao/learngit.git (push)
如果要推送到GitHub,使用命令:
git push github master
如果要推送到碼雲,使用命令:
git push gitee master
這樣一來,我們的本地庫就可以同時與多個遠程庫互相同步:
碼雲也同樣提供了Pull request功能,可以讓其他小夥伴參與到開源項目中來。你可以通過Fork我的倉庫:https://gitee.com/liaoxuefeng/learngit,創建一個your-gitee-id.txt
的文本文件, 寫點自己學習Git的心得,然後推送一個pull request給我,這個倉庫會在碼雲和GitHub做雙向同步。
本網頁轉自:https://www.liaoxuefeng.com/
搭建Git服務器,Git配置別名,使用碼雲