亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 系統 > CentOS > 正文

CentOS 6.3下使用Gitosis安裝搭建Git Server教程

2020-06-21 13:07:30
字體:
來源:轉載
供稿:網友

Git作為一個分布式的版本控制系統,使用git的時候,一般和服務器通訊使用的是ssh協議,用ssh的主要優點是速度快(傳輸前數據會先壓縮,比HTTP快),安全,方便讀寫。
 
客戶端通過ssh訪問服務器端的驗證方式一般有兩種,一種是用戶名密碼的方式,一種是使用公私鑰認證的方式. 使用公私鑰的方式比較方便,無需每次登錄輸入密碼。

某個受信任的客戶端的公鑰會被設置在服務器端的 ~/.ssh/authorized_keys文件中,有關此文件的格式可以參見 sshd的用戶手冊 man sshd . authorized_keys有個比較厲害的功能是 支持 command參數,使得每次用戶使用此公鑰進行驗證的時候執行此后面的命令.這樣就可以做一些邏輯處理了.

一般git庫的管理需要權限控制,如何方便簡單的進行庫的權限管理呢? authorized_keys是一個思路,指定特定command參數,每次驗證好用戶后首先執行相關邏輯,檢測當前用戶是否具有某個權限。 所以便有了gitosis,與其說gitosis是一個git權限管理系統,還不如說它是一個authorized_keys文件管理器.

解決方案:

環境部署

操作系統:              centos6.3 x64
Git:                         git-1.7.1
Gitosis:                   Gitosis
Gitweb:                   1.7.1-3        
OpenSSH Server:     openssh-server-5.3p1
apache:                  httpd-2.4.4
python-setuptools:   python-setuptools-0.6.10-3
        
Git server(centos6.3 x64): node2.example.com
Git client(centos6.3 x64): node1.example.com

server端配置:

一.關閉iptables和SELINUX

 

復制代碼
代碼如下:

# service iptables stop
# setenforce 0
# vi /etc/sysconfig/selinux
---------------
SELINUX=disabled
---------------

 

二.同步時間

 

復制代碼
代碼如下:

# ntpdate cn.pool.ntp.org

 

三.安裝apache

四.安裝OpenSSH

1.yum安裝OpenSSH:
 

復制代碼
代碼如下:

# yum install openssh-server -y

2.修改ssh服務端配置:

復制代碼
代碼如下:

# vi /etc/ssh/sshd_config
——————————————————————————————
Port 22 # 修改成你想要的登陸端口
PermitRootLogin no # 禁止root用戶登陸
StrictModes yes # 檢查密鑰的用戶和權限是否正確,默認打開的
RSAAuthentication yes # 啟用 RSA 認證
PubkeyAuthentication yes # 啟用公鑰認證
PasswordAuthentication yes # 啟用密碼認證,默認是打開的
ServerKeyBits 1024 # 修改后變為此狀態,將ServerKey強度改為1024比特
PermitEmptyPasswords no # 修改后變為此狀態,禁止空密碼進行登錄
——————————————————————————————

3.重啟服務:

復制代碼
代碼如下:

# /etc/init.d/sshd restart

 

五.安裝Git

 

復制代碼
代碼如下:

# yum install git-core -y

 

六.安裝Gitosis

1.安裝Gitosis依賴python-setuptools包
 

復制代碼
代碼如下:

# yum install python-setuptools -y

 

2.安裝Gitosis
 

復制代碼
代碼如下:

# cd ~
# mkdir src
# cd src
# git clone https://github.com/tv42/gitosis.git
# cd gitosis
# python setup.py install

 

3.為gitosis創建系統用戶
 

復制代碼
代碼如下:

# useradd -m git
# passwd git

 

4. 運行gitosis

(1).將管理員生成的公鑰上傳或拷貝到服務器上。這里的公鑰需要在git服務器管理員下使用ssh-keygen命令來創建
 

復制代碼
代碼如下:

# su - git

保證web頁面有權限顯示該倉庫內容

復制代碼
代碼如下:

# chmod -R 755 /home/git
# ssh-keygen -t rsa
# cp ~/.ssh/id_rsa.pub /tmp

 

(2).初始化gitosis

進入到拷貝過來的id_rsa.pub所在目錄
 

復制代碼
代碼如下:

# cd /tmp
# gitosis-init < id_rsa.pub

此時,會在/home/git目錄下生成gitosis倉庫和配置目錄

復制代碼
代碼如下:

# cd /home/git
# ll
----------------------------------------------------------------
drwxr-xr-x 2 git git 4096 Aug 12 13:39 gitosis
drwxr-xr-x 4 git git 4096 Aug 12 13:39 repositories
---------------------------------------------------------------

 

(3).切換回當前(root)用戶

 

復制代碼
代碼如下:

# exit

 

(4).配置權限

如果想要別人能夠clone gitosis-admin.git,需要執行以下操作:
 

復制代碼
代碼如下:

# chmod 755 /home/git/repositories/gitosis-admin.git/hooks/post-update

至此,gitosis的安裝工作已完成,其相關配置可以有管理員來操作,然后再提交到服務器上.

 

(5)現在可以試一下用初始化 Gitosis 的公鑰的擁有者身份 SSH 登錄服務器,應該會看到類似下面這樣:
 

復制代碼
代碼如下:

# su - git
$ ssh git@127.0.0.1
------------------------------------------------
PTY allocation request failed on channel 0
ERROR:gitosis.serve.main:Need SSH_ORIGINAL_COMMAND in environment.
Connection to gitserver closed.
------------------------------------------------

說明 Gitosis 認出了該用戶的身份,但由于沒有運行任何 Git 命令,所以它切斷了連接。那么,現在運行一個實際的 Git 命令 — 克隆 Gitosis 的控制倉庫:
在你本地計算機上克隆git倉庫

復制代碼
代碼如下:

# cd /tmp
# git clone git@gitserver:gitosis-admin.git

這會得到一個名為 gitosis-admin 的工作目錄,主要由兩部分組成:
紅色為git倉庫配置,藍色為實際倉庫保存的文件

復制代碼
代碼如下:

# cd gitosis-admin
# ll -a
----------------------------------------------------------
total 20
drwxr-xr-x 4 git git 4096 Aug 12 13:21 .
drwxr-xr-x 4 git git 4096 Aug 12 13:23 ..
drwxr-xr-x 8 git git 4096 Aug 12 13:22 .git
-rwxr-xr-x 1 git git 157 Aug 12 13:21 gitosis.conf
drwxr-xr-x 2 git git 4096 Aug 12 13:20 keydir
-----------------------------------------------------------

以上操作相當于,系統git用戶初始化并成為gitosis管理員,且利用其管理員權限將gitosis-admin倉庫clone到本地.

 

5.添加本地用戶john和倉庫test到gitosis,并和管理員git合作管理gitosis

1. 用戶john添加并發送id_rsa.pub給git
 

復制代碼
代碼如下:

# su -
# useradd john & passwd john
# su - john
# ssh-keygen -t rsa
-----------------------------------------------------------
Generating public/private rsa key pair.
Enter file in which to save the key (/home/john/.ssh/id_rsa):
Created directory '/home/john/.ssh'.
Enter passphrase (empty for no passphrase):
Enter same passphrase again:
Your identification has been saved in /home/john/.ssh/id_rsa.
Your public key has been saved in /home/john/.ssh/id_rsa.pub.
-----------------------------------------------------------
# cp /home/john/.ssh/id_rsa.pub /tmp

2. gitosis管理員git分配john權限

復制代碼
代碼如下:

# su - git
# mkdir projects
# cd ~/projects
# git clone git@node2.example.com:gitosis-admin
# cd gitosis-admin
# cat gitosis.conf
------------------------------------------------
[gitosis]
[group gitosis-admin]
writable = gitosis-admin
members = git@node2.example.com
------------------------------------------------
# ls keydir/
-------------------------
git@node2.example.com.pub
-------------------------
# cp /tmp/id_rsa.pub keydir/john.pub
# vi gitosis.conf
————————————————————————————————————
[gitosis]
[group gitosis-admin]
writable = gitosis-admin
members = git@node2.example.com
[group test]
writable = test
members = git@node2.example.com john
————————————————————————————————————
# git add .
# git commit -am "add member john and project foo"
# git push

 

3. 用戶git添加項目test

 

復制代碼
代碼如下:

# su - git
# cd ~/projects
# mkdir test
# cd test
# git init
# echo "Hello World." > hello.txt
# git add hello.txt
# git commit -am 'first commit'
# git remote add origin git@node2.example.com:test.git
# git push origin master

 

4. 用戶 john clone test并修改hello.txt
 

復制代碼
代碼如下:

# su - john
# git clone git@node2.example.com:test.git
# cd test
# date >> hello.txt
# git commit -am 'add time to hello.txt' && git push

 

整個過程分為:

1.通過修改gitosis-admin管理gitosis用戶權限,需要clone到本地,然后修改配置文件,最后add push將結果推送到遠程實現權限修改.

2.添加系統用戶,生成該用戶公鑰,并將其復制到keydir下,實現該用戶有權限進行git等相關操作.

3.登陸該用戶賬戶進行git相關操作,修改完后commit,push到中服務器即可完成倉庫權限配置.

七.安裝gitweb

1.首先我們需要Git的源碼,其中帶有GitWeb,并能生成定制的CGI腳本
 

復制代碼
代碼如下:

# git clone git://git.kernel.org/pub/scm/git/git.git
# cd git/
# make GITWEB_PROJECTROOT="/home/git/repositories" prefix=/usr gitweb
# cp -rf gitweb /usr/local/apache2/htdocs/

注: 通過指定 GITWEB_PROJECTROOT 變量告訴編譯命令 Git 倉庫的位置

 

2.設置Apache以CGI方式運行該腳本,并添加一個VirtualHost配置:

(1).加載apache的vhost配置文件
 

復制代碼
代碼如下:

# vi /usr/local/apache2/conf/httpd.conf

搜索包含httpd-vhosts的行,并去掉該行注釋.
(2).加載cgid模塊,使其支持perl語言.

復制代碼
代碼如下:

# vi /usr/local/apache2/conf/httpd.conf

搜索包含mod_cgid.so的行,并去掉該行注釋.
(3).配置VirtualHost

復制代碼
代碼如下:

# vi /usr/local/apache2/conf/extra/httpd-vhosts.conf

添加如下配置:

復制代碼
代碼如下:

——————————————————————————————————————————
<VirtualHost *:80>
ServerName git.example.com
DocumentRoot /usr/local/apache2/htdocs/gitweb
<Directory /usr/local/apache2/htdocs/gitweb>
Options +ExecCGI
AllowOverride All
order allow,deny
Allow from all
AddHandler cgi-script cgi pl
DirectoryIndex gitweb.cgi
</Directory>
</VirtualHost>
——————————————————————————————————————————

(4).安裝Time/HiRes.pm perl模塊
首次打開web頁面報Can't locate Time/HiRes.pm in @INC ….錯誤
解決方法:

復制代碼
代碼如下:

# yum install perl-devel perl-CPAN -y
# perl -MCPAN -e shell
cpan[2]> install Time::HiRes
cpan[3]> exit

(5).重啟apache服務

復制代碼
代碼如下:

# /usr/local/apache2/bin/apachectl restart

(6).修改本機HOST,并打開gitweb頁面
http://git.example.com

 

CentOS,Gitosis,Git,ServerCentOS,Gitosis,Git,Server

 

CentOS,Gitosis,Git,Server

CentOS,Gitosis,Git,Server

大功告成....


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美大胆a视频| 欧美综合国产精品久久丁香| 国产精品久久久久久一区二区| 日韩美女av在线| 精品久久久久国产| 国产精品一区久久久| 4444欧美成人kkkk| 久久精品久久久久久| 亚洲精选中文字幕| 精品欧美一区二区三区| 正在播放欧美视频| 欧美电影免费观看大全| 一区二区三区四区在线观看视频| 久久久久久高潮国产精品视| 日韩激情av在线播放| 欧美精品在线免费观看| 欧美久久精品午夜青青大伊人| 欧美日韩国产精品一区二区不卡中文| 国产精品专区第二| 情事1991在线| 日韩成人在线视频网站| 国产日韩视频在线观看| 91久久精品在线| 在线观看日韩www视频免费| 亚洲精品国产精品国自产在线| 日韩av在线免费看| 国产丝袜精品第一页| 久久艳片www.17c.com| 97超碰蝌蚪网人人做人人爽| 97超级碰碰碰久久久| 亚洲午夜精品视频| 久久精品2019中文字幕| 欧美激情视频三区| 欧美精品亚州精品| 亚洲一区二区三区四区在线播放| 日韩高清av在线| 97热精品视频官网| 久久久久久亚洲精品| 日韩久久免费电影| 精品露脸国产偷人在视频| 精品视频在线播放免| 精品国产一区二区在线| 麻豆国产精品va在线观看不卡| 疯狂欧美牲乱大交777| 久久综合免费视频影院| 欧美亚洲免费电影| 久久久欧美一区二区| 国产99久久精品一区二区永久免费| 国产精品中文字幕久久久| 国产精品嫩草影院久久久| 综合久久五月天| 亚洲级视频在线观看免费1级| www.亚洲免费视频| 91久久久久久久久久| 国产欧美精品久久久| 91久久精品美女| 国产精品扒开腿做| 91美女片黄在线观看游戏| 欧美精品999| 亚洲香蕉成视频在线观看| 色狠狠av一区二区三区香蕉蜜桃| 91av视频在线观看| 91色中文字幕| 91免费观看网站| 精品国内产的精品视频在线观看| 亚洲欧美中文另类| 超碰日本道色综合久久综合| 国产精品大陆在线观看| 欧美日韩国产色| 亚洲一区二区自拍| 啪一啪鲁一鲁2019在线视频| 久久理论片午夜琪琪电影网| 亚洲风情亚aⅴ在线发布| 欧美激情区在线播放| 中文欧美在线视频| 欧美夜福利tv在线| 色噜噜久久综合伊人一本| 精品国产老师黑色丝袜高跟鞋| 国产美女精彩久久| 久久久久九九九九| 精品爽片免费看久久| 97久久伊人激情网| 国产成人精品在线观看| 一本一道久久a久久精品逆3p| 国产精品永久免费在线| 亚洲自拍高清视频网站| 欧美午夜片在线免费观看| 久久久91精品国产一区不卡| 日韩视频免费看| 国产精品一区二区久久国产| 欧美日韩999| 欧美成人在线免费| 久久精品人人爽| 国产在线久久久| 亚洲无限乱码一二三四麻| 久久久电影免费观看完整版| 国产精品视频久久久久| 91免费的视频在线播放| 欧美性猛交丰臀xxxxx网站| 欧美激情亚洲国产| 97久久久免费福利网址| 2018中文字幕一区二区三区| 亚洲自拍偷拍第一页| 欧美一级在线播放| 91啪国产在线| 欧美激情奇米色| 黑人巨大精品欧美一区二区| 亚洲裸体xxxx| 久久免费视频网| 欧美乱大交xxxxx另类电影| 久久久久99精品久久久久| 91精品久久久久久综合乱菊| 欧美人与性动交a欧美精品| 91福利视频在线观看| 久久久人成影片一区二区三区观看| 国产成人精品在线播放| 欧美大片免费观看在线观看网站推荐| 一区二区欧美激情| 日韩av电影在线播放| 国产一区二区动漫| 久久久久久网站| 综合欧美国产视频二区| 欧美精品www| 欧美性猛交xxxx乱大交蜜桃| 成人av在线天堂| 国产亚洲欧美日韩一区二区| 国产婷婷成人久久av免费高清| 亚洲国产小视频在线观看| 久久精品精品电影网| 久久久久久成人| 日av在线播放中文不卡| 少妇高潮 亚洲精品| 91高潮在线观看| 狠狠躁夜夜躁人人躁婷婷91| 黄色一区二区三区| 亚洲偷熟乱区亚洲香蕉av| 欧美视频在线视频| 久久久久久久久综合| 亚洲图片欧洲图片av| 91精品在线国产| 国产精品免费一区二区三区都可以| 亚洲欧美变态国产另类| 成人性生交大片免费看视频直播| 欧美精品久久久久a| 成人h视频在线| 国产精品吊钟奶在线| 亚洲福利在线播放| 一本大道久久加勒比香蕉| 久久成人亚洲精品| 成人欧美一区二区三区黑人| 欧美激情综合亚洲一二区| 91精品综合视频| 日韩精品免费视频| 日韩有码在线观看| 热99在线视频| 97精品国产97久久久久久| 国产精品91久久久久久| 欧美成人合集magnet| 视频一区视频二区国产精品| 国模极品一区二区三区| 亚洲精品91美女久久久久久久| 久久久人成影片一区二区三区观看| 69av视频在线播放| 国产亚洲一区二区精品|