linux下搭建svn全指南
linux svn安装部署
使用yum search subversion获取需要安装的包
[root@localhost ~]# yum search subversion
subversion.i386 : Modern Version Control System designed to replace CVS
subversion-devel.i386 : Development package for Subversion developers.
subversion-javahl.i386 : JNI bindings to the Subversion libraries
subversion-perl.i386 : Perl bindings to the Subversion libraries
subversion-ruby.i386 : Ruby bindings to the Subversion libraries
依次安装以上的的subversion文件
yum install subversion subversion-devel subversion-javahl subversion-perl subversion-ruby
===========================================
安装完毕后,建立linux SVN创库文件
mkdir /svn
cd /svn
mkdir repos
svnadmin create repos
//付权限
chmod 755 /svn
======================================
编辑/svn/repos/conf/svnserve.conf
vi /svn/repos/conf/svnserve.conf
解开注释,记住这里的文件命令都必须抵头写,不能留空格,否则报错
anon-access = read
auth-access = write
password-db = passwd
authz-db = authz
============================================
vi /svn/repos/conf/passwd
user=pwd
如:tearsky=123456
用户:就是tearsky,密码就是123456
===============================
vi /svn/repos/conf/authz
追加下记文字
[groups]
# harry_and_sally = harry,sally
# harry_sally_and_joe = harry,sally,&joe
develop = zhuzhengling,zhangqiyu,zhangmengying,baoxiufen
# [/foo/bar]
# harry = rw
# &joe = r
# * =
# [repository:/baz/fuz]
# @harry_and_sally = rw
# * = r
[repos:/]
lisb=rw
@develop=rw
[/]
*=r
------------*=r 设置组,只有读取权限,可设置一个readTest=r,限制其他人访问svn,如果是rw表示可读可写
=======================================================
执行svnserve -d -r /svn/repos/ 启动服务
-d 启动,-r路径
==============================linux svn apache安装========================
svn安装同上
apache 安装
通过yum search httpd,找出需要安装的文件,
[root@TTenv conf.d]# yum search httpd
Loaded plugins: fastestmirror
Loading mirror speeds from cached hostfile
* base: mirrors.btte.net
* extras: mirrors.btte.net
* updates: mirrors.btte.net
=========================================================================== Matched: httpd ============================================================================
mod_ssl.x86_64 : SSL/TLS module for the Apache HTTP server
system-config-httpd.noarch : Apache configuration tool
centos-ds.x86_64 : CentOS Directory, Administration, and Console Suite
httpd.x86_64 : Apache HTTP Server
httpd-devel.i386 : Development tools for the Apache HTTP server.
httpd-devel.x86_64 : Development tools for the Apache HTTP server.
httpd-manual.x86_64 : Documentation for the Apache HTTP server.
mod_dav_svn.x86_64 : Apache server module for Subversion server.
yum install -y httpd....进行安装
[root@TTenv conf.d]# yum install -y mod_ssl system-config-httpd centos-ds httpd httpd-devel httpd-devel httpd-manual mod_dav_svn
安装完毕后,
新建用户
输入:htpasswd -c /svn/passwd.conf lisb 回车
输入两次密码
-c 只有文件不存在的时候才用,有这个文件了,就不用-c了,/svn新建的文件在/svn下面的passwd.conf,可以任意指定,lisb 里账号名字
如:创建新用户 htpasswd /svn/passwd.conf zhuzhengling
再复制/svn/repos/conf里面的authz文件到/svn下面,修改名字为authz.conf,也可以任意指定目录
cp /svn/repos/conf/authz /svn/authz.conf
authz.conf内容如下
[root@TTenv svn]# vi authz.conf
[groups]
dev_user=chenbs,lisb,zhuyt,tanggy,yangxz
#dev_user=lisb,zhuzhengling,zhangqiyu,baoxiufen,zhangmengying
[/]
@dev_user=rw
模块加载
//一般来说下面两个文件会自动弄好,不用我们管
打开/etc/httpd/conf.d/subversion.conf,这个文件中的如下两行取消注释。
LoadModule dav_svn_module modules/mod_dav_svn.so
LoadModule authz_svn_module modules/mod_authz_svn.so
相应的so文件已经自动copy到了APACHE/modules。这些工作就不用自己动手了。
版本库控制
[root@TTenv svn]# vi /etc/httpd/conf.d/subversion.conf
添加如下内容
<Location /svn/>#svn在访问的时候用到,http://ip/svn 3.DAV svn #不用修改
DAV svn
SVNParentPath /svn#资料库的绝对地址
SVNListParentPath on
AuthType Basic
AuthName "Subversion repository"
AuthzSVNAccessFile /svn/authz.conf#权限文件
AuthUserFile /svn/passwd.conf#账号文件
Require valid-user
</Location>
=========================
在这里就设置完成了
重启httpd
service httpd restart
==============================
注意事项
注意:
(1)单个版本库就是SVNPath /svn/svnroot/icec跟./svnadmin create /svn/svnroot/icec目录要一样,要不忙死你……【这个是对单个版本库】,多个版本库知道svn的主目录,
我这就是 SVNParentPath /svn/svnroot
(2)AuthzSVNAccessFile是权限控制文件,单个版本库不需要,多个版本库要设置不同版本库的权限
(3)目录svnroot目录的权限设置成755
四、验证安装
打开浏览器,输入地址为http://服务器ip/
出现登陆窗口,输入用户名跟密码,
如果可以正常打开如上页面则说明安装配置正常,可以正常使用了,在页面上可以看到由于目前资料库中没有内容,因此看到的内容为空。
五、导入数据到资料库
Cd /usr/local/subversion/bin
./svn import /要导入的目录 file:///svn/svnroot -m “说明文字”
重新打开浏览器,输入地址http://服务器ip/svn,输入用户名密码。
安装配置就完成了。
以下摘抄于http://www.dasairen.com/Centos/19023011232.html
六、可能遇到的问题
整个过程不会一帆风顺的,这里介绍一些可能遇到的问题。
1、【这个问题是我创建单个版本库时遇到的】安装好了后,浏览器打开http://服务器ip/svn,登陆出现不了页面,出现:
<D:error>
<C:error/> <m:human-readable errcode="2"> Could not open the requested SVN filesystem </m:human-readable> </D:error>
解决:这是httpd.conf里的<Locate svn>中的SVNPath指向错误没指到创建的资料库
2、输入账号密码提示不能认证,查看APACHE的/etc/httpd/logs/error_log,有如下提示:
[Tue Oct 05 18:07:09 2010] [error] [client 125.223.118.90] (13)Permission denied: Could not open password file: /svn/svnroot/passwd
[Tue Oct 05 18:07:09 2010] [error] [client 125.223.118.90] access to /svn failed, reason: verification of user id 'test' not configured
从日志看,因为检查过配置文件没有拼错,所以可以肯定是权限问题。从ls命令的结果可以看出,由于passwd的权限是没有问题的。
后来看了一位朋友的帖子【Linux环境下搭建APACHE+subversion+svnmanager】的启发,可能是SELinux引发的问题,
于是执行命令:
chcon -R -h -t httpd_sys_content_t /svn/svnroot
后来还是不行。执行以下命令后搞定
chcon -R -h -t httpd_sys_content_t /svn
总结教训:还是linux不熟悉的原因造成的,我是linux的新手。看来得恶补linux的基本知识。
3、组(group)设置
在TortoiseSVN中做Commit操作时可能遇到如下错误:
can't open file '/svn/svnroot/telnet/db/txn-current-lock': Permission denied
可以将telnet的所属组设置为APACHE
chgrp -R APACHE /svn/svnroot/telnet
4、文件夹创建删除属性
在TortoiseSVN中做Commit操作时可能遇到如下错误:
can't open '/svn/svnroot/telnet/db/tempfile.tmp': Permission denied
can't make directory '/svn/svnroot/telnet/dav/activities.d': Permission denied
设置telnet 群组的访问方式为“创建和删除文件”
5、The URI does not contain the name of a repository. [403, #190001
这个原因是因为httpd.conf文件里SVNParentPath
加上这行代码后必须在你的访问URL中访问你的SVN下的具体的库
如果开启父目录显示就不会有这个问题了,即加上SVNListParentPath on
还有意Location /svn/的svn后面有一条斜线。
//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
#停止 HTTPD服务
[root@zhangxx etc]# service httpd stop
停止 httpd:[ 确定 ]
#启动httpd服务
[root@zhangxx etc]# service httpd start
启动 httpd:[ 确定 ]
#重起HTTD服务
[root@zhangxx etc]# service httpd restart
停止 httpd:[ 确定 ]
启动 httpd:[ 确定 ]
#让httpd 在机器启动的时候在运行级别上停止
[root@zhangxx etc]# chkconfig --level 345 httpd off
[root@zhangxx etc]# chkconfig --list |grep httpd
httpd 0:关闭 1:关闭 2:关闭 3:关闭 4:关闭 5:关闭 6:关闭
#让httpd 在机器启动的时候在运行级别上启动
[root@zhangxx etc]# chkconfig --level 345 httpd on
[root@zhangxx etc]# chkconfig --list |grep httpd
httpd 0:关闭 1:关闭 2:关闭 3:启用 4:启用 5:启用 6:关闭
查看svnserve进程
ps -ef|grep svnserve
杀进程
killall svnserve
启动:
svnserve -d -r /svn/repos/
svnserve -d -r /svn/nj_repository/
查看httpd 进程
ps -ef|grep httpd
启动 httpd
service httpd stop
service httpd start
创建版本库
svnadmin create /svn/njsvnresource
svn import /home/oss file:///svn/nj_repository/jiashitong/oss -m "导入文件"
svnserve -d -r /svn/nj_repository/jiashitong --config-file=/svn/nj_repository/jiashitong/svnserve.conf
svnserve -d -r /data/svn --config-file=/data/svn/svnserve.conf
tail -200f /etc/httpd/logs/error_log
http://lesterlee.cn/?p=172
新增用户
编辑
/svn/authz.conf
htpasswd /svn/passwd.conf 用户名
killall svnserve
service httpd stop
svnserve -d -r /svn/repos/
service httpd start