日期:2014-05-16  浏览次数:20792 次

linux 下的subversion客户端安装
一、下载subversion,http://subversion.tigris.org下载最新版本(subversion-deps-1.6.20.tar.gz,subversion-1.6.20.tar.gz)
二、上传至linux/usr/soft/目录下,依次解压subversion-1.6.20.tar.gz,subversion-deps-1.6.20.tar.gz。
三、进入目录subversion-1.6.20,依次运行
1、./configure --prefix=/home/svnadmin/subversion --without-berkeley-db --with-openssl=/usr/local/ssl
2、make
3、make install
四、安装好客户端之后, 默认安装目录是/usr/local/subversion
五、ln -s /usr/local/subversion/bin/svn /usr/local/bin
测试svn   svn help

六、设置脚本的执行权限
chmod 777 list checkout commit
cp list checkout commit /usr/bin

另==================

前言
SVN服务器有2种运行方式:独立服务器和借助apache。2种方式各有利弊,独立SVN服务器不结合Apache安装使用,连接独立SVN服务器也不用HTTP协议。这是比较快捷的SVN服务器配置方法。本次安装时使用的是独立用品方式。

SVN存储版本数据也有2种方式:BDB和FSFS。因为BDB方式在服务器中断时,有可能锁住数据所以还是FSFS方式更安全一点,我安装时也使用的是FSFS方式。一 下载工具

1. subversion-1.6.17.tar.gz

2. subversion-deps-1.6.17.tar.gz
这两个包可以直接到CSDN去下载,版本要一样,都是必须下载的,否则单独下载第一个包编译时就会提示缺少模块。这两个包下载解压后会解压到同一个目录下,不需要特别指定。

二 解压安装

1. 解压两个包:

在此之前,我已经创建了一个用户svnadmin专门用来安装管理svn的,就解压在/home/svnadmin/目录下

tar -xzvf  subversion-1.6.17.tar.gz

tar -xzvf  subversion-deps-1.6.17.tar.gz
2. 编译安装

./configure --prefix=/home/svnadmin/subversion  --without-berkeley-db

//prefix指定安装的目录,without-berkeley-db表明不使用berkeley数据库

//在这一步有可能不成功,是因为有一些依赖的软件没装,具体见下面“遇到的问题”

make

make install

//也许要sudo,看情况

3. 查看是否安装成功

/home/svnadmin/subversion/bin/svnserve --version

//如果出现SVN的版本则证明安装成功
三 添加环境变量

可以在/etc/profile中添加,这是全局的。其实最好是专门添加一个svnadmin用户,在~/.bashrc中添加即可:

exprot PATH=$PATH:/home/svnadmin/subversion/bin
四 建立仓库

1. 创建目录

mkdir  -p  /home/svnadmin/svndata/repos1

加上参数P,是如果没有父目录则自动创建

注意: /home/svnadmin/svndata在这里将是所有仓库的根目录,repos1是其中的一个仓库。

2. 创建仓库

svnadmin create /svndata/repos1

这里使用SVN将repos1建立为仓库。则在repos1文件夹里会生成一系列对于repos1仓库相应的配置文件
五 配置仓库

1. 查看创建仓库后的文件

进入/svndata/repos1/conf,会发现有几个配置文件,如下图


2. 修改svnserve.conf

vi svnserve.conf

打开这个配置文件,可以看到很多配置项已经注释掉了,只需要按下面这几项修改就可以了

[general]

anon-access = none

auth-access = write

password-db = passwd

authz-db=authz
3. 目录控制文件authz (or叫权限控制文件)

vi authz

默认是没有配置的,要参照下面示例来配置

[groups]

admin = svnadmin

[repos1:/]

@admin = rw

svnadmin = rw
上面的配置权限控制文件的配置格式如下:

[groups]

<用户组名> = <用户1>,<用户2>, ……

[<版本库>:/项目/目录]

@<用户组名> = <权限>

<用户名> = <权限>

其中,方框号内部分可以有多种写法:
/,表示根目录及以下。根目录是svnserve启动时指定的,我们指定为/home/svnadmin/svndata。这样,/就是表示对全部版本库设置权限。

repos1:/,表示对版本库1设置权限

repos2:/occi,表示对版本库2中的occi项目设置权限

repos2:/occi/aaa,,表示对版本库2中的occi项目的aaa目录设置权限

权限主体可以是用户组、用户或*,用户组在前面加@,*表示全部用户。权限可以是w、r、wr和空,空表示没有任何权限。
4. 修改用户密码文件passwd

vi passwd

默认也是没有配置任何用户的,可按下面配置示例配置

[users]

svnadmin = 123456

用户密码的配置格式:

[users]

<用户1> = <密码1>

<用户2> = <密码2>

注意:这里的配置文件,除了注释外每行都必须顶行,否则又会报错了。
五 启动SVN

svnserve -d -r /home/svnadmin/svndata

-d表示在后台运行,-r表示……

注意:这里是/home/svnadmin/svndata,并非/home/svnadmin/svndata/repos1。这是SVN使所有仓库根目录都生效的命令,并非某个仓库。这里必须注意。
六 开启SVN的端口,默认是3690

在测试的时候,在本机可以使用svn,但是到了其他主机(在同一个局域网)就不行了,

错误信息提示:svn: 无法连接主机“192.168.6.74”: 没有到主机的路由

这就是因为防火墙的问题,要保证服务器和客户端都没有屏蔽这个端口
七 基本测试

1. checkout

svn co svn://192.168.6.74/repos1

checkout的时候,会要求输入用户名密码,只有配置了的用户才能验证通过