Linux安裝並配置SVN服務器

1. 安裝SVN服務器:

檢查是否已安裝

# rpm -qa subversion

安裝SVN服務器

# yum install httpd httpd-devel subversion mod_dav_svn mod_auth_mysql

驗證安裝

# cd /etc/httpd/modules
# ls | grep svn
mod_authz_svn.so
mod_dav_svn.so

查看版本

# svnserve --version

 

2. 代碼庫創建:

安裝完成後要建立SVN庫

# mkdir -p /opt/svn/repositories
# svnadmin create /opt/svn/repositories

執行後,自動建立repositories庫,查看/opt/svn/repositories文件夾包含了conf,db,format,hooks,locks,README.txt等文件,說明一個SVN庫已經建立。

 

3. 配置版本庫:

進入上面conf文件夾下,進行配置:

a. 用戶密碼passwd配置:

# vi + passwd  //+表示光標放在文件最低端

修改passwd爲一下內容:

[users]
# harry = harryssecret
# sally = sallyssecret
zhoulf=123456

 

b. 權限控制authz配置:

# vi + authz

設置哪些用戶可以訪問哪些目錄,向authz文件追加以下內容:

[/]
zhoulf=rw  //給該用戶訪問所有庫的權限
 或
[repositories:/project]  //repository庫的根目錄權限
zhoulf=rw

/ 表示根目錄及以下,根目錄是svnserve啓動時指定的,我們指定的是/opt/svn;/ 就是指對全部版本庫都具有權限

repositories:/ 表示對庫repositories的根目錄設置權限

PS:

* 權限配置文件中出現的用戶名必須已在用戶配置文件中定義。

* 對權限配置文件的修改立即生效,不必重啓svn。

 

c. 服務svnserve.con配置:

# vi + svnserve.conf

添加一下內容:

複製代碼

[general]
#匿名訪問的權限,可以是read,write,none,默認爲read
anon-access=none
#使授權用戶有寫權限
auth-access=write
#密碼數據庫的路徑
password-db=passwd
#訪問控制文件
authz-db=authz
#認證命名空間,subversion會在認證提示裏顯示,並且作爲憑證緩存的關鍵字
realm=/opt/svn/repositories

複製代碼

這裏注意各標籤不能錯,也不能有重複,不然無法連接。

 

d. 配置防火牆端口(如果需要):

不一定每個人都需要設置,可以先測試後再看是否需要打開端口

# vi /etc/sysconfig/iptables

添加一下內容:

-A INPUT -m state --state NEW -m tcp -p tcp --dport 3690 -j ACCEPT

保存後重啓防火牆

# service iptables restart

 

4. 查看:

a. 啓動SVN

# svnserve -d -r /opt/svn/repositories

 

b. 查看SVN進程

# ps -ef|grep svn|grep -v grep
root 12538 1 0 14:40 ? 00:00:00 svnserve -d -r /opt/svn/repositories

 

c. 檢測SVN端口

# netstat -ln |grep 3690
tcp 0 0 0.0.0.0:3690 0.0.0.0:* LISTEN

 

5. 停止重啓SVN:

# killall svnserve //停止
# svnserve -d -r /opt/svn/repositories // 啓動

 

6. 測試連接:

使用TortoiseSVN進行測試:

1. SVN服務啓動後,需要使用客戶端測試連接:

    客戶端連接地址:svn://192.168.15.231;然後,輸入用戶名密碼;

2. 新建一個文件夾,即本地的庫文件夾,右鍵checkout,將會得到一個隱藏文件夾.svn;

3. 在此文件夾中放入項目內容,然後右鍵點擊commit,就可以上傳本地項目了。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章