.編譯安裝git
yum install git
2.安裝gitosis
- $ yum install python python-setuptools
- $ git clone git://github.com/res0nat0r/gitosis.git
- $ cd gitosis
- $ python setup.py install
網址:https://github.com/res0nat0r/gitosis
3.在開發機器上產生公用密鑰(用來初始化gitosis)
- $ ssh-keygen -t rsa #不要求輸入密碼,一路斷行符號就行(在本地操作)
- $ scp ~/.ssh/id_rsa.pub root@xxx:/tmp/ # 上傳你的ssh public key到伺服器
4.初始化gitosis[伺服器端]
- $ adduser git # 新增一個git使用者(先添加使用者組 groupadd git)
- $ su git # 切換倒git使用者下
- $ gitosis-init < /tmp/id_rsa.pub # id_rsa.pub是剛剛傳過來的,注意放在/tmp目錄主要是因為此目錄許可權所有人都有定許可權的
- $ rm /tmp/id_rsa.pub # id_rsa.pub已經無用,可刪除.
5.擷取並配置gitosis-admin [用戶端]
- $ git clone git@xxx:gitosis-admin.git # 切換到root使用者並在本地執行,擷取gitosis管理項目,將會產生一個gitosis-admin的目錄,裡面有設定檔gitosis.conf和一個 keydir 的目錄,keydir目錄主要存放git使用者名稱
- $ vi gitosis-admin/gitosis.conf # 編輯gitosis-admin設定檔
如果無法git clone的話,可以使用git clone git@xxx:/home/git/repositories/gitosis-admin.git
# 在gitosis.conf底部增加
- [group 組名]
- writable = 項目名
- members = 使用者 # 這裡的使用者名稱字 要和 keydir下的檔案名稱字相一致
# VI下按ZZ(大寫)兩次會執行自動儲存並退出,完成後執行
- $ cd gitosis-admin
- $ git add .
- $ git commit -a -m “xxx xx” # 要記住的是,如果每次添加新檔案必須執行git add .,或者git add filename,如果沒有新加檔案,只是進行修改的話就可以執行此句。
# 修改了檔案以後一定要PUSH到伺服器,否則不會生效。
- $ git push
如果在git push的時候,遇到錯誤“ddress 192.168.0.77 maps to bogon, but this does not map back to the address - POSSIBLE BREAK-IN ATTEMPT!”,解決為修改/etc/hosts檔案,將ip地址與主機名稱對應關係寫進去就可以了。
注意:這裡我們並沒有進行任何的修改的,現在只有一個管理git的項目。下面的為新添加項目的配置,大家經常用到的也就是下面的操作的。
建立項目
到此步就算完成gitosis的初始化了。接下來的是建立一個新項目到伺服器的操作,如第5步中配置gitosis.conf檔案添加的是
- [group project1] # 組名稱
- writable = project1 # 項目名稱
- members = xxx # 使用者名稱xxx一定要與用戶端使用的使用者名稱完全一樣,否則無許可權操作
提交修改並更新到git server服務端
- $ git commit -a -m “添加新項目project1,新項目的目錄是project1,該項目的成員是xxx“ # “”裡的內容自定
- $ git push
將新建立的項目提交到git server 上進行登記。以便客戶可以操作新項目.
# 在用戶端建立項目目錄(用戶端,目前使用者為 XXX )
現在回到開發人員用戶端,上面建立了一個新項目project1並提交到了git server 。我們這裡就建立此項目的資訊.注意 項目名稱 project1要與gitosis.conf檔案配置一致,
- $ mkdir /home/使用者/project1
- $ cd /home/使用者/project1
- $ git init
- $ git add . # 新增檔案 留意後面有一個點
- $ git commit -a -m “初始化項目project1″
# 然後就到把這個項目放到git server伺服器上去.
- $ git remote add origin git@xxx:project1.git # xxx為伺服器位址
- $ git push origin master
# 也可以把上面的兩步合成一步
- $ git push git@xxx:project1.git master
說明:如果在執行 git push origin master 的時候,提示以下錯誤:
error: src refspec master does not match any.
error: failed to push some refs to 'git@192.168.0.77:pro2.git'
這是由於項目為空白的原因,我們在項目目錄裡新建立一個檔案。經過->add -> commit -> push 就可以解決了
- $ touch a.txt
- $ git add a.txt
- $ git commit -a -m 'add a.txt'
- $ git push
------------------------------------------------------------------------------------------------
如果在git clone的時候遇到“
error: cannot run ssh: No such file or directory - cygwin git
”錯誤,則表示本機沒有安裝ssh命令。安裝方法請參考:http://blog.haohtml.com/archives/13313
有時候我們要更換電腦來重新開發項目。這個時候,只需要將id_rsa私密金鑰放在home目錄裡的.ssh目錄裡就可以了。(有時候一個人開發多重專案,這時候可能會提示id_rsa檔案已經存在。不太清楚這裡如何解決???)