*********安装apr
[root@os11728 src]# wget http://mirror.bjtu.edu.cn/apache//apr/apr-1.4.5.tar.gz
[root@os11728 src]# tar -zxvf apr-1.4.5.tar.gz
[root@os11728 src]# cd apr-1.4.5
[root@os11728 apr-1.4.5]# ./configure –prefix=/usr/local/apr
[root@os11728 apr-1.4.5]# make
[root@os11728 apr-1.4.5]# make install
[root@os11728 apr-1.4.5]# cat /etc/ld.so.conf
[root@os11728 apr-1.4.5]# echo /usr/local/apr/lib >> /etc/ld.so.conf
*********安装apr-util
[root@os11728 src]# wget http://mirror.bjtu.edu.cn/apache//apr/apr-util-1.3.12.tar.gz
[root@os11728 src]# tar -zxvf apr-util-1.3.12.tar.gz
[root@os11728 src]# cd apr-util-1.3.12
[root@os11728 apr-util-1.3.12]# ./configure –prefix=/usr/local/apr-util –with-apr=/usr/local/apr
[root@os11728 apr-util-1.3.12]# make
[root@os11728 apr-util-1.3.12]# make install
[root@os11728 apr-util-1.3.12]# echo /usr/local/apr-util/lib >> /etc/ld.so.conf
[root@os11728 apr-util-1.3.12]# ldconfig -v
1.1. 安装基本组件(libxml、openssl)
[root@os11728 src]# yum check-update
[root@os11728 src]# yum -y update
[root@os11728 src]# yum clean packages
[root@os11728 src]# yum -y install libxml* openssl openssl-devel
1.2. 安装 sqlite
[root@os11728 src]# wget http://www.sqlite.org/sqlite-autoconf-3070800.tar.gz
[root@os11728 src]# tar -zxvf sqlite-autoconf-3070800.tar.gz
[root@os11728 src]# cd sqlite-autoconf-3070800
[root@os11728 sqlite-autoconf-3070800]# ./configure –prefix=/usr/local/sqlite
[root@os11728 sqlite-autoconf-3070800]# make
[root@os11728 sqlite-autoconf-3070800]# make install
1.3. 安装 neon
(不需要支持http协议可以略掉此安装)
[root@os11728 src]# wget http://www.webdav.org/neon/neon-0.29.6.tar.gz
[root@os11728 src]# tar -zxvf neon-0.29.6.tar.gz
[root@os11728 src]# cd neon-0.29.6
[root@os11728 neon-0.29.6]# ./configure –prefix=/usr/local/neon –with-ssl=openssl
[root@os11728 neon-0.29.6]# make
[root@os11728 neon-0.29.6]# make install
1.4. 安装Subversion
[root@os11728 src]# wget http://ftp.cuhk.edu.hk/pub/packages/apache.org/subversion/subversion-1.7.5.tar.gz
[root@os11728 src]# tar -zxvf subversion-1.7.5.tar.gz
[root@os11728 src]# cd subversion-1.7.5
[root@os11728 src]# mkdir /usr/local/src/subversion-1.7.5/sqlite-amalgamation
[root@os11728 src]# cp /usr/local/src/sqlite-autoconf-3070800/sqlite3.c /usr/local/src/subversion-1.7.5/sqlite-amalgamation/sqlite3.c
[root@os11728 subversion-1.7.5]# ./configure –prefix=/usr/local/subversion –with-apxs=/usr/local/apache2/bin/apxs –with-apr=/usr/local/apache2 –with-apr-util=/usr/local/apache2 –with-ssl –with-zlib=/usr/local/zlib –enable-maintainer-mode –without-berkeley-db –enable-mod-activation –with-neon=/usr/local/neon –enable-shared
[root@os11728 subversion-1.7.5]# make clean
[root@os11728 subversion-1.7.5]# make
[root@os11728 subversion-1.7.5]# make install
在编译安装subvision时,提示configure: error: Subversion requires SQLite,原因是需要依赖Sqlite。
解决方法:下载sqlite-3.6.13 ,解压后,进入sqlite目录,复制sqlite3.c到subvision源码文件sqlite-amalgamation目录下,如果没有sqlite-amalgamation目录,手动新建一个即可。
在make subvision时,出现以下错误提示:
/usr/local/src/neon-0.29.6/src/ne_auth.c:781: undefined reference to `ne__ntlm_destroy_context’
/usr/local/src/neon-0.29.6/src/ne_auth.c:785: undefined reference to `ne__ntlm_create_context’
collect2: ld returned 1 exit status
make: *** [subversion/libsvn_ra_neon/libsvn_ra_neon-1.la] Error 1
解决方法:修改/usr/local/src/neon-0.29.6/src/Makefile,将CFLAGS = -g -O2 -prefer-pic 改成 CFLAGS = -fPIC -g -O2,然后重新编译neon,接着再重新编译subversion即可。
添加Subversion的环境变量
[root@os11728 subversion-1.7.5]# vi /etc/profile
在最后加上如下一行代码:
将其打开把
export PATH=$PATH:/usr/local/subversion/bin
这句放在“export PATH USER LOGNAME MAIL HOSTNAME HISTSIZE INPUTRC”的上一行
立即生效环境配置,不需要重启,用下命令:
[root@os11728 subversion-1.7.5]# . /etc/profile
测试SVN是否安装成功:
[root@os11728 ~]#svn –version
显示以下信息:
svn: /usr/lib/libz.so.1: no version information available (required by /usr/local/subversion/lib/libsvn_delta-1.so.0)
svn, version 1.7.1 (r1186859)
compiled Oct 25 2011, 11:24:55
Copyright (C) 2011 The Apache Software Foundation.
This software consists of contributions made by many people; see the NOTICE
file for more information.
Subversion is open source software, see http://subversion.apache.org/
The following repository access (RA) modules are available:
* ra_neon : Module for accessing a repository via WebDAV protocol using Neon.
- handles ‘http’ scheme
* ra_svn : Module for accessing a repository using the svn network protocol.
- with Cyrus SASL authentication
- handles ‘svn’ scheme
* ra_local : Module for accessing a repository on local disk.
- handles ‘file’ scheme
表明安装成功,但出现了错误提示:svn: /usr/lib/libz.so.1: no version information available (required by /usr/local/subversion/lib/libsvn_delta-1.so.0)
这是libsvn_delta-1.so.0依赖的库/usr/lib/libz.so.1不可用导致的。错误追踪:
[root@www ~]# cd /usr/lib
[root@www lib]# ll libz*
-rwxr-xr-x 1 root root 92598 Jan 10 2007 libz.a
lrwxrwxrwx 1 root root 13 Apr 20 2010 libz.so -> libz.so.1.2.3
lrwxrwxrwx 1 root root 13 Oct 13 14:45 libz.so.1 -> libz.so.1.2.3
-rwxr-xr-x 1 root root 75028 Jan 10 2007 libz.so.1.2.3
[root@www lib]# ldd libz.so.1.2.3
linux-gate.so.1 => (0x00d8f000)
libc.so.6 => /lib/libc.so.6 (0x00c0f000)
/lib/ld-linux.so.2 (0x00bec000)
从上可以看到libz.so.1软链接到libz.so.1.2.3,libz.so.1.2.3是zlib-1.2.3生成的库,该库可能已被删除,而我已安装的zlib-1.2.5,见:
[root@www lib]# cd /usr/local/zlib/lib
[root@www lib]# ls
libz.a libz.so libz.so.1 libz.so.1.2.5 pkgconfig
[root@www lib]# ll libz*
-rw-r–r– 1 root root 101462 Oct 13 14:43 libz.a
lrwxrwxrwx 1 root root 13 Oct 13 14:43 libz.so -> libz.so.1.2.5
lrwxrwxrwx 1 root root 13 Oct 13 14:43 libz.so.1 -> libz.so.1.2.5
-rwxr-xr-x 1 root root 95004 Oct 13 14:43 libz.so.1.2.5
[root@www lib]# ldd libz.so.1.2.5
linux-gate.so.1 => (0x002f8000)
libc.so.6 => /lib/libc.so.6 (0×00134000)
/lib/ld-linux.so.2 (0x00bec000)
故可将/usr/lib/libz.so.1重新链接至/usr/local/zlib/lib/libz.so.1.2.5,如下:
[root@www lib]# cp /usr/lib/libz.so.1 /usr/lib/libz.so.1.bak
[root@www lib]# cp /usr/local/zlib/lib/libz.so.1.2.5 /usr/local/zlib/lib/libz.so.1.2.5.bak
[root@www lib]# ln -fs /usr/local/zlib/lib/libz.so.1.2.5 /usr/lib/libz.so.1
再次查看SVN版本信息:
[root@www lib]# svn –version
svn, version 1.7.1 (r1186859)
compiled Oct 25 2011, 11:24:55
Copyright (C) 2011 The Apache Software Foundation.
This software consists of contributions made by many people; see the NOTICE
file for more information.
Subversion is open source software, see http://subversion.apache.org/
The following repository access (RA) modules are available:
* ra_neon : Module for accessing a repository via WebDAV protocol using Neon.
- handles ‘http’ scheme
* ra_svn : Module for accessing a repository using the svn network protocol.
- with Cyrus SASL authentication
- handles ‘svn’ scheme
* ra_local : Module for accessing a repository on local disk.
- handles ‘file’ scheme
错误提示不见了,问题解决。^_^
1.5. Subversion之Apache HTTP Server 配置
修改Apache HTTP Server 配置
[root@os11728 ~]# vi /usr/local/apache2/conf/httpd.conf
(1)增加以下模块:
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
(2)增加SVN的虚拟主机,设定 Subversion 文件库路径
<VirtualHost *:80>
ServerName svn.finet230.cn
DocumentRoot /usr/local/svnroot
#
[email protected] SiteLogs
CustomLog “|/usr/local/sbin/cronolog /var/www/logs/svn_finet230_cn/access_%Y%m%d.log” combined
ErrorLog “|/usr/local/sbin/cronolog var/www/logs/svn_finet230_cn/error_%Y%m%d.log”
<Directory “/usr/local/svnroot”>
Options -Indexes FollowSymLinks Includes
AllowOverride All
Order allow,deny
#Allow from all
deny from all
</Directory>
<Location /svn>
#告诉Aapche加载svn模块来处理请求
DAV svn
#指定SVN版本库父目录
SVNParentPath “/usr/local/svnroot/”
#连接框提示
AuthName “Subversion repository”
#权限配置文件
AuthzSVNAccessFile “/usr/local/apache2/conf/dav_svn.authz”
#采用何种认证
Require valid-user
Satisfy Any
# The following is Basic authentication setting
#身份验证方式(连接类型设置)
AuthType Basic
#用户配置文件(身份验证数据存放的路径及文件)
AuthUserFile “/usr/local/apache2/conf/dav_svn.passwd”
#<LimitExcept>
#Require valid-user
#</LimitExcept>
</Location>
</VirtualHost>
#其中authfile是通过“htpasswd [–c] /usr/local/apache2/conf/dav_svn.passwd username password”来创建的
#”Require valid-user”告诉apache在authfile中所有的用户都可以访问。如果没有它,
#则只能第一个用户可以访问新建库
#顺便把你的端口号也改一下,要不然可能&你以前的Apache的端口冲突
#其中AuthzSVNAccessFile指定了文件库访问政策文件,Require valid-use表示只有经过认证的用户才可以访问, Satisfy Any表示允许匿名访问(要与后面提到的*参数配套使用),AuthUserFile用来指示使用htpasswd创建的密码文件的位置。
(3)用Apache的htpasswd指令生成用户名和密码
[root@os11728 ~]# htpasswd -cm /usr/local/apache2/conf/dav_svn.passwd bovin
[root@os11728 ~]# htpasswd -m /usr/local/apache2/conf/dav_svn.passwd bovin
[root@os11728 ~]# htpasswd -m /usr/local/apache2/conf/dav_svn.passwd server
(3)用Apache的htpasswd指令删除用户名和密码
[root@os11728 ~]# htpasswd -D /usr/local/apache2/conf/dav_svn.passwd bovin
htpasswd语法
htpasswd [ -c ] [ -m ] [ -D ] passwdfile username
htpasswd -b [ -c ] [ -m | -d | -p | -s ] [ -D ] passwdfile username password
htpasswd -n [ -m | -d | -s | -p ] username
htpasswd -nb [ -m | -d | -s | -p ] username password
top
选项
-b
使用批处理方式。也就是直接从命令行获取密码而不进行提醒。使用这个选项需要特别注意,因为命令行中的密码是清晰可见的。
-c
创建passwdfile文件。如果passwdfile已经存在,那么将被清空并改写。该选项不能和 -n 同时使用。
-n
在标准输出上显示结果而不是更新文件。用于生成可以为Apache非文本输出存储格式所接受的密码记录。这个选项改变了命令行语法,因为passwdfile参数(通常是第一个)被忽略了。该选项不能和 -c 同时使用。
-m
使用MD5加密密码。在Windows, Netware, TPF上这是默认方法。
-d
使用crypt()对密码进行加密。在Windows, Netware, TPF以外的平台上这是默认方法。虽然有可能在所有的平台上被htpasswd支持,但是在Windows, Netware, TPF上,该方法不能被httpd所支持。
-s
使用 SHA 对密码进行加密。这种方法易于通过LDAP目录交换格式和Netscape server进行交换。
-p
使用明文密码(不加密)。虽然htpasswd在所有平台上都支持这种方法,但是httpd只能在Windows, Netware, TPF上支持这种方法。
-D
如果username存在于passwdfile中,则删除该用户。
passwdfile
包含用户名和密码的文本文件的名称。如果使用了 -c 选项,若文件已存在则更新它,若不存在则创建它。
username
在passwdfile中添加或更新记录。若username不存在则添加一条记录,若存在则更新其密码。
password
将被加密并存储到文件中的明文密码。必须和 -b 同时使用。
(4)编辑/usr/local/apache2/conf/dav_svn.authz文件
[root@os11728 ~]# vi /usr/local/apache2/conf/dav_svn.authz
添加以下内容:
[aliases]
# joe = /C=XZ/ST=Dessert/L=Snake City/O=Snake Oil, Ltd./OU=Research Institute/CN=Joe Average
[groups]
g_vip = server
g_manager = bovin
g_usr = seal,xieyan,yangdandan,sunny
g_usr_read = prolove
g_all = @g_vip,g_manager,g_user
[/]
@g_vip = rw
@g_manager = rw
[bovin:/]
@g_manager = rw
[finet_tpl:/]
@g_vip = rw
@g_manager = rw
@g_usr = rw
@g_usr_read = r
*=
重启apache。
(5)SVN检出测试
[root@os11728 ~]# mkdir bovin
[root@os11728 ~]# svn checkout http://svn.finet230.cn/svn/bovin bovin #将svn.finet230.cn改为你的域名或IP
配置svn+apache服务器时,在导入或提交时,如果是unix、linux、mac os x等系统可能遇到类似这样的权限问题:
svn: 提交失败(细节如下):
svn: Can’t open file ‘/usr/local/svnroot/bovin/db/txn-current-lock’: Permission denied
或者
svn: 提交失败(细节如下):
svn: Can’t create directory ‘/usr/local/svnroot/bovin/db/transactions/1-2.txn’: Permission denied
这个主要原因:在svnadmin create时是root身份,所以,mod_dav_svn就没有write权限等。
解决办法:
修改目录/usr/local/svnroot的权限属性
[root@os11728 ~]# chown -R daemon /usr/local/svnroot
[root@os11728 ~]# chmod -R 755 /usr/local/svnroot
再试就ok~
1.6. svnsync双机备份
参阅:http://www.scmbbs.com/cn/svntp/2007/11/svntp4.php
使用svnsync备份很简单,步骤如下:
1) 在备份机上创建一个空库:
[root@os11728 ~]# svnadmin create /usr/local/svnroot/bovin
[root@os11728 ~]# chown -R daemon /usr/local/svnroot/bovin
[root@os11728 ~]# chmod -R 755 /usr/local/svnroot/bovin
2)更改该库的钩子脚本pre-revprop-change(因为svnsync要改这个库的属性,也就是要将源库的属性备份到这个库,所以要启用这个脚本):
[root@os11728 ~]# cd /usr/local/svnroot/bovin/hooks
[root@os11728 ~]# cp pre-revprop-change.tmpl pre-revprop-change
[root@os11728 ~]# chmod 755 pre-revprop-change
[root@os11728 ~]# vi pre-revprop-change
将该脚本后面的三句注释掉,或者干脆将它弄成一个空文件。
3)初始化,此时还没有备份任何数据:
[root@os11728 ~]# svnsync init file:///usr/local/svnroot/bovin/ http://192.168.1.230/svn/bovin/ –allow-non-empty
语法是:svnsync init {你刚创建的库url} {源库url}
注意本地url是三个斜杠的:///
4)开始备份(同步):
[root@os11728 ~]# svnsync sync file:///usr/local/svnroot/bovin/
5)建立同步脚本
备份完毕后,建立钩子脚本进行同步。在源库/hooks/下建立/修改post-commit脚本,在其中增加一行,内容如下:
svnsync sync –non-interactive file:///usr/local/svnroot/bovin/
常见问题解决:
问题一:
svnsync init file:///usr/local/svnroot/bovin/ http://192.168.1.230/svn/bovin/
从目标版本库获得锁失败,当前被“rhel500:284ff204-e16b-457f-933c-03d1c26c314b”持有
svnsync: Couldn’t get lock on destination repos after 10 attempts
解决方法,执行以下命令:
svn propdel svn:sync-lock –revprop -r 0 http://192.168.1.230/svn/bovin/
删除属性“svn:sync-lock”于版本库版本 0
问题二:
[root@www conf]# sh /usr/local/svnroot/Bovin/hooks/post-commit
subversion/svnsync/main.c:1384: (apr_err=22)
subversion/svnsync/main.c:1298: (apr_err=22)
svnsync: E000022: Destination HEAD (120) is not the last merged revision (119); have you committed to the destination without using svnsync?
解决方法,执行以下命令:
[root@www conf]# svn proplist -v –revprop -r0 file:///usr/local/svnroot/Bovin/
Unversioned properties on revision 0:
svn:sync-from-uuid
91184778-99fa-495a-80f9-2b4ba10bcf3d
svn:sync-last-merged-rev
119
svn:sync-last-merged-revision
120
svn:date
2011-05-24T05:53:13.406401Z
svn:sync-from-url
svn://192.168.1.230/Bovin
[root@www conf]# svn propset –revprop -r0 svn:sync-last-merged-revision 120 file:///usr/local/svnroot/Bovin/
property ‘svn:sync-last-merged-revision’ set on repository revision 0
[root@www conf]# svn propset –revprop -r0 svn:sync-last-merged-rev 120 file:///usr/local/svnroot/Bovin/
property ‘svn:sync-last-merged-rev’ set on repository revision 0
[root@www conf]# sh /usr/local/svnroot/Bovin/hooks/post-commit
问题三:
[root@www conf]# /usr/local/subversion/bin/svnsync sync file:///usr/local/svnroot/bovin/
Failed to get lock on destination repos, currently held by ‘www.finet85.cn:834e6569-67ad-472f-a745-25792c632a02′
Failed to get lock on destination repos, currently held by ‘www.finet85.cn:834e6569-67ad-472f-a745-25792c632a02′
svnsync: Couldn’t get lock on destination repos after 10 attempts
这个时候可能属性被锁了。
解决方法,执行以下命令:
[root@www conf]# svn propdel svn:sync-lock –revprop -r0 file:///usr/local/svnroot/bovin/
删除成功后,再试一遍基本就可以了。
如果反复操作都是同样错误的话,有可能是你的svn安装的有问题,重新安装一遍就好了,俺就是这样。
从目标版本库获得锁失败,当前被“rhel500:284ff204-e16b-457f-933c-03d1c26c314b”持有
svnsync: Couldn’t get lock on destination repos after 10 attempts
一些备忘:
1.客户机访问
客户机的访问方法与服务器的运行方式有直接关系
window客户机:
1) 服务器以http方式运行
安装完TortoiseSVN-1.1.1-UNICODE_svn-1.1.1.msi后,在你想工作的目录下点击右键,执行checkout,输入http://svn服务器ip/svn/repository即可。
2) 服务器以svnserve方式运行
同上的区别只是URL of repository变为 svn://svn服务器ip/home/mysvn
或者 svn+ssh://svn服务器ip/home/mysvn
(注意不是//svn服务器ip//svn/repository)
linux客户机:
1) 服务器以http方式运行
执行 #svn checkout http: //svn服务器ip/svn/repository
2) 服务器以svnserve方式运行
执行 #svn checkout svn://svn服务器ip/home/mysvn
或者 #svn checkout svn+ssh://svn服务器ip/home/mysvn
2.客户认证机制
这与服务器的运行方式有关
服务器以svnserve方式运行
默认下客户可以以匿名方式通过svn://方式任意访问档案库,为了限制其权限,比如只允许读操作,可以通过修改档案库conf子目录中的svnseve.conf文件来实现。
#vi /home/mysvn/conf/svnseve.conf
修改[general]字段下内容为:
anon-access = read
如果设为anon-access = none,则匿名用户不可以通过svn://方式访问档案库
为了实现用户认证,我们一般采用svn+ssh://访问机制。
首先在svnseve.conf文件设置anon-access = none禁止匿名用户通过svn://方式访问档案库
在其后加入auth-access = write一行
auth-access 是限制有援权的使用者(使用svn+ssh:// 来登入) 的存取权限,我们设为是可以读写。
当用户通过svn+ssh://访问时,服务器会自动启动ssh认证机制,要求用户输入密码,对于window用户来说还需要安装第三方软件openssh,才可以采用这种机制
服务器以http方式运行
比如我们想给 Sally 与 Harry 送交存取档案库的权限. 首先, 我们必须把它们加入到密码档案.
# ### 第一次: 以 -c 建立档案
# htpasswd -c /etc/svn-auth-file harry
New password: *****
Re-type new password: *****
Adding password for user harry
# htpasswd /etc/svn-auth-file sally
New password: *******
Re-type new password: *******
Adding password for user sally
#
接着,在/usr/local/apache2/conf/httpd.conf的加入:
<Location /svn/repository >
DAV svn
SVNPath /home/mycvs
AuthType Basic
AuthName “Subversion repository”
AuthUserFile /etc/svn-auth-file
Require valid-user
</Location>
重新启动 Apache后,如果有人要访问SVN服务器,系统会要求他输入用户名和密码。只有输入Sally 或Harry的用户名和相应的密码,才可以对档案库进行修改和访问
3.添加用户
打开/conf/目录,打开svnserve.conf找到一下两句:
# [general]
# password-db = passwd
去之每行开头的#,其中第二行是指定身份验证的文件名,即passwd文件
同样打开passwd文件,将
# [users]
# harry = harryssecret
# sally = sallyssecret
这几行的开头#字符去掉,这是设置用户,一行一个,存储格式为“用户名 = 密码”,如可插入一行:admin = admin888,即为系统添加一个用户名为admin,密码为admin888的用户
4. 如果linux的登录用户名密码都和svn的其中一个用户名密码相同时,在checkout的时候不会要求输入用户名密码直接就可以checkout出来。比如:linux有个用户wooin,svn也有一个用户wooin,并且密码都是一样的,当用wooin登录linux后,执行checkout,可以直接提取出源码文件,不用输入认证信息。
5. 在svn使用过程中牵扯到几种权限:文件系统的权限,linux系统权限,svn用户的权限,apache进程的权限。
文件系统的权限,linux系统权限:这里相同的意思,就是平时大家使用linux时文件夹和文件的访问权限。在svn建立仓库,文件夹,配置文件的时候用svnroot用户,并将仓库权限设置为700,不允许其他用户直接通过文件系统查看,只能由svnroot进行管理。
apache进程的权限:因为所有跟仓库传输的操作都是通过apache进程进行的,所以即使你给svn用户设置了很大的权限,但是apache进程没有访问仓库或者相关文件的权限也没有用,apache进程的权限设置在 /usr/local/apache2/conf/httpd.conf 文件中配置,找到文件中的这两行:
User daemon # 将daemon改为svnroot,让apache进程以svnroot的身份运行
Group daemon
svn用户的权限:就是在repository/authz.conf文件中设置的权限信息,是svn用来管理仓库访问权限的。
6. svn服务器设置有两种方式:http 和 svnserve。这里介绍的是http方法
7. 在/etc/profile的结尾设置一些svn启动时要做的工作 # start apache server for svn
/usr/sbin/apachectl start
export SVN_EDITOR=vi
8. APR libraries 安装 SVN 的时候最好指定 –with-apr= 和 –with-apr-util= 参数到 Apache 安装的根目录
(ServerRoot)下,而不是使用缺省的 SVN 安装包中自带的 apr 。否则如果你安装的 Apache
版本不同有可能导致 APR 库不匹配,出现类似:
Can’t set position pointer in file ‘/svn/test/db/revs/1′: Invalid argument 的错误。
Updated 2006-04-20 16:30 — 比如说如果你安装的是apache 2.2.0版本,就需要在编译安装svn的时候指定
–with-apxs和–with-apr参数到你的apache2.2.0安装目录下:
./configure –divfix=${subversionInstallFolder} /
–with-apxs=${apacheInstallFolder}/bin/apxs /
–with-apr=${apacheInstallFolder} /
–with-apr-util=${apacheInstallFolder} /
–with-ssl /
–with-zlib /
–enable-maintainer-mode