linux centos 下面httpd支持的svn 服务器端安装
一,Subversion有两种运行方式
一种是基于apache Http Server,另外一种是Subversion Standalone Server。
以下是基于httpd的svn的安装
二,安装svn
yum install httpd httpd-devel subversion mod_dav_svn
如果你已经装了apache了,不想装二个apache的话。你可以单独下个subversion来装一下就行了。
注意一点的是,路径要正确:
#./configure --with-apxs=/apache路径/bin/apxs --prefix=/usr/local/subversion
--with-apr=/usr/local/apache2 --with-apr-util=/apache路径 --with-ssl --with-zlib
--enable-maintainer-mode
1),确定已经安装了svn模块:mod_dav_svn
[root@svn zhangying]# cd /etc/httpd/modules/
[root@svn modules]# ls |grep svn
mod_authz_svn.so
mod_dav_svn.so
[root@svn modules]#
2),看一下svn是否已安装成功
[root@svn modules]# svn --version
svn, version 1.4.2 (r22196)
compiled Aug 10 2009, 18:00:04
Copyright (C) 2000-2006 CollabNet.
Subversion is open source software, see http://subversion.tigris.org/
This product includes software developed by CollabNet (http://www.Collab.Net/).
The following repository access (RA) modules are available:
* ra_dav : Module for accessing a repository via WebDAV (DeltaV) protocol.
- handles 'http' scheme
- handles 'https' scheme
* ra_svn : Module for accessing a repository using the svn network protocol.
- handles 'svn' scheme
* ra_local : Module for accessing a repository on local disk.
- handles 'file' scheme
三,创建仓库,修改svn配置文件
1),加载模块
[root@svn conf.d]#cd /etc/httpd/conf.d
[root@svn conf.d]# nano subversion.conf
添加以下二行
LoadModule dav_svn_module modules/mod_dav_svn.so
LoadModule authz_svn_module modules/mod_authz_svn.so
2),创建仓库,以及仓库目录的设置
# mkdir -p /var/www/svn
# cd /var/www/svn
# svnadmin create test
# chown -R apache.apache test
# vi /etc/httpd/conf.d/subversion.conf
<Location /svn>
DAV svn
#注意,下面的路径,子文件夹名不能和父文件名重复,不然就会出问题
SVNParentpath /var/www/svn/repository
#
# # Limit write permission to list of valid users.
# <LimitExcept GET PROPFIND OPTIONS REPORT>
# # Require ssl connection for password protection.
# # sslRequiressl
#
AuthType Basic
AuthName "Subversion repository"
AuthzSVNAccessFile /var/www/svn/repository/authz.conf
AuthUserFile /var/www/svn/repository/authfile
Require valid-user
# </LimitExcept>
</Location>
3),添加用户
下面建立可访问用户文件
# htpasswd -c /var/www/svn/repository/authfile 用户名
要增加用户,则使用下面命令
# htpasswd /var/www/svn/repository/authfile 用户名 //第一次设置用户时使用-c表示新建一个用户文件。回车后输入用户密码,完成对用户的增加 当你用页面访问svn时,apache要进行的密码确认 4),权限分限# nano /var/www/svn/repository/authz.conf [test:/] //这表示,仓库test的根目录下的访问权限 zhangy = rw //test仓库zhangy用户具有读和写权限 hunk = r //test仓库hunk用户具有读权限 [/] //这个表示在所有仓库的根目录下 * = r //这个表示对所有的用户都具有读权限 #[groups] //这个表示群组设置 #svn1-developers = zhangy, hunk //这个表示某群组里的成员 #svn2-developers = zhangy #[svn1:/] #@svn1-developers = rw //如果在前面加上@符号,则表示这是个群组权限设置搞好之后重起apache
# service httpd restart 5),svn的一些操作a.import操作 [root@svn www] svn import /var/www/zhangy/test/ file:///var/www/svn/repository/test -m "Initial repository test" Adding /var/www/zhangy/test.txt Adding /var/www/zhangy/test1.txt 注意: 1,file:///在这里是3个/,我开始导入时写成了二个,老是报错,我就很晕。 2,在导入时,如果存在中文字符的文件名导入会停止报错 b.check out操作 [root@svn www] cd /var/www [root@svn www] svn co http://yoursvnserver/svn/test Authentication realm: <http://yoursvnserver:80> Subversion repositoryPassword for 'youruser': A test/test.txt A test/test1.txt Checked out revision 1. c.edit和commit操作 [root@svn www] cd /var/www [root@svn www] nano test.txt -- 修改一些东西后. [root@svn www] svn commit -m "Added a line to test.txt." Sending test/test.txt Transmitting file data . Committed revision 2. d.add和delete操作[root@svn www] svn co http://yoursvnserver/svn/test[root@svn www] cd /var/www [root@svn www] nano test2.txt -- 添加一个新文件. [me@mylappy ~] svn add test2.txt A test2.txt [me@mylappy ~] svn commit -m "new one" Adding test2.txt Transmitting file data . Committed revision 3. 删除操作把add换成delete就可以了
TortoiseSVN客户端,网上搜一下,到处都是,在这儿就不罗嗦参考文档
http://wiki.CentOS.org/HowTos/Subversion?highlight=%28subversion%29
/var/www/zhangy