由于公司需要一个svn,所以我最近研究了一下svn,下面是我的笔记,分享给大家,如果有不对的地方,请指点!
我搭建的是基于Apache Http Server的svn,我的系统发行版本是redhat 5.4.
- 1、安装apache与svn,还有svn需要的模块mod_dav_svn
- yum install httpd httpd-devel subversion mod_dav_svn
- 2、查看svn的mod_dav_svn模块是否安装
- [root@nginx-backup ~]# cd /etc/httpd/modules/
- [root@nginx-backup modules]# ll |grep svn
- -rwxr-xr-x 1 root root 12704 2011-06-09 mod_authz_svn.so
- -rwxr-xr-x 1 root root 146928 2011-06-09 mod_dav_svn.so
- 3、查看svn是否安装成功
- [root@nginx-backup modules]# svn --version
- svn, version 1.6.11 (r934486)
- compiled Jun 8 2011, 16:22:13
- Copyright (C) 2000-2009 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_neon : Module for accessing a repository via WebDAV protocol using Neon.
- - handles 'http' scheme
- - handles 'https' 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安装成功
- 4、创建仓库,以及仓库目录的设置
- [root@nginx-backup modules]# mkdir -p /svndata
- [root@nginx-backup modules]# cd /svndata/
- [root@nginx-backup svndata]# svnadmin create ctitc ##创建仓库,仓库名字为ctitc
- [root@nginx-backup svndata]# chown -R apache:apache ctitc ##更改仓库ctitc的用户为apache,这个apache与apache里的httpd.conf里的用户应该一致
- [root@nginx-backup svndata]#vim /etc/httpd/conf.d/subversion.conf ##在最后面添加一下内容
- <Location /svn>
- DAV svn
- #SVNParentPath /svndata/ctitc/
- #
- # # Limit write permission to list of valid users.
- # <LimitExcept GET PROPFIND OPTIONS REPORT>
- # # Require SSL connection for password protection.
- # # SSLRequireSSL
- #
- SVNListParentPath on
- #SVNParentPath "/svndata/ctitc/test" ##svn打开时的目录,如果你是多个仓库用SVNParentPath,只有1个的话使用SVNPath
- SVNPath "/svndata/ctitc"
- AuthType Basic
- AuthName "Subversion repository"
- AuthUserFile "/svndata/ctitc/conf/authfile"
- Require valid-user
- SVNAutoversioning on
- ModMimeUsePathInfo on
- # </LimitExcept>
- </Location>
- 5、添加用户
- [root@nginx-backup svndata]# htpasswd -c /svndata/ctitc/conf/authfile test ##建立访问的用户test
- 如果想要添加多个用户可以使用
- [root@nginx-backup svndata]# htpasswd /svndata/ctitc/conf/authfile test
- 6、配置权限
- [root@nginx-backup svndata]# vim /svndata/ctitc/conf/authz
- [groups]
- admin = test ##用户组为admin,里面的用户为test
- [admin:/]
- @admin = rw ##admin组具有读写权限
- [/]
- * = r #其他用户具有读权限
- [ctitc:/] ##ctitc仓库根目录下的访问权限
- test = rw ##用户test具有读写权限
- 7、svn的import导入
- [root@nginx-backup svndata]# svn import /svndata/ctitc/ file:///svndata/ctitc -m "Initial repository"
- 8、配置svn服务端
- [root@nginx-backup svndata]# vim /svndata/ctitc/conf/svnserve.conf
- 内容修改为:
- [general]
- anon-access = none
- auth-access = write
- password-db = /svndata/ctitc/conf/passwd
- authz-db = /svndata/ctitc/conf/authz
- realm = ctitc
- 注意,把这几项的#去掉的时候,一定要这些空格都删除,否则会出现错误。
- 9、修改passwd
- [root@nginx-backup svndata]# vim /svndata/ctitc/conf/passwd
- [users]
- # harry = harryssecret
- # sally = sallyssecret
- test= test ##我设置的用户与密码均为test
- 现在svn的服务都配置完成了,需要重启启动apache与svnserve
- [root@nginx-backup svndata]# service httpd restart
- [root@nginx-backup svndata]# svnserve -d -r /svndata/ctitc/
- 然后查看apache与svnserve是否启动
- [root@nginx-backup svndata]# ps -ef|grep httpd
- root 4902 1 0 Dec27 ? 00:00:00 /usr/sbin/httpd
- apache 4904 4902 0 Dec27 ? 00:00:10 /usr/sbin/httpd
- apache 4905 4902 0 Dec27 ? 00:00:17 /usr/sbin/httpd
- apache 4906 4902 0 Dec27 ? 00:00:08 /usr/sbin/httpd
- apache 4907 4902 0 Dec27 ? 00:01:28 /usr/sbin/httpd
- apache 4908 4902 0 Dec27 ? 00:00:15 /usr/sbin/httpd
- apache 4909 4902 0 Dec27 ? 00:00:19 /usr/sbin/httpd
- apache 4910 4902 0 Dec27 ? 00:00:10 /usr/sbin/httpd
- apache 4911 4902 0 Dec27 ? 00:00:04 /usr/sbin/httpd
- apache 5142 4902 0 Dec27 ? 00:00:15 /usr/sbin/httpd
- apache 21541 4902 0 12:02 ? 00:00:02 /usr/sbin/httpd
- root 24116 23659 0 14:42 pts/2 00:00:00 grep httpd
- [root@nginx-backup svndata]# ps -ef|grep svnserve
- root 4915 1 0 Dec27 ? 00:00:00 svnserve -d -r /svndata/ctitc/
- root 24118 23659 0 14:42 pts/2 00:00:00 grep svnserve
现在就可以在浏览器里输入http://127.0.0.1/svn就能访问你的svn了,账号与密码均为test。
需要注意的是,如果想创建与修改svn里的文件,需要使用svn客户端来进行,比如我使用的就是TortoiseSVN,具体如何使用这类就不介绍了,大家可以参照http://www.cnblogs.com/blsong/archive/2010/09/02/1816124.html来学习。
再回复里,有人出现还有一个就是在svn commit的时候提示
Can't open file '/svndata/XXXXXXX/txn-current-lock': Permission denied
这个是因为selinux没有关闭,由于我是在生产机器部署的svn,前端有了防火墙与负载均衡设备,所以我的iptables与selinux都已经关闭,所以没有出现此问题,请大家在配置svn的时候注意iptables与selinux。
本文转自 dl528888 51CTO博客,原文链接:http://blog.51cto.com/dl528888/752892,如需转载请自行联系原作者