- 浏览: 261913 次
- 性别:
- 来自: 深圳
文章分类
最新评论
-
liliang880504:
bitnami_redmine_merge这个数据库是创建和合 ...
bitnami-redmine服务器迁移
*********安装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
#bovin.phang@gmail.com 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
[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
#bovin.phang@gmail.com 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
发表评论
-
checking build system type... x86_64-unknown-linux-gnu
2015-11-16 12:16 2178sudo yum -y install make gcc gc ... -
svn更换新仓库地址, 以及UUID不同的解决方式
2015-02-27 09:18 6252shell 命令: svn relocate svn://s ... -
linux下tar.gz、tar、bz2、zip等解压缩、压缩命令小
2015-02-15 23:54 627Linux下最常用的打包程 ... -
用 Apache 和 Subversion 搭建安全的版本控制环境
2015-02-15 18:02 585作为新一代的开源版本 ... -
Linux SVN Server 相关网址
2015-02-15 00:09 641SVN服务器从Windows迁移到LInux: http:// ... -
Linux SVNServer搭建,并支持https访问
2015-02-15 00:02 12651.Subversion安装过程 参考http://blog. ... -
eclipse svn 切换用户
2015-02-14 20:31 835在eclipse中经常用到用svn ... -
SVN authz 配置详解 转载
2015-02-14 15:35 817我们对项目根目录做了限制,该目录只允许arm事业部的经理才能修 ... -
linux服务器,svn认证失败,配置问题,防火墙等等
2015-02-14 15:22 1131之前自己还真没设置过SVN,今天亲自动手,错误百出,真是够头 ... -
Linux 搭建SVN 服务器
2015-02-13 15:55 644一. SVN 简介 S ...
相关推荐
为了在 Linux 环境下安装 Subversion,需要安装相关依赖包,包括 OpenSSL、zlib 和 Apache。 一、安装依赖包 1. 安装 OpenSSL:OpenSSL 是一个安全套件,Subversion 需要它来提供加密功能。安装过程中可能会报错,...
在Linux环境下安装Subversion,需要准备以下组件: 1. **Subversion**:版本控制软件。 2. **BerkeleyDB**:用于存储版本库数据的数据库。 3. **Apache**:Web服务器,用于提供对版本库的HTTP访问。 #### 三、安装...
Linux环境下搭建Subversion(简称svn)服务器,主要涉及到两个方面:一是Subversion自身服务的搭建,二是与Apache服务器的集成。Subversion是一个开源的版本控制系统,用于跟踪文件和目录的变更,便于团队协作开发。...
在Linux环境下,如RHEL6中通过源码编译的方式安装Subversion,可以更好地控制安装配置细节,满足特定的需求。 **步骤详解:** 1. **下载 Subversion 源码包:** - 使用`wget`命令下载Subversion主程序和依赖包。 ...
【Subversion 在 Linux 下的安装与配置】 Subversion(简称 SVN)是一款强大的开源版本控制系统,它跟踪文件和...在Linux环境中安装并配置Subversion独立服务器,可以实现稳定且安全的版本控制,提升团队的生产力。
通过以上步骤,可以顺利完成 Subversion Edge 在 Linux 环境下的安装、配置以及数据迁移工作。这种方式不仅适用于企业内部的开发团队,也可以用于任何需要集中版本控制管理的场景。对于初次接触 Subversion Edge 的...
在IT行业中,Linux、Apache和Subversion是三个非常重要的组件,它们共同构成了一个高效且可靠的软件开发...通过本文的步骤,你已经学会了如何在Linux环境中安装和配置这个组合,从而为你的开发工作流提供强有力的支持。
本文档主要介绍了如何在Linux系统中安装和配置Subversion服务器,以及如何使用Subversion客户端TortoiseSVN。Subversion是一个开源的版本控制系统,常用于替代存在诸多限制的CVS系统,以解决文件名修改、目录管理、...
本篇文章将深入讲解如何在Linux环境中安装和配置Subversion 1.4.5版本。 首先,我们需要了解Subversion的基本概念。Subversion是一个集中式的版本控制系统,它维护着项目文件的历史版本,使得团队成员可以同时工作...
本文将详细介绍如何在 Linux 环境下快速配置 SVN,并提供一套实用的权限管理策略以及版本库的备份与恢复方案。 #### 二、配置步骤详解 ##### 1. 创建版本库 首先,在服务器上创建 SVN 版本库。这里以 `/u/svntest`...
在Linux环境中,Subversion(简称svn)是一种广泛使用的版本控制系统,用于管理软件项目的源代码和其他文件的变更。本文将详细讲解如何在没有网络连接的情况下,通过提供的“Linux离线安装svn.zip”压缩包来安装和...
以上步骤详细描述了在Linux环境下安装和配置Subversion以及使用HTTPS访问的全过程。遵循这些步骤,可以构建一个安全、可靠的版本控制系统,为团队协作提供有力支持。在实际操作中,请根据具体系统和需求进行适当的...
本文旨在详细介绍如何在Linux环境下安装并配置Subversion服务器,包括搭建过程中的关键步骤和技术细节。 #### 实验环境 为了进行Subversion的安装与配置实验,以下环境被设定为测试平台: - **SVN服务器**:...
在Linux环境中,安装Subversion是进行团队协作的重要步骤。这里我们将详细探讨如何在Linux上安装`subversion-1.6.18`这一特定版本。 一、SVN简介 Subversion是一种集中式版本控制系统,与Git这样的分布式版本控制...
在Linux环境下安装和配置CollabNet SubversionEdge需要遵循一系列步骤,包括安装依赖、下载与解压软件、设置环境变量、创建用户与权限、配置服务器以及调整防火墙规则。 首先,安装CollabNet SubversionEdge前,...
### Linux环境下安装Subversion (SVN) 的详细步骤与注意事项 #### 一、背景介绍 在软件开发过程中,版本控制系统是非常重要的工具之一。Subversion(SVN)作为一款开源的集中式版本控制系统,在团队协作中扮演着...
- **运行安装程序**:运行可执行文件 `SubversionEdge3.2.1(Windows32-bit)` 进行安装,默认情况下安装路径为 C 盘。 - **配置 Java 环境变量**:如果安装 Subversion Edge 前没有安装 Java 和 Python,那么安装过程...
总之,Linux系统上的Subversion服务器安装与配置涉及到多个步骤,包括系统环境准备、Apache和SVN的安装配置、用户管理以及客户端的使用。通过这样的配置,企业可以有效地管理和协作项目代码,提高开发效率。
通过以上步骤,你可以在没有网络连接的Linux环境下成功安装和使用SVN。请注意,具体步骤可能会因Linux发行版和个人需求而略有不同,务必根据实际情况调整。在执行过程中,如果遇到任何问题,建议查阅官方文档或社区...
**使用Subversion客户端TortoiseSVN**\n - **Windows环境下安装**:在Windows系统上下载并安装TortoiseSVN,提供图形化的界面操作。\n - **浏览资源库**:使用TortoiseSVN客户端连接到Subversion服务器,查看、检出...