CentOS用yum安裝配置svn伺服器步驟

來源:互聯網
上載者:User

簡單的,用yum安裝方式:

#yum install subversion

安裝完成之後,採用以下查看是否安裝完成

#svn --version

建立SVN的倉庫,比如:

#mkdir -p /data/svn
#svnadmin create opengeo

然後會發現自動產生conf、db、format、hooks、locks、README.txt等檔案或目錄。

修改conf目錄下的設定檔

在svnserve.conf中,編輯配置為:

[general]
anon-access = none
auth-access = write
password-db = passwd
authz-db = authz

在auth中,配置組和許可權為:

[groups]
dev = user1,user2,user3
[/]
@dev = rw

在passwd中配置使用者名稱和密碼為:

[users]
user1=pass1
user2=pass2
user3=pass3

經過以上幾步,安裝和配置完成,啟動svn並指定相應的目錄:

#svnserve -d -r /data/svn/

查看服務是否啟動成功

#netstat -nlp | grep svn

關閉svn服務

#killall -9 svnserve

然後,便可以通過如下地址訪問,{ip}替換為你的SVN伺服器IP地址或網域名稱:

svn://{ip}/opengeo

SVN Server詳細配置手冊


系統內容
CentOS 5.8 迷你安裝(關閉iptables和selinux) + ssh + yum

一,安裝必須的軟體包.
yum install subversion mysql-server httpd mod_dav_svn mod_perl sendmail wget gcc-c++ make unzip perl* ntsysv vim-enhanced

說明:
subversion (SVN伺服器)
mysql-server (用於codestriker)
httpd mod_dav_svn mod_perl (用於支援WEB方式管理SVN伺服器)
sendmail (用於配置使用者提交代碼後發寄件提醒)
wget gcc-c++ make unzip perl* (必備軟體包)
ntsysv vim-enhanced (可選)

二,基本的SVN伺服器配置
1,建立一個目錄用於儲存SVN所有檔案
# mkdir /home/svn

2,建立一個版本倉庫
# svnadmin create /home/svn/project

3,初始化版本倉庫中的目錄
# mkdir project project/server project/client project/test (建立臨時目錄)
# svn import project/ file:///home/svn/project -m “初始化SVN目錄”
# rm -rf project (刪除臨時建立的目錄)

4,添加使用者
要添加SVN使用者非常簡單,只需在/home/svn/project/conf/passwd檔案添加一個形如“username=password”的條目就可以了。為了測試,我添加了如下內容:

[users]
# harry = harryssecret
# sally = sallyssecret
pm = pm_pw
server_group = server_pw
client_group = client_pw
test_group = test_pw

5,修改使用者存取原則
/home/svn/project/conf/authz記錄使用者的存取原則,以下是參考:

[groups]
project_p = pm
project_s = server1,server2,server3
project_c = client1,client2,client3
project_t = test1,test1,test1


[project:/]
@project_p = rw
* =

[project:/server]
@project_p = rw
@project_s = rw
* =

[project:/client]
@project_p = rw
@project_c = rw
* =

[project:/doc]
@project_p = rw
@project_s = r
@project_c = r
@project_t = r
* =

說明:以上資訊表示,只有project_p使用者組有根目錄的讀寫權。r表示對該目錄有讀許可權,w表示對該目錄有寫入權限,rw表示對該目錄有讀寫權限。最後一行的* =表示,除了上面設定了許可權的使用者組之外,其他任何人都被禁止訪問本目錄。這個很重要,一定要加上!

6,修改svnserve.conf檔案,讓使用者和策略配置升效.
svnserve.conf內容如下:

[general]
anon-access = none
auth-access = write
password-db = /home/svn/project/conf/passwd
authz-db = /home/svn/project/conf/authz

7,啟動伺服器
# svnserve -d -r /home/svn
注意:如果修改了svn配置,需要重啟svn服務,步驟如下:

# ps -aux|grep svnserve
# kill -9 ID號
# svnserve -d -r /home/svn

8,測試伺服器

# svn co svn://192.168.60.10/project
Authentication realm: <svn://192.168.60.10:3690> 92731041-2dae-4c23-97fd-9e1ed7f0d18d
Password for 'root':
Authentication realm: <svn://192.168.60.10:3690> 92731041-2dae-4c23-97fd-9e1ed7f0d18d
Username: server_group
Password for 'server_group':
svn: Authorization failed ( server_group沒用根目錄的訪問權 )

# svn co svn://192.168.60.10/project
Authentication realm: <svn://192.168.60.10:3690> 92731041-2dae-4c23-97fd-9e1ed7f0d18d
Password for ‘root’:
Authentication realm: <svn://192.168.60.10:3690> 92731041-2dae-4c23-97fd-9e1ed7f0d18d
Username: pm
Password for ‘pm’:
A    project/test
A    project/server
A    project/client
Checked out revision 1.  ( 測試提取成功 )

# cd project/server
# vim main.c
# svn add main.c
# svn commit main.c -m “測試一下我的C程式,看什麼看,不行啊??”
Adding         main.c
Transmitting file data .
Committed revision 2.  ( 測試提交成功 )

三,配置SVN伺服器的HTTP支援
1,轉換SVN伺服器的密碼
由於SVN伺服器的密碼是明文的,HTTP伺服器不與支援,所以需要轉換成HTTP支援的格式。我寫了一個Perl指令碼完成這個工作.
指令碼內容如下:
# cd /home/svn/project/conf/
# vim PtoWP.pl

#!/usr/bin/perl # write by huabo, 2009-11-20  use warnings; use strict;  #open the svn passwd file open (FILE, "passwd") or die ("Cannot open the passwd file!!!n");  #clear the apache passwd file open (OUT_FILE, ">webpasswd") or die ("Cannot open the webpasswd file!!!n"); close (OUT_FILE);  #begin foreach (<FILE>) { if($_ =~ m/^[^#].*=/) { $_ =~ s/=//; `htpasswd -b webpasswd $_`; } }# chmod +x PtoWP.pl
# ./PtoWP.pl
Adding password for user pm
Adding password for user server_group
Adding password for user client_group
Adding password for user test_group
現在目錄下會多一個webpasswd檔案。

2,修改httpd.conf,添加關於SVN伺服器的內容
編輯/etc/httpd/conf/httpd.conf,在最後添加如下資訊:

<Location /project>
DAV svn
SVNPath /home/svn/project/
AuthType Basic
AuthName "svn for project"
AuthUserFile /home/svn/project/conf/webpasswd
AuthzSVNAccessFile /home/svn/project/conf/authz
Satisfy all
Require valid-user
</Location>


3,修改svn目錄的屬主為apache帳號:chown -R apache.apache /home/svn/project/
(注意:原文少了這一步,會出許可權問題。)
4,重啟Web伺服器:
# /etc/init.d/httpd restart
Stopping httpd: [FAILED]
Starting httpd: [ OK ]

5,用瀏覽器訪問http://192.168.60.10/project/server/測試

 

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.