Linux下SVN安装配置以及使用

第一章 安装

1. 采用源文件编译安装。源文件共两个,为:
subversion-1.6.21.tar.gz (subversion 源文件)
subversion-deps-1.6.21.tar.gz (subversion依赖文件)
注意文件版本必须一致,否则很容易产生各种奇怪的问题.

2. 上传以上两个文件到服务器上,解压。解压命令为:

 
 tar xfvz subversion-1.6.21.tar.gz
tar xfvz subversion-deps-1.6.21.tar.gz

指令简介:tar 为解压命令,xfvz为tar命令的参数,用于解压tar.gz格式压缩的文件。
 
3. 解压后生成 subversion-1.6.21 子目录,两个压缩包解压后都会自动放到此目录下,不用手动更改。

4. 进入解压子目录:

cd subversion-1.6.21

5. 执行 ./configure –prefix=/opt/subversion 进行配置设定并指明安装目录. 注意prefix前是两个减号. 默认不带BDB包, 所以默认使用的是FSFS模式. 若想使用BDB模式需另外下载BDB包.建议使用FSFS模式.两种模式比较参考以下链接:

http://doc.iusesvn.com/show-21-1.html

指令简介:configure命令用于检查安装平台和目标特征,prefix用于指定路径。

6. 执行 make 编译.

7. 执行 make install 安装.

8. 添加环境变量:

 vi /etc/profile

在文件最后加入:
export PATH=$PATH:/usr/local/svn/bin

9. 测试SVN是否安装成功,执行:

svnserve --version

如果显示版本信息, 则安装成功.

第二章 配置

本系统采用为每个项目单独建一版本库的策略。配置文件,密码文件,访问控制文件等都放在版本库的conf目录下。所以每次开始一个新项目都必须新建一个版本库,并重新配置各配置文件。还有很重要的一条,要求各组员重新配置客户端,包括服务器版本库路径,本地路径等信息。

1. 建立版本库目录(可建立多个,新建库后以下各项都需重新配置。注意区别安装目录与版本库目录,以下讲的都是版本库目录)

mkdir –p /opt/svndata/repos

2. 建立svn版本库(与上面目录对应)

 svnadmin create /opt/svndata/repos

执行此命令后svn自动在repos目录下添加必须的配置文件.
注意:版本库不同于一般的文件夹, 直接在操作系统上新建文件无法被SVN识别, 必须使用import等命令将文件导入版本库.
此为svn内部指令,create用于新建版本库。请使用svn help查看详细说明。

3. 修改版本库配置文件

 vi /opt/svndata/repos/conf/svnserve.conf

各参数功能在配置文件的注释中有说明, 此处配置如下:
[general]
anon-access = none # 使非授权用户无法访问
auth-access = write # 使授权用户有写权限
password-db = /opt/svndata/conf/pwd.conf # 指明密码文件路径
authz-db = /opt/svndata/conf/authz.conf # 访问控制文件
realm = /repos # 认证命名空间,subversion会在认证提示里显示,并且作为凭证缓存的关键字。
其它采用默认配置. 各语句都必须顶格写, 左侧不能留空格, 否则会出错.(这个参数跟之后访问的地址有关)
其中pwd.conf 与 authz.conf 在新建版本库时系统不会自动创建,需要自己创建。
指令简介:这是svn配置文件的格式,请按照以上格式书写。

4. 配置用户

1vi /opt/svndata/repos/conf/pwd.conf

输入以下内容:
[users]
username1 = password1
username2 = password2
可以添加多个,此为用户名密码对。

5. 配置权限
vi /opt/svndata/repos/conf/authz.conf
指令简介:此配置文件采用“基于路径的授权”策略,中括号里指定路径,以下列出对各用户的授权。包括只读r,读写rw。没有列出的用户,则不允许访问。还可以对用户分组,具体请参考svn手册,以下是简单例子:
[/]
user1 = rw
user2 = r

注意:

* 权限配置文件中出现的用户名必须已在用户配置文件中定义。

* 对权限配置文件的修改立即生效,不必重启svn。

权限:注意配置文件格式,前面不能有空格

用户组格式:

[groups]

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

————————

[groups]

Svnadmin = shengchao,yingzi

g_chengxu= test1,test2,test2

————————

其中,1个用户组可以包含1个或多个用户,用户间以逗号分隔。

版本库目录格式:

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

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

<用户名> = <权限>

其中,方框号内部分可以有多种写法:

/,表示根目录及以下。根目录是svnserve启动时指定的,我们指定为/www/svndata。这样,/就是表示对全部版本库设置权限。

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

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

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

权限主体可以是用户组、用户或*,用户组在前面加@,*表示全部用户。权限可以是w、r、wr和空,空表示没有任何权限。

示例:

[groups]

admin = shengchao

[/]

@admin = rw

[repos1:/abc/aaa]

yingzi = rw

[repos2:/pass]

yingzi =

6. 使用import导入文件
新建好的版本库是空的,需要导入工作目录。

$ svnadmin create /usr/local/svn/newrepos
 $ svnimport mytree file:///usr/local/svn/newrepos/some/project

但是在导入后,用来的目录树并没有转换成工作拷贝,为了开始工作,还是需要运行svn checkout导出一个工作拷贝。因为导入后,文件在版本库中是以特殊的形式存在db文件夹中的,不能以明文的方式查看。必须使用svn checkout导出工作副本(workcopy)才能以正常方式查看。

svn checkout file:///usr/local/svn/newrepos/some/project workcopy

7. 启动服务
执行svnserve –d –r /opt/svndata/ 启动服务, 以deamon方式运行。
本系统采用svnserve方式, 这是小团队项目的推荐方法. 这种方法维护最少, 配置最简单.
指令简介:此指令用于启动svn服务,-d指明以守护模式运行,svn自动在3690端口监听。3690是默认端口,可以使用“–listen-port=”或者“–listen-host=”来指定其它端口。-r选项用来指定svn服务的根目录,这样用户就可以使用相对路径访问,而不用提供完整路径。
使用以下命令检出:(svnserver方式)

 svn checkout svn://127.0.0.1/dir

以上为示例。IP需要根据具体情况调整,dir为版本库路径,若在启动时已指定则可省略。
版本库信息在版本库文件夹里,所以要删除版本库只需要删除版本库所在的文件夹即可。
另外工作副本只是自己维护的文件夹,可以用Windows直接删掉,对别人没有影响。千万不要使用版本库的删除命令,否则版本库里的内容也会被删除。

 ------------------------------------------------------------------------------------------

配置两个资源库:svn默认端口是3690

 1.启动命令: svnserve -d -r 版本库路径 --listen-host 192.168.1.178  

如:svnserve -d -r /opt/svndata --listen-host 192.168.1.178

启动时遇到的问题: 

启动svnserve时出现cannot bind server socket:address already in use 

解决方法: 
方法一:找出svnserve id 杀死掉进程 

netstat -ntlp 

kill -9 id 

方法二:重新指定一个端口号(默认端口3690) 

svnserve -d --listen-port 3691 -r /opt/svndata/repos

2.检查是否启动成功:(查看是否存在svnserve 进程)

ps -ef|grep svnserve

 

貌似更简单的安装方法:好尴尬

一:安装
1、下载安装包,这里下载1.7.13版本

1
wget http://archive.apache.org/dist/subversion/subversion-1.7.13.tar.gz

2、编译 --without-berkeley-db取消使用berkeley-db,采

1
./configure --prefix=/usr/local/subversion --without-berkeley-db

出现了错误

1
configure: error: no suitable apr found

在网上找了一下,是因为缺少必要的依赖文件,
运行./get-deps.sh下载一下文件

1
./get-deps.sh

之后再./configure --pre...一下
make && make install

 

发表评论

电子邮件地址不会被公开。 必填项已用*标注