使用SVN协议访问仓库方法揭秘

本节和大家一起学习一下使用SVN协议访问仓库的方法,主要包括建立仓库,设置授权和访问仓库几个步骤,希望通过本节的介绍大家能够掌握使用SVN协议访问仓库的方法。

使用SVN协议访问仓库

1、创建仓库
正如访问本地仓库一样,开始必须先用svnadmin在存放仓库的目录中创建必须的文件,以形成仓库。
在远端,存放仓库的机器行运行: # svnadmin create /var/svn/repos/
创建的文件和目录有:
  引用
# ll -a /var/svn/repos/

总计 36

drwxr-xr-x 7 root root 4096 07-01 15:21 .
drwxr-xr-x 3 root root 4096 07-01 11:00 ..
drwxr-xr-x 2 root root 4096 07-01 15:21 conf
drwxr-xr-x 2 root root 4096 07-01 15:21 dav
drwxr-sr-x 5 root root 4096 07-01 15:21 db
-r--r--r-- 1 root root    2 07-01 15:21 format
drwxr-xr-x 2 root root 4096 07-01 15:21 hooks
drwxr-xr-x 2 root root 4096 07-01 15:21 locks
-rw-r--r-- 1 root root  229 07-01 15:21 README.txt
一般不要手动去更新、删除、添加上述这些目录或文件的内容,应通过svn客户端来进行管理的工作。

2、设置授权

若通过svn协议访问远端的仓库,必须建立授权关系。svnserve对于每个仓库,都有一个独立的配置文件和独立的用户、权限管理。该文件存放在:
 
引用
repository-path/conf/svnserve.conf
也就是对应在每个仓库的目录下面。使用svnadmin create创建仓库后,就会在对应的位置创建一个示范文件。
以下是一个简单的例子:
  引用
# vi /var/svn/repos/conf/svnserve.conf
[general]
anon-access = read # 允许匿名用户只读访问,若设置为none表示不允许匿名访问
auth-access = write # 通过验证的用户可以读和写
password-db = passwd # 用户保存文件,也可以使用绝对路径来指定位置
authz-db = authz # 权限管理文件
realm = My First Repository # 仓库名称

可通过man svnserve.conf 获取帮助信息。
※ 注意,配置项前面不能有前置空格,否则后续执行svn命令时,会报Option expected错误
然后,在上面指定的用户、权限配置文件中加入相关信息:
  引用
# vi /var/svn/repos/conf/passwd
[users] # 这是固定格式
linuxing = redflag # linuxing是用户名,redflag是明文表示的密码
harry = harryssecret

SVN协议允许访问该仓库的用户都可以在这文件中定义,而对应用户的权限,则在权限配置文件中定义:
  引用
# vi /var/svn/repos/conf/authz
[groups] # 这也是固定格式
users1 = linuxing,harry # 定义属于组的用户
# 可定义仓库中的某个相对路径,如[/],或[/project1]
# 若是多个仓库共享一个权限文件,可以用仓库名加“:”开头来定义,如:[project2:/]
# 这个project2必须是已经由svnadmin create /path/project2 创建好的仓库
[/]
linuxing = rw # 定义某个用户的权限,r是只读、w是可写、留空是不允许访问
@users1 = rw # 定义某个组的权限
* = r # 用“*”号表示其他用户

用户和权限配置文件必须与svnserve.conf中设置的路径相同。若把这两个配置文件放在仓库外,例如:/etc/svn/目录,则允许多个仓库共享同样的配置文件。
用户和权限配置文件保存后即可生效,不需重启svnserve服务。下一步就可以使用SVN协议访问仓库了。

3、访问仓库
在保证远端svnd服务已经启动的情况下: 
引用
# service svnd start
Starting svnd:                                             [确定]
# service svnd status
svnserve (pid 21869) 正在运行...
# netstat -ln|grep 3690
tcp       0      0 :::3690                     :::*                        LISTEN

参考前一篇日志的内容,使用svn客户端即可进行访问: 
引用
# svn import /root/perl svn://localhost/project1 -m 'initialization'
“root”的密码:
认证领域:<svn://192.168.228.135:3690> My First Repository
用户登录名:linuxing
“linuxing”的密码:
新增           /root/perl/tcp_socket_cli.pl
新增           /root/perl/connect.pl
新增           /root/perl/tcp_socket_dt_srv.pl

相关推荐