SVN
linux搭建svn服务器
参考:http://www.cnblogs.com/chaichuan/p/3758173.html
Subversion(SVN) 是一个开源的版本控制系統, 也就是说 Subversion 管理随着时间改变的数据。 这些数据放置在一个中央资料档案库 (repository) 中。 这个档案库很像一个普通的文件服务器, 不过它会记住每一次文件的变动。 这样你就可以把档案恢复到旧的版本, 或是浏览文件的变动历史。
SVN中的一些概念
(1). repository(源代码库)
源代码统一存放的地方
(2). Checkout (提取)
下载代码,客户端通过checkout从服务器(Subversion)端下载源代码
(3). Commit (提交)
从服务器下载的代码,如果做了变更则需要提交到服务器端
(4). Update (更新)
本地已经checkout了一份代码,如果别人对代码做了更改并且已经提交,那么update可以更新别人更改后的代码,一般在提交代码前都需要更新一下代码,防止自己的代码覆盖了别人更改了的代码
SVN管理源代码是以行为单位的,如果两个程序员修改的不是同一行代码,SVN都会自动合并两种修改。如果是同一行,SVN会提示文件Confict, 冲突,如果发生冲突则需要手动的解决冲突,切不可直接提交。
windows常用的客户端软件:TortoiseSVN
SVN 服务器搭建(centeros linux)
yum install -y subversion
或者
yum -y install svn
验证是否安装成功
svnserve --version
创建SVN 版本库
mkdir svn svnadmin create svn/rep01
rep01为版本库的名称,rep01的结构如下
$ ls svn/rep01/ conf db format hooks locks README.txt
svn配置文件
$ ls svn/rep01/conf/ authz passwd svnserve.conf
(1)svnserve.conf: svn服务配置文件下。
(2)passwd: 用户名口令文件。
(3)authz: 权限配置文件。
svnserve.conf 文件, 该文件配置项分为以下5项:
anon-access: 控制非鉴权用户访问版本库的权限。
auth-access: 控制鉴权用户访问版本库的权限。
password-db: 指定用户名口令文件名。取消注释使用默认文件,也就是conf同级的那个passwd文件,取消注释前面不能有任何空格,不然会报错
authz-db:指定权限配置文件名,通过该文件可以实现以路径为基础的访问控制。取消注释使用默认文件,也就是conf同级的那个authz文件,取消注释前面不能有任何空格,不然会报错
realm:指定版本库的认证域,即在登录时提示的认证域名称。若两个版本库的认证域相同,建议使用相同的用户名口令数据文件
当指定 password-db 和 authz-db 时连接svn才提示输入密码
passwd文件
[users] # harry = harryssecret # sally = sallyssecret username = password
#代表注释
authz文件
[aliases] #在这个组下面定义别名 # joe = /C=XZ/ST=Dessert/L=Snake City/O=Snake Oil, Ltd./OU=Research Institute/CN=Joe Average [groups] #定义组的概念,比如harry,sally是一组 # harry_and_sally = harry,sally # harry_sally_and_joe = harry,sally,&joe # [/foo/bar] #指定配置库 # harry = rw # 用户harry有读写权限 # &joe = r # &joe代表别名joe # * = # [repository:/baz/fuz] #指定配置库 repository配置库名称 /baz/fuz配置库repository下的路径 # @harry_and_sally = rw # @harry_and_sally代表组harry_and_sally # * = r # *通配符,代表所有人 $anonymous 匿名用户 $authenticated非匿名用户
启动和停止SVN服务
启动SVN服务:
svnserve -d -r svn/rep01
-d表示后台运行
-r 指定配置库路径
命令行测试
mkdir test cd test svn co svn://localhost/rep01
停止SVN服务:
ps -aux | grep svn kill -9 进程杀掉
或者
killall svnserve
注意如下配置
[/] * = rw [rep01:/] test = rw
则启动配置库的时候需要svnserve -d -r svn,不然会找不到配置库rep01
客户端连接SVN 服务器
地址:svn://ip/repository 如:svn://192.168.19.100/rep01
http访问svn
参考:http://www.cnblogs.com/ayanmw/archive/2011/12/19/2294054.html
安装apache相关组件
yum -y install mod_dav_svn httpd
在/etc/httpd/conf.d/目录下会存在文件subversion.conf,其配置内容如下
LoadModule dav_svn_module modules/mod_dav_svn.so LoadModule authz_svn_module modules/mod_authz_svn.so # # Example configuration to enable HTTP access for a directory # containing Subversion repositories, "/var/www/svn". Each repository # must be both: # # a) readable and writable by the 'apache' user, and # # b) labelled with the 'httpd_sys_content_t' context if using # SELinux # # # To create a new repository "http://localhost/repos/stuff" using # this configuration, run as root: # # # cd /var/www/svn # # svnadmin create stuff # # chown -R apache.apache stuff # # chcon -R -t httpd_sys_content_t stuff # #<Location /repos> # DAV svn # SVNParentPath /var/www/svn # # # Limit write permission to list of valid users. # <LimitExcept GET PROPFIND OPTIONS REPORT> # # Require SSL connection for password protection. # # SSLRequireSSL # # AuthType Basic # AuthName "Authorization Realm" # AuthUserFile /path/to/passwdfile # Require valid-user # </LimitExcept> #</Location>
<Location /repos>:/repos为虚拟目录,对应SVNParentPath指定的实际目录
AuthUserFile:指定用户名密码文件,该文件使用htpasswd命令创建
SVNParentPath:指定了SVN配置库的父目录
AuthUserFile 用户添加
htpasswd -h查看命令帮助
第一次添加用户
htpasswd -c passwd test
passwd:文件的名称
test:用户名
再次添加用户
htpasswd passwd test
启动apache服务
sudo service httpd restart
注意修改配置库目录的权限,不然会一直报权限问题的
chown -R apache:apache rep01 chcon -R -t httpd_sys_content_t rep01
此刻就可以使用http://localhost/repos/stuff repos为映射的虚拟路径,stuff为配置库