linux下svn的安装和配置
《linux 下svn 的安装和配置》一、相关的几个安装包Apr : apr-1.3.8.tar.gz 和 apr-util-1.3.9.tar.gzApache : httpd-2.2.13.tar
《linux 下svn 的安装和配置》
一、相关的几个安装包
Apr : apr-1.3.8.tar.gz 和 apr-util-1.3.9.tar.gz
Apache : httpd-2.2.13.tar.gz
Subversion: subversion-1.5.6.tar.gz 和 subversion-deps-1.5.6tar.gz *说明: SVN 依赖的APR 版本要正确。
Apache 为2.0.x ,对应的APR 版本应为0.9.x ;
Apache 为2.2.x ,对应的APR 版本应为1.2.x 。
二、 安装步骤
1. 安装apr-1.3.8.tar.gz
# tar –zvxf apr-1.3.8.tar.gz (解压)
# cd apr-1.3.8 (进入apr…所在的目录)
# ./configure (安装不指定路径时 默认安装到/usr/local/apr) # make ; # make install (安装)
2. 安装 apr-util-1.3.9.tar.gz
# tar –zvxf apr-util-1.3.9.tar.gz
# cd apr-util-1.3.9
# ./configure - -with-apr=/usr/local/apr
# make ; # make install
3. 安装httpd-2.2.13.tar.gz
# tar xzvf httpd-2.2.6.tar.gz
# cd httpd-2.2.6
# ./configure --prefix=/usr/local/apache2
--enable-dav
--enable-modules=so
--enable-maintainer-mode
--enable-rewrite
--with-apr=/usr/local/apr/bin/apr-1-config
--with-apr-util=/usr/local/apr/bin/apu-1-config
# make # make install
,安装之后重新启动apache 服务:# /usr/local/apache2/bin/apachectl –k start / restart * apache的默认端口为80(更改端口号:/etc/…/)
4. 安装subversion
# tar –zvxf subversion-1.5.6.tar.gz
# tar –zvxf subversion-deps-1.5.6.tar.gz (这两个自动解压成一个包 subversion-1.5.6) # cd subversion-1.5.6
(如果linux 系统上已经装有apr 或者apr-util ,移除 apr 存在的版本,
subversion 解压 后的文件里有apr 相关的文件,需要移除)
# rm –rf apr
# rm -rf apr-util
说明:由于subversion-deps 包里的APR 是0.9.x 的,
因此编译svn 时要删除从deps 里解压出来的apr, apr-util,改而使用apache 2.2里提供的
# cd subversion-1.5.6
#./configure
--with-apxs=/usr/local/apache2/bin/apxs
--prefix=/usr/local/svn
--with-apr=/usr/local/apr/bin/apr-1-config
--with-apr-util=/usr/local/apr/bin/apu-1-config
--with-ssl
--with-zlib
--enable-maintainer-mode
#make ; #make install
(如果apache 不是安装在默认路径,configure 必須加上--with-apxs 选项, 如:./configure
--with-apxs=/usr/local/apache2/bin/apxs)
* configure可能存在的问题及解决方法
1. configure: error: could not find library containing RSA_new
-- yum install openssl-devel
2. configure: error: no XML parser was found: expat or libxml 2.x required
-- yum install expat-devel
3. configure: error: --with-zlib requires an argument.
-- 去掉此选项。
(如果: 执行了configure,make 后 make install时出错:
/bin/sh /usr/local/httpd-2.2.3/srclib/apr/libtool --mode=install /usr/bin/install -c -m 755 libaprutil-1.la /usr/local/apache2/lib
,libtool: install: error: cannot install `libaprutil-1.la' to a directory not ending in /usr/local/apache22/lib
make[2]: *** [install] Error 1
则在./configure 后
make clean
make
make install
)
确定一下svn 有没有安装成功
# /usr/local/svn/bin/svnserve --version
# vi /usr/local/apache2/conf/httpd.conf
看到下面两个模块说明安装成功
LoadModule dav_svn_module modules/mod_dav_svn.so
LoadModule authz_svn_module modules/mod_authz_svn.so
5. 开始建立版本库
/usr/local/svn/bin/svnadmin create /svn/project/www (创建仓库"www" )
ls /svn/project/www (查看有没有创建好, 如果多了一些文件则说明版本库已经创建好) (如果出现“无法创建顶级目录”的错误,请先
cd /
mkdir svn
)
导入项目文件到版本库
/usr/local/svn/bin/svn import /home/test file:///svn/project/www -m "init"
这条语句将把路径/share/www下找到的项目文件导入到你创建的/svn/project/www 仓库中去,提交后的修订版为1
配置提高svn 版本库的安全性
chmod –R 700 /svn/project/www (不让其他人有该目录的权限)
注意:直接这么chmod 会导致svn 客户端无法访问, 同时需要修改apache 配置文件./conf/httpd.conf文件,(如果你的水平不够高的话, 这一步可以先跳过, 以免给自己找麻烦! 等把服务完全搞定后再来进一步提高安全性) 在httpd.conf 文件中有这么一段内容: User daemon
Group daemon
,把上述内容改成:
User apache
Group apache
(我的系统在安装apache 的时候, 自动增加了apache 用户和apache 组, 如果你系统没有这个用户和组, 则请自己添加该用户和组)
修改svn 仓库的所有者
chown -R apache:apache /svn/project
6. Apache配置:
配置步骤
1 单资源库,如果打算只建立一个资源库,用这种方式。打开命令提示符,输入svnadmin create E:ResourcesSVNRepositories�A,回车。其中
E:ResourcesSVNRepositories�A为你的资源库路径。
2 多资源库,如果要创建多个资源库,用这种方式。打开命令提示符,输入svnadmin create E:ResourcesSVNRepositories�A,回车;输入三vsndmin
create E:ResourcesSVNRepositories�B,回车...
首先应保证Apache 能正常运行。将SVN 根目录的bin 目录下的mod_dav_svn.so和 mod_authz_svn.so两个文件拷贝到Apache 根目录下的modules 目录下;
打开Apache 配置文件httpd.conf ,找到
#LoadModule dav_fs_module modules/mod_dav_fs.so
#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
在文件末尾加上
如果是单资源库:
DAV svn
SVNPath E:¥Resources¥SVN¥Repositories
AuthType Basic
AuthName "Subversion Reporsitory"
,AuthUserFile E:¥Resources¥SVN¥conf¥passwd
AuthzSVNAccessFile E:¥Resources¥SVN¥conf¥authz
Require valid-user
如果是多资源库:
DAV svn
SVNListParentPath on
SVNParentPath E:¥Resources¥SVN¥Repositories
AuthType Basic
AuthName "Subversion Reporsitory"
AuthUserFile E:¥Resources¥SVN¥conf¥passwd
AuthzSVNAccessFile E:¥Resources¥SVN¥conf¥authz
Require valid-user
( 其中:
重启Apache ,查看Apache Service Monitor状态栏是否包含“SVN/1.6.0 DAV/2”字样。在浏览器中输入http://******/svn/(其中******为你的主机域名地址或者IP 地址),验证配置。)
方法1:配置svn 权限管理
1). 添加用户:
# /usr/local/apache/bin/htpasswd –c /svn/passwd user1
第一次设置用户时使用-c 表示新建一个用户文件。回车后输入用户密码,完成对用户的增加, 第二次添加用户不需要带-c 参数
2). 权限分配:
vi /svn/auth.conf (进入文件auth.conf ,对其进行编辑)
,[groups]
Admin=usr1,user2 (这个表示admin 群组里的成员 user1,user2)
Develop=u1, u2 (这个表示Develop 群组里的成员 u1,u2)
[www:/] (这表示,仓库www 的根目录下的访问权限)
user1 = rw (www 仓库user1用户具有读和写权限)
user2 = r ( www 仓库userl 用户具只有读权限)
@develop=rw (这表示 群 develop 的成员都具有读写权限)
[/] (这个表示在所有仓库的根目录下)
* = r (这个表示对所有的用户都具有读权限)
注意:在编辑authz.conf 文件时,所有行都必须要顶头写,否则会报错
3). 配置提高svn 版本库的安全性
chmod –R 700 /svn/project/www (不让其他人有该目录的权限)
注意:直接这么chmod 会导致svn 客户端无法访问, 同时需要修改apache 配置文件./conf/httpd.conf文件, 在httpd.conf 文件中有这么一段内容:
User daemon
Group daemon
把上述内容改成:
User apache
Group apache
(我的系统在安装apache 的时候, 自动增加了apache 用户和apache 组, 如果你系统没有这个用户和组, 则请自己添加该用户和组)
修改svn 仓库的所有者
chown -R apache:apache /svn/project
方法2:配置svn 权限管理(即authz.conf 的配置)
1. 添加用户:
/usr/local/apache/bin/htpasswd –c /svn/passwd user1
第一次设置用户时使用-c 表示新建一个用户文件。回车后输入用户密码,完成对用户的增加,第二次添加用户不需要带-c 参数
2. 权限分配:
vi /svn/auth.conf (进入文件auth.conf ,对其进行编辑)
,[groups]
Admin=usr1,user2 (这个表示admin 群组里的成员 user1,user2)
Develop=u1, u2 (这个表示Develop 群组里的成员 u1,u2)
[www:/] (这表示,仓库www 的根目录下的访问权限)
user1 = rw (www 仓库user1用户具有读和写权限)
user2 = r ( www 仓库userl 用户具只有读权限)
@develop=rw (这表示 群 develop 的成员都具有读写权限)
[/] (这个表示在所有仓库的根目录下)
* = r (这个表示对所有的用户都具有读权限)
注意:在编辑authz.conf 文件时,所有行都必须要顶头写,否则会报错
7、重启apache 服务和启动svn 服务
/usr/local/apache/bin/apachectl –k restart
就可以通过 http://192.168.18.110/svn/project/www 这个URL 来访问仓库了,当然,受权限的限制,必须是合法用户才能访问且具有相应的权限
客户端
windows 客户端用TortoiseSVN-1.4.4.9706-win32-svn-1.4.4.msi 也许有更高版本,我没有测试
Eclipse 插件:software update > url=http://subclipse.tigris.org/update_1.0.x
注意:
如果输入用户名密码后出现:
Could not open the request SVN filesystem
请检查你的/usr/local/apache/conf/httpd.conf 是否正确
如果客户端出现:
org.tigris.subversion.javahl.clientexception ra layer request failed
请检查你的url.username password
如果系统时间和现实时间相差太大,可能会导致安装出问题,修改系统时间的命令: Date –s (修改linux 系统时间)
,访问过程中出现的两个问题:
1. svn: Can‟t create directory „/subversion/main/db/transactions/0-1.txn‟: Permission denied
解答:设置svn 配置库库文件夹的权限(chmod -R 777 /svn/project/www) 2. Error: 服务器发送了意外的返回值(403 Forbidden),在响应 “CHECKOUT” 的请求
[Linux]svn服务的安装和启动设置
在CentOS 系统下,使用以下命令进行SVN 服务的安装
# yum -y install subversion
安装完毕后,svnserve 服务就被添加到了系统的自动启动进程里面,但是尚未开启,所以依然无法随系统自动启动服务。为了安全起见,我们需要修改SVN 服务端口,及自定义版本库所在目录。所以需要对以下文件进行相应的修改。
# vi /etc/rc.d/init.d/svnserve
找到以下内容
pidfile=${PIDFILE-/var/run/svnserve.pid}
lockfile=${LOCKFILE-/var/lock/subsys/svnserve}
args="--daemon --pid-file=${pidfile} $OPTIONS"
修改为
pidfile=${PIDFILE-/var/run/svnserve.pid}
lockfile=${LOCKFILE-/var/lock/subsys/svnserve}
logfile=/var/log/svnserve.log
args="--daemon --root /storage/repos --listen-port 621 --pid-file=${pidfile} --log-file=${logfile} $OPTIONS"
--root 是版本库所在的目录
--listen-port 是SVN 服务端口号
--log-file 是SVN 日志文件
修改完成后使用以下命令将自动跟随系统启动功能进行激活
# chkconfig svnserve on
也可以使用以下方式进行手工操作
# service svnserve start 启动服务
# service svnserve stop 停止服务
# service svnserve restart 重启服务