CentOS 5.5下搭建部署独立SVN服务器全程详解
SVN服务器有2种运行方式:
1、独立服务器(例如:svn://xxx.com/xxx);
2、借助apache(例如:http://svn.xxx.com/xxx);
为了不依赖apache,我选择第一种方式:独立的svn服务器。
SVN存储版本数据也有2种方式:
1、bdb;
2、fsfs。
由于bdb方式在服务器中断时,有可能锁住数据,所以还是fsfs方式更安全一点,我也选择这种方式。
具体部署:
1.下载subversion安装包[root@server ~]# cd /usr/local/src [root@serversrc]#ls [root@serversrc]#wgethttp://subversion.tigris.org/downloads/subversion-1.6.6.tar.gz [root@serversrc]#wgethttp://subversion.tigris.org/downloads/subversion-deps-1.6.6.tar.gz [root@serversrc]#tarxfvzsubversion-1.6.6.tar.gz [root@serversrc]#tarxfvzsubversion-deps-1.6.6.tar.gz [root@serversrc]#cdsubversion-1.6.6 [root@server subversion-1.6.6]# |
2.编译SVN
首先检测系统有没有安装SSL:
找不到,就执行如下命令进行安装:
[root@server subversion-1.6.6]# yum install openssl [root@server subversion-1.6.6]# yum install openssl-devel |
安装之后用find / -name opensslv.h命令找到opensslv.h所在的目录,即下列--with-openssl=后面的路径,编译:
[root@server subversion-1.6.6]# find / -name opensslv.h /usr/include/openssl/opensslv.h [root@server subversion-1.6.6]# ./configure --prefix=/usr/local/svn --with-openssl=/usr/include/openssl --without-berkeley-db |
注:以svnserve方式运行,不加apache编译参数。以fsfs格式存储版本库,不编译berkeley-db。
此时编译报如下错误:
configure:ConfiguringSubversion1.6.6
configure:creatingconfig.nice
checkingforgcc...no
checkingforcc...no
checkingforcl.exe...no
configure:error:in`/usr/local/src/subversion-1.6.6':
configure:error:noacceptableCcompilerfoundin$PATH
See `config.log' for more details.说明没有安装gcc相关库,使用如下命令安装gcc后再编译:
[root@server subversion-1.6.6]# yum -y install gcc [root@server subversion-1.6.6]# ./configure --prefix=/usr/local/svn --with-openssl=/usr/include/openssl --without-berkeley-db |
最后出现下面WARNING,直接忽略即可,因为不使用BDB存储。
configure: WARNING: we have configured without BDB filesystem support Youdon'tseemtohaveBerkeleyDBversion4.0.14ornewer installedandlinkedtoAPR-UTIL.WehavecreatedMakefileswhich willbuildwithouttheBerkeleyDBback-end;yourrepositorieswill useFSFSasthedefaultback-end.Youcanfindthelatestversionof BerkeleyDBhere: http://www.sleepycat.com/download/index.shtml |
3.安装SVN为避免出现以下错误
error while loading shared libraries: libiconv.so.2: cannot open shared object file: No such file or directory |
先执行以下操作:1)、编辑/etc/ld.so.conf文件,添加下面一行:
/usr/local/lib |
2)、保存后运行ldconfig:
/sbin/ldconfig |
注:ld.so.conf和ldconfig用于维护系统动态链接库。
安装
[root@server subversion-1.6.6]# make && make install |
安装完成,执行以下命令测试:
[root@server subversion-1.6.6]# /usr/local/svn/bin/svnserve --version svnserve,版本1.6.6(r40053) 编译于 Feb 15 2012,22:15:26版权所有 (C) 2000-2009 CollabNet。 Subversion是开放源代码软件,请参阅http://subversion.tigris.org/站点。 此产品包含由 CollabNet(http://www.Collab.Net/) 开发的软件。下列版本库后端(FS) 模块可用: * fs_fs : 模块与文本文件(FSFS)版本库一起工作。 |
为了方便下操作,下面将SVN的BIN添加到PATH,编辑/etc/profile,添加:
PATH=/usr/local/svn/bin:$PATH |
保存后,使其立即生效:
source /etc/profile |
4.配置SVN建立版本库目录,可建多个:
[root@server ~]# mkdir -p /home/svndata/repos #建立版本库[root@server ~]# /usr/local/svn/bin/svnadmin create /home/svndata/repos #修改版本库配置文件 |
编辑/home/svndata/repos/conf/svnserve.conf,内容修改为:
[general] anon-access=none auth-access=write password-db=/usr/local/svn/conf/passwd.conf authz-db=/usr/local/svn/conf/authz.conf realm = repos |
注意:对用户配置文件的修改立即生效,不必重启svn。在/usr/local/svn/下面新建conf目录,并在/usr/local/svn/conf内新建passwd.conf和authz.conf文件:
mkdir conf cdconf/ touchpasswd.conf touch authz.conf |
添加用户及密码:
[root@server ~]# useradd wll[root@server ~]# passwd wll |
编辑/usr/local/svn/conf/passwd.conf,添加如下代码并保存:
[users] wll = 123456 |
配置svn用户访问权限,编辑usr/local/svn/conf/authz.conf,添加如下代码并保存:
[groups] admin=wll [/] @admin=rw #[repos:/abc/aaa] #king=rw #[repos:/pass] #king=svn 注意: *权限配置文件中出现的用户名必须已在用户配置文件中定义。 *对权限配置文件的修改立即生效,不必重启svn。 用户组格式: [groups] =, 其中,1个用户组可以包含1个或多个用户,用户间以逗号分隔。 版本库目录格式: [<版本库>:/项目/目录] @<用户组名>=<权限> <用户名>=<权限> 其中,方框号内部分可以有多种写法: [/],表示根目录及以下,根目录是svnserve启动时指定的,我们指定为/home/svndata,[/]就是表示对全部版本库设置权限。 [repos:/]表示对版本库repos设置权限; [repos:/abc]表示对版本库repos中的abc项目设置权限; [repos:/abc/aaa]表示对版本库repos中的abc项目的aaa目录设置权限; 权限主体可以是用户组、用户或*,用户组在前面加@,*表示全部用户。 权限可以是w、r、wr和空,空表示没有任何权限。 |
建立启动svn的用户:
[root@server ~]# useradd svn [root@server ~]# passwd svn |
允许用户svn访问版本库:
[root@server ~]# chown -R svn:svn /home/svndata |
启动svn:
[root@server ~]# su - svn -c "svnserve -d --listen-port 9999 -r /home/svndata" 其中: su-svn:表示以用户svn的身份启动svn; -d:表示以daemon方式(后台运行)运行; --listen-port9999:表示使用9999端口,可以换成你需要的端口。但注意,使用1024以下的端口需要root权限; -r /home/svndata :指定根目录是/home/svndata。 |
5.将svn加入到开机启动编辑/etc/rc.d/rc.local文件,加入如下启动命令:
/usr/local/svn/bin/svnserve -d --listen-port 9999 -r /home/svndata |
如果想停止svn,则使用如下命令:
killall svnserve |
如果想将svn作为服务,在/etc/rc.d/init.d/目录下新建名为svn的文件并设置权限为755,并添加如下代码:
#!/bin/bash #buildthisfilein/etc/rc.d/init.d/svn #chmod755/etc/rc.d/init.d/svn #centos下可以用如下命令管理svn:servicesvnstart(restart/stop) SVN_HOME=/home/svndata if[!-f"/usr/local/svn/bin/svnserve"] then echo"svnserverstartup:cannotstart" exit fi case"$1"in start) echo"Startingsvnserve..." /usr/local/svn/bin/svnserve-d--listen-port9999-r$SVN_HOME echo"Finished!" ;; stop) echo"Stopingsvnserve..." killallsvnserve echo"Finished!" ;; restart) $0stop $0start ;; *) echo"Usage:svn{start|stop|restart}" exit1 esac |
6.连接SVN安装TortoiseSVN,重启系统。启动TortoiseSVN并在地址栏中输入
svn://192.168.1.87:9999/repos 根据提示输入用户名与密码后就可以
原始出处 :http://300second.blog.51cto.com/7582/780348
相关推荐
pub_svnserve.conf的 pub_authz.conf的配置文件有非法字符的原因引起,需要查找pub_authz.conf提的非法内容比如多余的空格删除或直接将pub_authz.conf