您的位置:首页 > 运维架构 > Apache

Svn安装与整合Apache

2010-02-10 23:14 471 查看
一 、Svn独立服务安装
ContOS AS 5
安装包获取:
wget http://subversion.tigris.org/downloads/subversion-1.6.5.tar.gz
wget http://subversion.tigris.org/downloads/subversion-deps-1.6.5.tar.gz
编译:
tar xfvz subversion-1.6.5.tar.gz
tar xfvz subversion-deps-1.6.5.tar.gz
subversion-deps包有四个目录zlib apr apr-util neon这四个目录都是依赖包,编译subversion所必须的代码
cd subversion-1.6.5
./configure --prefix=/opt/svn --without-berkeley-db --with-zlib=/usr
(注:以svnserve方式运行,不加apache编译参数。以fsfs格式存储版本库,不编译berkeley-db)
make clean
make
make install
测试:
svnserve –version
如果显示如下,安装成功:
svnserve, version 1.6.5 (r21228)
2. svn配置
建立版本库目录,可建多个:
mkdir -p /opt/svndata/repos
建立版本库:
svnadmin create /opt/svndata/repos
修改版本库配置文件:
vi /opt/svndata/repos/conf/svnserve.conf
[general]
anon-access = none
auth-access = write
password-db = /opt/svndata/repos/conf/pwd.conf
authz-db = /opt/svndata/repos/conf/authz.conf
realm = repos
配置允许访问的用户:
vi/opt/svndata/repos/conf/pwd.conf
注意:对用户配置文件的修改立即生效,不必重启svn。
文件格式如下:
[users]
<用户1> = <密码1>
<用户2> = <密码2>
其中,[users]是必须的。下面列出要访问svn的用户,每个用户一行。示例:
[users]
alan = password
king = hello
配置用户访问权限:
vi /opt/svndata/repos/conf/authz.conf
文件中定义用户组和版本库目录权限。
注意:
* 权限配置文件中出现的用户名必须已在用户配置文件中定义。
* 对权限配置文件的修改立即生效,不必重启svn。
用户组格式:
[groups]
<用户组名> = <用户1>,<用户2>
其中,1个用户组可以包含1个或多个用户,用户间以逗号分隔。
版本库目录格式:
[<版本库>:/项目/目录]
@<用户组名> = <权限>
<用户名> = <权限>
其中,方框号内部分可以有多种写法:
/,表示根目录及以下。根目录是svnserve启动时指定的,我们指定为/opt/svndata。这样,/就是表示对全部版本库设置权限。
repos1:/,表示对版本库1设置权限
repos2:/abc, ,表示对版本库2中的abc项目设置权限
repos2:/abc/aaa, ,表示对版本库2中的abc项目的aaa目录设置权限
权限主体可以是用户组、用户或*,用户组在前面加@,*表示全部用户。权限可以是w、r、wr和空,空表示没有任何权限。
示例:
[groups]
admin = alan
[/]
@admin = rw
[repos1:/abc/aaa]
king = rw
[repos2:/pass]
king =
3. 启动svn
建立启动svn的用户:
useradd svn
passwd svn
根据提示为用户svn设置密码
允许用户svn访问版本库:
chown -R svn:svn /opt/svndata
chown -R svn:svn /opt/data
启动svn:
svnserve -d –listen-port 9999 -r /opt/svndata
-d表示以daemon方式(后台运行)运行
–listen-port 9999表示使用9999端口,可以换成你需要的端口。
-r /opt/svndata指定根目录是/opt/svndata
检查:
ps -ef | grep svnserve
如果显示如下,即为启动成功:
svn    6941   1 0 15:07 ?    00:00:00 svnserve -d –listen-port 9999 -r /opt/svndata
二、svn服务与apache 整合
apache 需要开启webdav 功能
./configure --prefix=/usr/local/apache --enable-so --enable-dav=share --enable-dav-fs
tar xfvz subversion-1.6.5.tar.gz
tar xfvz subversion-deps-1.6.5.tar.gz
./configure --prefix=/usr/local/svn1 --with-apxs=/usr/local/apache/bin/apxs
查看个动态库有没有安装成功
vi /usr/local/apache/conf/httpd.conf
LoadModule dav_module modules/mod_dav.so
LoadModule dav_svn_module modules/mod_dav_svn.so
LoadModule authz_svn_module modules/mod_authz_svn.so
配置http.conf
vi /opt/apache/conf/httpd.conf
配置:
<Location /svn>
DAV svn
SVNParentPath /data/svn/ //svn父目录
AuthType Basic
AuthName "Subversion repository"
AuthUserFile /data/svn/passwd
AuthzSVNAccessFile /data/svn/auth
Require valid-user
</Location>
建立SVN存储仓库
#mkdir -p /data/svn/repos
#svnadmin create /data/svn/repos
备份以前的SVN库
#svnadmin dump /data/svn/repos > /root/repos
把备份出来的数据恢复到本地
#svnadmin load /data/svn/repos/ < /root/repos
建立本地访问控制文件
#/usr/local/apache/bin/htpasswd [-c] /data/svn/passwd north
//第一次设置用户时使用-c表示新建一个用户文件。
#/usr/local/apache/bin/htpasswd passwd 用户名(加入新的用户)
建立本地项目控制文件
touch /data/svn/auth
文件内容为:
[groups]
[repos:/]
#wxy = rw
north = rw
tom = rw

安装客户端TortoiseSVN,访问服务器
http://192.168.0.180/svn/repos
注意:SVN是APACHE配置的时候加上去的。
到此安装基本结束

三、日常维护命令和参数
启动svn服务
svnserve -d --listen-port 20000 -r /opt/svndata
创建版本库
svnadmin create fs-type fsfs /opt/svndata/mark
查看版本库的信息
svn list file:///opt/svndata/mark
svn list --verbose file:///opt/svndata/mark
导入库的目录结构
svn import /tmp/mark/ file:///opt/svndata/mark/ --message "init" (文件夹mark下有bo)

删除版本库mark下文件夹bo
svn delete svn://192.168.0.180:20000/opt/svndata/mark/bo -m "delete "
//导出
$svnlook youngest oldrepo
$svnadmin dump oldrepo >; dumpfile
//还原
$svnadmin load newrepo < dumpfile
停止subversion服务
ps –aux | grep svnserve
kill -9 ID号
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: