怎么在linuxlinux安装svn服务器器上部署svn

博客访问: 684874
博文数量: 332
博客积分: 9995
博客等级: 中将
技术积分: 4359
注册时间:
分类: LINUX 22:14:08
通常,很多Linux发行版已经自带了svn软件,安装系统时候选择即可。因此,本文并不讲解如何安装svn相关软件,而是重点总结一下如果使用svnserve服务器来构建自己的代码仓库,并且允许别人远程访问。本文的整个内容参考了svn手册。 一、新建并初始化版本库
1.新建代码仓库# svnadmin create /home/myrepos这样,我们就在/home目录下新建了版本库myrepos。2.初始化代码仓库#mkdir -p code/{branches,tags,trunk}按照svn手册上的建议,我们版本库的布局采用branches/tags/trunk这样的三个目录。然后可以将代码直接拷贝的trunk目录,也可以随后采用svn add的方式添加。&#svn import code file: ///home/myrepos将我们构造好的版本库布局(以及代码,如果已经拷贝到trunk下的话)提交到版本库。由于这里我们是在本地操作,因此可以直接使用file协议方式提交。格式为:file:// + 版本库绝对的路径&OK,到这里我们已经构建了一个本地版本库,可以再本地使用svn ci的方法得到版本库的副本了。如果前面只是提交了版本库布局,而没有提交代码的话,则可以通过如下命令,提交版本代码:#svn co file: ///home/myrepos/trunk repos通常只从主线目录trunk下取出源码,放在了新建的repos目录。然后可以将源码拷贝到repos目录。执行以下两条命令将代码添加的版本库。#svn add *#svn ci * -m "Committed codes"首先需要将拷贝的代码加入到当前的副本中,然后将代码提交到版本库。&二、配置并启动svnserve1. 配置svnserve这一步主要完成远程用户访问版本的权限。在版本库目录下有个conf目录:home/myrepos/conf,该目录包含三个文件:authz,passwd,svnserve.conf。(1)svnserve.conf&此文件重点的设置内容如下:anon-access = readauth-access = writepassword-db = passwdauthz-db = authz其中,anon-acces s和auth-access分别代表设置匿名用户和授权用户的访问权限。read代表只读,write代表可读可写,还有一个none,代表禁止访问。如果不想让匿名用户访问的话,可以设置anon-access = none。password-db为保存版本库的用户名和密码,通常为conf目录下的passwd文件。authz-db指向的文件,主要用于将用户进行分组,并赋予不同的组不同的权限。譬如有多个目录时,设置某个组的用户只可以访问其中的那些目录。(2)passwd如前面介绍,这个文件的主要内容如下[users]harry = harrysecretsally = sallyssecret以上两行就是可以访问版本库的用户名和密码。格式为:user = passwd。(3)authz[groups]# harry_and_sally = harry,sally&# [/foo/bar]# harry = rw# * =&# [repository:/baz/fuz]# @harry_and_sally = rw# * = r以上就是authz文件的格式。先给用户分组,然后分别设置每个组的工作目录以及权限等。本文的讲解并未用到authz的配置。&2. 启动svnserve#svnserve -d -r /home/svnserve将以守护进程的方式运行。同时,通过-r选项指定了版本库的目录。这个目录可以是版本库的上级目录(/home),也可以是版本库的目录(/home/myrepos)。具体的区别会在后面讲到。当然,也可以不用-r指定。&三、远程访问svnserve。假设版本服务器的地址为10.1.1.1,那么用户可以在远程linux端输入命令:#svn checkout svn://10.1.1.1/myrepos myrepos这样版本库的所有内容都被check出来,存放在当前目录myrepos下。这里相当于使用svn协议,不用搭建http服务器。&如果启动svnserve的时候,-r选项指定的是版本库的目录,譬如/home/myrepos,那么检出版本的时候,执行的命令为:#svn checkout svn://10.1.1.1/ myrepos&如果启动svnserve是没有指定-r选项,则要输入版本库的绝对路径:#svn checkout svn://10.1.1.1/home/myrepos myrepos&四、容易出现的问题
在访问svnserve时,遇到了不少的问题,大致总结一下:
1. 这一步最容易避免,一定要记得启动svnserve。
2. 记得要正确的修改配置文件svnserve.conf和passwd。
3. 保证版本库服务器没有配置限制远程访问svnserve的规则。有时在访问svn服务器的时候,会提示服务器积极拒绝链接。简单起见,可以看看iptables -L INPUT和iptables -L OUTPUT有没有限制访问的规则。
4. 要保证输入版本库的URL正确。后记:1. 版本库的初次导入可以采用多种方式:
(1)直接构建好版本库目录,并将源码拷贝的对应的位置,然后svn import即可;
(2)先用svn checkout取出版本,然后构建目录和源码,执行svn add 并且svn commit即可。
2. 导入或者提交文件类型的控制
&&& svn客户端是可以配置忽略哪些些文件,比如说我们不想提交*.o之类的文件。那么可以通过设置svn:ignore或者global-ignore来进行过滤相关的文件。通常默认的情况就会过滤掉*.o, *.so,*.a等被svn认为是中间生成的文件。我本人使用的客服端不管是WIN的还是Linux的都是这种默认情况。
&&& 但是,如果有时基于某种需要,或者是导入一个别人之前维护的工程,里面有些*.so,*.a文件必须保留,那么如果在第一次import的时候全部导入呢?曾经问过有些朋友说,svn add或者svn import是可以直接把这种文件导入到版本库的。但是我个人进行测试的时候,确实导入不进去,除非你直接svn add这个文件,然后提交应该就可以了。
&&& 如果这样的文件比较多,而且比较分散,那么如何解决呢?看一下svn import和svn add这两个命令的帮助,都有--no-ignore选项。这个选项的功能就是执行相应动作的时候,不忽略任何文件。那么执行以下两条命令:
svn import [source] [repository] --no-ignore
svn add [source] --no-ignore
会自动将source目录下所有的内容全部import或者add。因此,通过--no-ignore选项,可以满足提交一些特殊文件的需求。3. 用一个旧版本的svnadmin创建的版本库,直接拷贝到另外一台svn版本比较高的PC上使用时,发现提示数据库版本不匹配。解决的方法:
(1)导出旧的版本库内容,包含版本信息
具体使用的命令为svnadmin dump, 详细使用方法参考手册。该命令的格式为:
svnadmin dump REPOS_PATH [-r LOWER[:UPPER]] [--incremental]
如果我将版本库完整的信息都倒出来的话,执行如下命令:
# svnadmin dump old_repos > repos.dump
默认版本库dump的时候是输出在终端的,通过重定下输出到repos.dump文件里面。该文件实际是文本文件。
(2)导入旧版本库的内容
在需要导入的位置,新建一个版本库
# svnadmin create new_repos
然后将repos.dump文件导入到新的版本库:
# svnadmin load new_repos < repos.dump
该命令成功执行完毕之后,新的版本库中已经包含了old_repos版本库中的所有版本内容。svnadmin dump和svnadmin load命令都支持导入/导出某个指定revsion或者某个指定范围的所有revision。该部分后记参考了如下连接,在此表示感谢:
阅读(7223) | 评论(0) | 转发(1) |
给主人留下些什么吧!~~
请登录后评论。Linux安装SVN服务器Linux安装SVN服务器乐观一下百家号1.yum安装SVN我们通过yum的方式来安装svn,具体操作如下:2.配置SVN接下来,我们需要创建SVN数据的存储根目录3.启动SVN我们启动SVN,并指定svn的数据根目录,并检查svn是否启动成功4. 建立项目版本库创建svn的版本库,比如取名qfhl,命令为svnadmin create具体操作如下:5.修改SVN版本库配置文件在/huangguizhao/svndata/qfhl/conf下面有多个配置文件注意:一个重要的好习惯,修改系统配置文件前,记得要备份!!!修改配置文件的细节如下:6.创建用户,授权访问指定SVN仓库注意:我们的密码和权限设置都在conf目录下编辑passwd文件,创建账号及密码编辑authz文件,配置用户可以访问的仓库配置如下:表示两个用户对仓库都有读写的权限。最后重启下svn的服务,然后就可以了7.客户端访问SVN服务我们通过客户端来访问我们Linux的SVN访问地址:Svn://192.168.10.170/qfhl用户名:hgz密码:hgz为了让大家的学习成本更低,制作更加可操作性的文档,我说制作这个文档花了解决两个小时,你信吗?本文由百家号作者上传并发布,百家号仅提供信息发布平台。文章仅代表作者个人观点,不代表百度立场。未经作者许可,不得转载。乐观一下百家号最近更新:简介:今天不起眼的努力定会成就明天的了不起作者最新文章相关文章Linux下安装SVN服务端简明教程_服务器应用_Linux公社-Linux系统门户网站
你好,游客
Linux下安装SVN服务端简明教程
来源:Linux社区&
作者:Linux
使用yum安装非常简单:
yum install subversion
我们这里在/home下建立一个名为svn的仓库(repository),以后所有代码都放在这个下面,创建成功后在svn下面多了几个文件夹。
[root@localhost /]
[root@localhost home]
[root@localhost home]
[root@localhost home]
README.txt
我们这里特别关注一下conf文件夹,这个是存放配置文件的
[root@localhost home]
[root@localhost conf]
svnserve.conf
authz 是权限控制文件
passwd 是帐号密码文件
svnserve.conf 是SVN服务配置文件
接下来我们依次修改这3个文件。
配置passwd
[root@localhost conf]
test1=123456
test2=123456
上面的例子中我们创建了2个用户,一个test1,一个test2
[root@localhost conf]
liuxianan=rw
上面配置的含义是,liuxianan对/home/svn/下所有文件具有可读可写权限,test只有只读权限,除此之外,其它用户均无任何权限,最后一行*=很重要不能少。
拓展:使用用户分组
这个我一般不用,但是记录下来。
还是这个文件:
[root@localhost conf]
group1 = liuxianan
group2 = test1,test2
@group1 = rw
@group2 = r
上面配置中创建了2个分组,分组1的用户可读可写,分组2的用户只读。
格式说明:
版本库目录格式:[&版本库&:/项目/目录]@&用户组名& = &权限&& 用户名& = &权限&
配置svnserve.conf
[root@localhost conf]
打开下面的5个注释
anon-access = read
auth-access = write
password-db = passwd
authz-db = authz
realm = /home/svn
最后一行的realm记得改成你的svn目录
打开注释时切记前面不要留有空格,否则可能有问题(网上说的,我没有亲测)
启动与停止
[root@localhost conf]
[root@localhost conf]
上述启动命令中,-d表示守护进程, -r 表示在后台执行。停止还可以采用杀死进程的方式:
[root@localhost conf]
00:00:00 svnserve -d -r /home/svn
0 22:05 pts/0
00:00:00 grep svnserve
[root@localhost conf]
最后来个总的截图:
客户端连接
这里使用TortoiseSVN,输入地址svn://你的IP 即可,不出意外输入用户名和密码就能连接成功了。
默认端口3690,如果你修改了端口,那么要记得加上端口号。
总的来说,如果你不需要杂七杂八的权限配置只是自己一个人用的话,安装配置还是比较简单的,并不像网上说的那么麻烦,我按照网上的方法一次性成功了。
扩展:yum安装路径
以svn为例:
# rpm -qa | grep subversion
subversion-1.6.11-15.el6_7.x86_64
# rpm -ql subversion-1.6.11-15.el6_7.x86_64
/usr/share/doc/subversion-1.6.11
/usr/share/doc/subversion-1.6.11/BUGS
/usr/share/doc/subversion-1.6.11/CHANGES
rpm -qa 查询所有安装的rpm包,可以配合grep命令。
rpm -qi 查询某个具体包的介绍。
rpm -ql 列出某个具体包的所有文件
rpm几个默认安装路径:
一些设置文件放置的目录
一些可执行文件
/usr/lib64
一些程序使用的动态函数库
/usr/share/doc
一些基本的软件使用手册与帮助文档
/usr/share/man
一些man page文件
14.04 下搭建SVN服务器 SVN://&
6.2 SVN搭建 (YUM安装)
CentOS 6.5部署Apache+SVN&
Apache+SVN搭建SVN服务器
Windows下SVN服务器搭建和使用 + 客户端重新设置密码
Ubuntu Server 12.04 安装 SVN 并迁移 Virtual SVN数据
Ubuntu Server搭建SVN服务以及迁移方法
Subversion (SVN) 的详细介绍:Subversion (SVN) 的下载地址:
本文永久更新链接地址:
相关资讯 & & &
   同意评论声明
   发表
尊重网上道德,遵守中华人民共和国的各项有关法律法规
承担一切因您的行为而直接或间接导致的民事或刑事法律责任
本站管理人员有权保留或删除其管辖留言中的任意内容
本站有权在网站内转载或引用您的评论
参与本评论即表明您已经阅读并接受上述条款如何在linux下安装配置svn服务器_百度知道
如何在linux下安装配置svn服务器
&#xe6b9;答题抽奖
首次认真答题后
即可获得3次抽奖机会,100%中奖。
ForeverOpp知道合伙人
ForeverOpp
采纳数:69
获赞数:248
apt-get install subversion
匿名用户知道合伙人
按照这个教程来操作,挺不错的。
fendou375知道合伙人
采纳数:29
获赞数:118
擅长:暂未定制
百度一下,一大堆
为你推荐:
其他类似问题
您可能关注的内容
个人、企业类
违法有害信息,请在下方选择后提交
色情、暴力
我们会通过消息、邮箱等方式尽快将举报结果通知您。博客分类:
linux svn安装部署
使用yum search subversion获取需要安装的包
[root@localhost ~]# yum search subversion
subversion.i386 : Modern Version Control System designed to replace CVS
subversion-devel.i386 : Development package for Subversion developers.
subversion-javahl.i386 : JNI bindings to the Subversion libraries
subversion-perl.i386 : Perl bindings to the Subversion libraries
subversion-ruby.i386 : Ruby bindings to the Subversion libraries
依次安装以上的的subversion文件
yum install subversion subversion-devel subversion-javahl subversion-perl subversion-ruby
===========================================
安装完毕后,建立linux SVN创库文件
mkdir /svn
cd /svn
mkdir repos
svnadmin create repos
//付权限
chmod 755 /svn
======================================
编辑/svn/repos/conf/svnserve.conf
vi /svn/repos/conf/svnserve.conf
解开注释,记住这里的文件命令都必须抵头写,不能留空格,否则报错
anon-access = read
auth-access = write
password-db = passwd
authz-db = authz
============================================
vi /svn/repos/conf/passwd
user=pwd
如:tearsky=123456
用户:就是tearsky,密码就是123456
===============================
vi /svn/repos/conf/authz
追加下记文字
[groups]
# harry_and_sally = harry,sally
# harry_sally_and_joe = harry,sally,&joe
develop = zhuzhengling,zhangqiyu,zhangmengying,baoxiufen
# [/foo/bar]
# harry = rw
# &joe = r
# * =
# [repository:/baz/fuz]
# @harry_and_sally = rw
# * = r
[repos:/]
lisb=rw
@develop=rw
[/]
*=r
------------*=r 设置组,只有读取权限,可设置一个readTest=r,限制其他人访问svn,如果是rw表示可读可写
=======================================================
执行svnserve -d -r /svn/repos/ 启动服务
-d 启动,-r路径
==============================linux svn apache安装========================
svn安装同上
apache 安装
通过yum search httpd,找出需要安装的文件,
[root@TTenv conf.d]# yum search httpd
Loaded plugins: fastestmirror
Loading mirror speeds from cached hostfile
* base: mirrors.btte.net
* extras: mirrors.btte.net
* updates: mirrors.btte.net
=========================================================================== Matched: httpd ============================================================================
mod_ssl.x86_64 : SSL/TLS module for the Apache HTTP server
system-config-httpd.noarch : Apache configuration tool
centos-ds.x86_64 : CentOS Directory, Administration, and Console Suite
httpd.x86_64 : Apache HTTP Server
httpd-devel.i386 : Development tools for the Apache HTTP server.
httpd-devel.x86_64 : Development tools for the Apache HTTP server.
httpd-manual.x86_64 : Documentation for the Apache HTTP server.
mod_dav_svn.x86_64 : Apache server module for Subversion server.
yum install -y httpd....进行安装
[root@TTenv conf.d]# yum install -y mod_ssl system-config-httpd centos-ds httpd httpd-devel httpd-devel httpd-manual mod_dav_svn
安装完毕后,
新建用户
输入:htpasswd -c /svn/passwd.conf lisb& 回车
输入两次密码
-c 只有文件不存在的时候才用,有这个文件了,就不用-c了,/svn新建的文件在/svn下面的passwd.conf,可以任意指定,lisb 里账号名字
如:创建新用户 htpasswd /svn/passwd.conf zhuzhengling
再复制/svn/repos/conf里面的authz文件到/svn下面,修改名字为authz.conf,也可以任意指定目录
cp /svn/repos/conf/authz /svn/authz.conf
authz.conf内容如下
[root@TTenv svn]# vi authz.conf
[groups]
dev_user=chenbs,lisb,zhuyt,tanggy,yangxz
#dev_user=lisb,zhuzhengling,zhangqiyu,baoxiufen,zhangmengying
[/]
@dev_user=rw
模块加载
//一般来说下面两个文件会自动弄好,不用我们管
打开/etc/httpd/conf.d/subversion.conf,这个文件中的如下两行取消注释。
LoadModule dav_svn_module&&&& modules/mod_dav_svn.so
LoadModule authz_svn_module&& modules/mod_authz_svn.so
相应的so文件已经自动copy到了APACHE/modules。这些工作就不用自己动手了。
版本库控制
[root@TTenv svn]# vi /etc/httpd/conf.d/subversion.conf
添加如下内容
&Location /svn/&#svn在访问的时候用到,http://ip/svn&& 3.DAV svn&&&&&&&&&& #不用修改&&
DAV svn
SVNParentPath /svn#资料库的绝对地址
SVNListParentPath on
AuthType Basic
AuthName "Subversion repository"
AuthzSVNAccessFile /svn/authz.conf#权限文件
AuthUserFile /svn/passwd.conf#账号文件
Require valid-user
&/Location&
=========================
在这里就设置完成了
重启httpd
service httpd restart
==============================
注意事项
注意:
(1)单个版本库就是SVNPath /svn/svnroot/icec跟./svnadmin create /svn/svnroot/icec目录要一样,要不忙死你……【这个是对单个版本库】,多个版本库知道svn的主目录,
我这就是 SVNParentPath /svn/svnroot
(2)AuthzSVNAccessFile是权限控制文件,单个版本库不需要,多个版本库要设置不同版本库的权限
(3)目录svnroot目录的权限设置成755
四、验证安装
打开浏览器,输入地址为http://服务器ip/
出现登陆窗口,输入用户名跟密码,
如果可以正常打开如上页面则说明安装配置正常,可以正常使用了,在页面上可以看到由于目前资料库中没有内容,因此看到的内容为空。
五、导入数据到资料库
Cd /usr/local/subversion/bin
./svn import /要导入的目录 file:///svn/svnroot -m “说明文字”
重新打开浏览器,输入地址http://服务器ip/svn,输入用户名密码。
安装配置就完成了。
以下摘抄于http://www.dasairen.com/Centos/.html
六、可能遇到的问题
整个过程不会一帆风顺的,这里介绍一些可能遇到的问题。
1、【这个问题是我创建单个版本库时遇到的】安装好了后,浏览器打开http://服务器ip/svn,登陆出现不了页面,出现:
&D:error&
&C:error/& &m:human-readable errcode="2"& Could not open the requested SVN filesystem &/m:human-readable& &/D:error&
解决:这是httpd.conf里的&Locate svn&中的SVNPath指向错误没指到创建的资料库
2、输入账号密码提示不能认证,查看APACHE的/etc/httpd/logs/error_log,有如下提示:
[Tue Oct 05 18:07:09 2010] [error] [client 125.223.118.90] (13)Permission denied: Could not open password file: /svn/svnroot/passwd
[Tue Oct 05 18:07:09 2010] [error] [client 125.223.118.90] access to /svn failed, reason: verification of user id 'test' not configured
从日志看,因为检查过配置文件没有拼错,所以可以肯定是权限问题。从ls命令的结果可以看出,由于passwd的权限是没有问题的。
后来看了一位朋友的帖子【Linux环境下搭建APACHE+subversion+svnmanager】的启发,可能是SELinux引发的问题,
于是执行命令:
chcon -R -h -t httpd_sys_content_t /svn/svnroot
后来还是不行。执行以下命令后搞定
chcon -R -h -t httpd_sys_content_t /svn
总结教训:还是linux不熟悉的原因造成的,我是linux的新手。看来得恶补linux的基本知识。
3、组(group)设置
在TortoiseSVN中做Commit操作时可能遇到如下错误:
can't open file '/svn/svnroot/telnet/db/txn-current-lock': Permission denied
可以将telnet的所属组设置为APACHE
chgrp -R APACHE& /svn/svnroot/telnet
4、文件夹创建删除属性
在TortoiseSVN中做Commit操作时可能遇到如下错误:
can't open '/svn/svnroot/telnet/db/tempfile.tmp': Permission denied
can't make directory '/svn/svnroot/telnet/dav/activities.d': Permission denied
设置telnet 群组的访问方式为“创建和删除文件”
5、The URI does not contain the name of a repository. [403, #190001
这个原因是因为httpd.conf文件里SVNParentPath
加上这行代码后必须在你的访问URL中访问你的SVN下的具体的库
如果开启父目录显示就不会有这个问题了,即加上SVNListParentPath on
还有意Location /svn/的svn后面有一条斜线。
//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
#停止 HTTPD服务
[root@zhangxx etc]# service httpd stop
停止 httpd:[& 确定& ]
#启动httpd服务
[root@zhangxx etc]# service httpd start
启动 httpd:[& 确定& ]
#重起HTTD服务
[root@zhangxx etc]# service httpd restart
停止 httpd:[& 确定& ]
启动 httpd:[& 确定& ]
#让httpd 在机器启动的时候在运行级别上停止
[root@zhangxx etc]# chkconfig --level 345 httpd off
[root@zhangxx etc]# chkconfig --list |grep httpd
httpd&&&&&&&&&& 0:关闭& 1:关闭& 2:关闭& 3:关闭& 4:关闭& 5:关闭& 6:关闭
#让httpd 在机器启动的时候在运行级别上启动
[root@zhangxx etc]# chkconfig --level 345 httpd on
[root@zhangxx etc]# chkconfig --list |grep httpd
httpd&&&&&&&&&& 0:关闭& 1:关闭& 2:关闭& 3:启用& 4:启用& 5:启用& 6:关闭
查看svnserve进程
ps -ef|grep svnserve
杀进程
killall svnserve
启动:
svnserve -d -r /svn/repos/
svnserve -d -r /svn/nj_repository/
查看httpd 进程
ps -ef|grep httpd
启动 httpd
service httpd stop
service httpd start
创建版本库
svnadmin create /svn/njsvnresource
svn import /home/oss file:///svn/nj_repository/jiashitong/oss -m "导入文件"
svnserve -d -r /svn/nj_repository/jiashitong --config-file=/svn/nj_repository/jiashitong/svnserve.conf
svnserve -d -r /data/svn --config-file=/data/svn/svnserve.conf
tail -200f /etc/httpd/logs/error_log
浏览: 1574 次
来自: 沈阳
(window.slotbydup=window.slotbydup || []).push({
id: '4773203',
container: s,
size: '200,200',
display: 'inlay-fix'

我要回帖

更多关于 linuxsvn服务器搭建 的文章

 

随机推荐