Linux SVN 服务器配置以及客户端使用

原创 SVN
阅读数: 809 2014年06月06日

1、配置好yum,检查subversion安装包

[root@svn ~]# yum list |grep subversion

subversion.i386                          1.4.2-4.el5_3.1               base

subversion-devel.i386                     1.4.2-4.el5_3.1               base    

subversion-javahl.i386                     1.4.2-4.el5_3.1               base    

subversion-perl.i386                      1.4.2-4.el5_3.1               base    

subversion-ruby.i386                      1.4.2-4.el5_3.1               base    

[root@svn ~]# yum -y install subversion

测试安装是否成功: 

#svnserve  --version     回车显示版本说明安装成功

[root@svn ~]# netstat –nat  查看默认TCP 3690端口是否监听. 


2、创建svn版本库

[root@svn /]# mkdir -p /data/svndata  #创建SVN存放目录

[root@svn /]# svnadmin create /data/svndata/winne  #创建名为 winne 的SVN仓库

 

cd /data/svndata/winne/conf  进入这个目录,对文件修改

3、svnserve配置文件概述 

svnserve.conf --  svn服务配置文件,该文件版本库目录的conf目录下。 

passwd -- 用户名口令文件,该文件名在文件svnserve.conf中指定,缺省为同目录下的。 

authz  -- 权限配置文件,该文件名也在文件svnserve.conf中指定,缺省为同目录下的。

 

conf/svnserve.conf 文件

配置项分为以下5项: 

anon-access 匿名用户访问版本库的权限。 (推荐给none:不支持匿名读取和上传功能;anon-access = none  必须设置,否则无法显示“历史日志”,无法回滚文件)

auth-access  控制鉴权用户访问版本库的权限。 

password-db 指定用户名口令文件名。 

authz-db    指定权限配置文件名,通过该文件可以实现以路径为基础的访问控制。 

realm      客户端凭证缓存(指定版本库的认证域,即在登录时提示的认证域名称。若两个版本库的 

           认证域相同,建议使用相同的用户名口令数据文件)

例子:

[general]

anon-access = none #匿名用户不允许访问

auth-access = write #授权用户可以有写权限

password-db = /data/svndata/common/passwd #指定密码配置文件路径

authz-db = /data/svndata/common/authz #指定权限配置文件路径



conf /Passwd 密码配置文件

user1 = user12345

user2 = user212345

 

conf /authz  权限配置文件

[groups]       设置组

admin = user1

dev = user2

system = hooker

php = peter,px

group_b= user_b,user_c (一个组多个人,是这么写的)


#设置根目录的权限配置

[/]

*=     #其他用户无法无权限,不让其他用户获得里面的内容

* = r  #或表示其他用户只有读的权限,

@admin = rw    设置admin组有读写权限 [这是按群组方式管理,上面设置了组以后,下面只要设置一次权限即可;作用和 user1 = rw 的一样。赋予读写权限]

@php = rw

@system = r


#设置版本仓库的权限配置

[vzs_dev_www:/]

@vzs_dev = rw

@system = r

user1 = rw      用户1权限是:可读写(也就是下载文件和上传文件)[这是按个人来设置权限,只对这个人有效]

user2 = r        用户2权限是:可读,不可写

@admin = rw  设置admin组有读写权限 [这是按群组方式管理,上面设置了组以后,下面只要设置一次权限即可;作用和 user1 = rw 的一样。赋予读写权限]

* =                其他用户无权限

@dev = rw


…以此类推

注意提示:

1、因为user1 属于 admin 组里面;所以 user1 = rw 与 @admin = rw 有一个即可,除非要对use1单独设置 

2、*=   表示除了配置中的用户或组,其他用户或组的无权,或者其他的权限统一配置。这个不可取消,因为SVN的权限有继承性。如果组dev获得了nim的读写权限,那继承了nim/one 的读写权限,必须对 nim/one 进行特殊设置,阻止其他用户或组的访问;具体请查看:http://steve-wang-victor.iteye.com/blog/517642


4、启动和停止SVN服务

启动SVN服务:

[root@svn ~]# svnserve -d -r /data/svndata/   (注意,启动服务器的目录是svndate,不是winne)

-d表示后台运行

-r 指定根目录是 /data/svndata/

停止SVN服务:

ps -aux |grep svn

kill -9 进程号  //进程杀掉

注意:千万别在chkconfig上面开启svnserc自动启动,会占用端口,而且还用不了

添加开机启动# echo "svnserve -d -r /data/svndata/" >> /etc/rc.local


5、然后在linux上某个目录checkout这个SVN(做钩子的时候也需要这一步)

例1:svn checkout svn://192.168.1.102/winne  /app/www/shihui91/  --username=lyl --password=123456 --no-auth-cache

例2:svn checkout svn://127.0.0.1/pengfly_weixin  /home/www/pengfly_weixin/ --username=sys_update --password=qwerty654321 --no-auth-cache


6、制作钩子,HOOKS功能(制作钩子的时候,必须执行第5步,先在那个目录 svn checkout 一下)

先复制 post-commit.tmpl 为 post-commit :#cp post-commit.tmpl post-commit,一开始没有这个文件

vim  /svndata/winne/hooks/post-commit (编辑完后,需要给这个文件执行权限: chmod 744 post-commit)

内如如下:

#!/bin/sh

export.UTF-8

#自动更新

svn update /home/www/pengfly_weixin/ --username=lyl --password=123456 --no-auth-cache

#svn 命令也许要写好绝对目录


#修改对应权限(注意:一定要指定目录,否则就把整个系统的文件都修改了,那就悲剧了)

chmod 755 /home/www/pengfly_weixin/upload

chown -R www.www /home/www/pengfly

 

客户端使用

Windows客户端TortoiseSVN的使用

1, TortoiseSVN 客户端的安装

 

2,客户端的文件更新至服务器(user1操作)

新建一个空目录,右键Checkout (提取)

svn://192.168.103.26/winne

输入passwd文件中的授权用户帐号就可以了



Linux客户端的使用


客户端操作流程一般是:


用户A:  checkout (提取)    -> add (添加新文件)   -> commit (提交)


用户B:  SVN log(查看更新) -> update(更新版本)


1,SVN的安装


yun –y install subversion


2,Linux  svn的常用命令


()内为命令简写.


checkout (co) 提取


commit (ci)   提交


update (up)  更新


list (ls)      列表


 


3, checkout (co) 提取 svn服务器上的文件


(user1)操作流程


[root@TEST ~]# svn co svn://192.168.103.26/winne


Authentication realm:


Password for 'root':  


Authentication realm:


Username: user1                    /输入用户名


Password for 'user1':                 /输入密码


A    winne/Cosmic Ride - BeFour.lrc


A    winne/20070716171657126.pdf


A    winne/svnbook.pdf


revision 1.          / checkout (co) 提取成功,看到Checked out版本为1


注:可以使用带用户名和密码的访问:


svn co --username user1 --password user1 svn://192.168.103.26/winne


[root@TEST ~]# ll


drwxr-xr-x 3 root root  4096 Sep 23 09:02 winne  /winne目录是SVN自动生成的


drwxr-xr-x 2 root root  4096 Jul 30 02:06 tasks


[root@TEST ~]# cd winne


[root@TEST winne]# ll


total 2868


-rw-r--r-- 1 root root 1566968 Sep 23 08:53 20070716171657126.pdf


-rw-r--r-- 1 root root    2397 Sep 23 08:53 Cosmic Ride - BeFour.lrc


-rw-r--r-- 1 root root 1354300 Sep 23 08:53 svnbook.pdf


 


4,user1修改文件并提交


[root@TEST winne]# vi testsvn.txt


[root@TEST winne]# svn add testsvn.txt          /将testsvn.txt添加到库中


A         testsvn.txt


[root@TEST winne]# svn commit  -m "test" testsvn.txt   /注释为test


Adding         testsvn.txt


Transmitting file data .


Committed revision 2.                              /版本更新为2了


 


5,user2回window客户端更新版本


回到Windows的客户端看日志, 版本已经更新为2了,注释test,客户端update就可以更新到新的版本了.


phpriji.cn | 网站地图 | 沪ICP备17015433号-1