su - svn -c "svnserve -d --listen-port 3690 -r /home/svn/svndata/xiyouji"
測(cè)試:
svnserve –version
如果顯示如下,安裝成功:
svnserve, version 1.4.0 (r21228)
compiled Oct 12 2006, 10:18:56
Copyright (C) 2000-2006 CollabNet.
Subversion is open source software, see http://subversion.tigris.org/
This product includes software developed by CollabNet (http://www.Collab.Net/).
The following repository back-end (FS) modules are available:
* fs_fs : Module for working with a plain file (FSFS) repository.
2. svn配置
建立版本庫(kù)目錄,可建多個(gè):
mkdir -p /opt/svndata/repos1
mkdir -p /opt/svndata/repos2
建立版本庫(kù):
svnadmin create /opt/svndata/repos1
svnadmin create /opt/svndata/repos2
修改版本庫(kù)配置文件:
版本庫(kù)1:
vi /opt/svndata/repos1/conf/svnserve.conf
內(nèi)容修改為:
[general]
anon-access = none
auth-access = write
password-db = /opt/svn/conf/pwd.conf
authz-db = /opt/svn/conf/authz.conf
realm = repos1
版本庫(kù)2:
vi /opt/svndata/repos2/conf/svnserve.conf
內(nèi)容修改為:
[general]
anon-access = none
auth-access = write
password-db = /opt/svn/conf/pwd.conf
authz-db = /opt/svn/conf/authz.conf
realm = repos2
即除realm = repos2外,其他與版本庫(kù)1配置文件完全相同。如果有更多的版本庫(kù),依此類推。
配置允許訪問(wèn)的用戶:
vi /opt/svn/conf/pwd.conf
為了簡(jiǎn)化配置,2個(gè)版本庫(kù)共用1個(gè)用戶配置文件。如有必要,也可以分開(kāi)。
注意:對(duì)用戶配置文件的修改立即生效,不必重啟svn。
文件格式如下:
[users]
<用戶1> = <密碼1>
<用戶2> = <密碼2>
其中,[users]是必須的。下面列出要訪問(wèn)svn的用戶,每個(gè)用戶一行。示例:
[users]
alan = password
king = hello
配置用戶訪問(wèn)權(quán)限:
vi /opt/svn/conf/authz.conf
為了簡(jiǎn)化配置,3個(gè)版本庫(kù)共用1個(gè)權(quán)限配置文件/opt/svn/conf/pwd.conf。如有必要,也可以分開(kāi)。文件中定義用戶組和版本庫(kù)目錄權(quán)限。
注意:
* 權(quán)限配置文件中出現(xiàn)的用戶名必須已在用戶配置文件中定義。
* 對(duì)權(quán)限配置文件的修改立即生效,不必重啟svn。
用戶組格式:
[groups]
<用戶組名> = <用戶1>,<用戶2>
其中,1個(gè)用戶組可以包含1個(gè)或多個(gè)用戶,用戶間以逗號(hào)分隔。
版本庫(kù)目錄格式:
[<版本庫(kù)>:/項(xiàng)目/目錄](méi)
@<用戶組名> = <權(quán)限>
<用戶名> = <權(quán)限>
其中,方框號(hào)內(nèi)部分可以有多種寫(xiě)法:
/,表示根目錄及以下。根目錄是svnserve啟動(dòng)時(shí)指定的,我們指定為/opt/svndata。這樣,/就是表示對(duì)全部版本庫(kù)設(shè)置權(quán)限。
repos1:/,表示對(duì)版本庫(kù)1設(shè)置權(quán)限
repos2:/occi, ,表示對(duì)版本庫(kù)2中的occi項(xiàng)目設(shè)置權(quán)限
repos2:/occi/aaa, ,表示對(duì)版本庫(kù)2中的occi項(xiàng)目的aaa目錄設(shè)置權(quán)限
權(quán)限主體可以是用戶組、用戶或*,用戶組在前面加@,*表示全部用戶。權(quán)限可以是w、r、wr和空,空表示沒(méi)有任何權(quán)限。
示例:
[groups]
admin = alan
[/]
@admin = rw
[repos1:/occi/aaa]
king = rw
[repos2:/pass]
king =
刪除無(wú)用文件:
rm /opt/svndata/repos1/conf/authz
rm /opt/svndata/repos1/conf/passwd
rm /opt/svndata/repos2/conf/authz
rm /opt/svndata/repos2/conf/passwd
3. 啟動(dòng)svn
建立啟動(dòng)svn的用戶:
useradd svn
passwd svn
根據(jù)提示為用戶svn設(shè)置密碼
允許用戶svn訪問(wèn)版本庫(kù):
chown –R svn:svn /opt/svndata
chown –R svn:svn /opt/data
啟動(dòng)svn:
su - svn -c "svnserve -d --listen-port 9999 -r /opt/svndata"
其中:
su – svn表示以用戶svn的身份啟動(dòng)svn
-d表示以daemon方式(后臺(tái)運(yùn)行)運(yùn)行
--listen-port 9999表示使用9999端口,可以換成你需要的端口。但注意,使用1024以下的端口需要root權(quán)限
-r /opt/svndata指定根目錄是/opt/svndata
檢查:
ps –ef|grep svnserve
如果顯示如下,即為啟動(dòng)成功:
svn 6941 1 0 15:07 ? 00:00:00 svnserve -d --listen-port 9999 -r /opt/svndata