Linux下SVN安装配置和使用中遇到的问题

两个命令:

svn info :显示版本库信息,svn的下载url等。

svn co https://xxxxx/xxx   wodemulu   (通过我的目录制定co的文件夹)

svn st:显示修改的文件。

=-=========================================

第一章 安装

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

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

 
1 tar xfvz subversion-1.6.1.tar.gz
2 tar xfvz subversion-deps-1.6.1.tar.gz

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

4. 进入解压子目录:

1 cd subversion-1.6.1

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. 添加环境变量:

1 vi /etc/profile

在文件最后加入:
SVNPATH=$PATH:/opt/subversion/bin
export SVNPATH

source /etc/profile #使环境变量生效

###我测试这个时SVNPATH虽然加入了环境变量,但是还是不能在除了/opt/subversion/bin外边执行,报错-bash: svnserve: command not found。

然后我直接PATH=$PATH:/opt/subversion/bin,省去第二步,source一下就成功了。对环境变量学的比较浅,没搞清楚为什么。

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

1 svnserve --version

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

第二章 配置

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

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

1 mkdir –p /opt/svndata/repos

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

1 svnadmin create /opt/svndata/repos

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

3. 修改版本库配置文件

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

各参数功能在配置文件的注释中有说明, 此处配置如下:
[general]
anon-access = none # 使非授权用户无法访问
auth-access = write # 使授权用户有写权限
password-db = /opt/svndata/repos/conf/pwd.conf # 指明密码文件路径
authz-db = /opt/svndata/repos/conf/authz.conf # 访问控制文件

我的linux中指定上边两项的路径如下:

password-db = passwd
authz-db = authz

这样写简单,文件就在svnserve.conf同级目录下
realm = /opt/svndata/repos # 认证命名空间,subversion会在认证提示里显示,并且作为凭证缓存的关键字。版本库路径
其它采用默认配置. 各语句都必须顶格写, 左侧不能留空格, 否则会出错.
其中pwd.conf 与 authz.conf 在新建版本库时系统不会自动创建,需要自己创建。
指令简介:这是svn配置文件的格式,请按照以上格式书写。

4. 配置用户

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

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

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

我的svn的配置:

dev = user1,user2,user3    //配置用户

[/]   //指定的路径为 /

@dev = rw   //指定的权限为rw

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

1 $ svnadmin create /usr/local/svn/newrepos (创建版本库)
2

$ svn import mytree file:///usr/local/svn/newrepos/project(把本机mytree目录树导入版本库中的project下)

例如: svn import /var/www/ file:///usr/local/svn/newrepos/project

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

1

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

例如:svn checkout file:///usr/local/svn/newrepos/project /root/svndata(导出版本库到/root/svndata下)

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

1 svn checkout svn://127.0.0.1/dir

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

 

使用中遇到的问题:

问题一、Error:Can’t connect to host: 由于目标机器积极拒绝,无法连接。
解决办法:首先测试svn的3690端口是否打开:telnet localhost 3690
如果不成功说明服务没有被正常启动,请参考前面步骤。
可以将svn服务加入自启动:

参考:http://blog.csdn.net/lqg1122/article/details/7345671

问题二、Error:No repository found in svn://192.168.1.110/svn/repos/test
解决方法:
A、测试1:
①运行svnserve -d -r e:svn epos est //指定test根目录为服务的根目录
②运行svn://192.168.1.188,可以正常访问修改test。
③运行svn://192.168.1.188/test
出现svn://192.168.1.188/test non-existent in
B、测试2:
①运行svnserve -d -r e:svn epos //指定test上层目录为服务的根目录
②运行svn://192.168.1.188/test,可以正常访问修改Repository
③运行svn://192.168.1.110
出现Error:No repository found in svn://192.168.1.188
C、结论:
①SVN服务启动时指定的根目录不同,会影响相同URL的访问结果。
②SVN在访问指定路径时会从服务的根目录下寻找,即基于我们启动服务时指定的根目录。
③svn://192.168.1.188指向默认的test
svn://192.168.1.188/test指向test
④测试1失败是因为已经把路径直接指向了test的根目录。
⑤测试2失败是因为只是把路径指向了test的上层目录。
解决如下:
svn://192.168.1.188/repos/test而不是 svn://192.168.1.188/svn/repos/test

问题三:提交时发生错误

$:svn ci

svn: Commit failed (details follow):
svn: Could not use external editor to fetch log message; consider setting the $SVN_EDITOR environment variable or using the --message (-m) or --file (-F) options
svn: None of the environment variables SVN_EDITOR, VISUAL or EDITOR are set, and no 'editor-cmd' run-time configuration option was found

解决:svn ci -m "添加提交说明信息"。

或者:

问题原因是: 

没有设置svn编辑器的环境变量,主要是import、commit中填写comment要用

在 终端中 sudo vim /etc/bashrc 打开文件

加入:export SVN_EDITOR=vim

如果,保存的时候,无法保存。wq! 强制保存退出

编辑完以后一般需要让配置文件立即生效,可执行命令:
source  /etc/bashrc

问题四:window下的导出版本库没有对号,差号等图标:

1.执行以下"Cleanup"试试。

2.重启试试。

问题五:show log只显示nodate,没有提交信息:

解决:

此问题主要出现在svnserve.conf文件中的anon-access访问权限的设置问题上。使用SVN客户端SHOW LOG时,
1.找到你SVN版本库下conf文件夹下的svnserve.conf文件
2.打开svnserve.conf文件,将其中名为anon-access的一项设置为 anon-access = none。
这样的话,日志文件即可显示正常。
svn修改配置文件不需要重启,直接生效。如果修改为none仍旧不显示日志,可以提交一个版本后再查看。
原文地址:https://www.cnblogs.com/leezhxing/p/3473777.html