linux SVN.docx
- 文档编号:6439129
- 上传时间:2023-01-06
- 格式:DOCX
- 页数:8
- 大小:20.69KB
linux SVN.docx
《linux SVN.docx》由会员分享,可在线阅读,更多相关《linux SVN.docx(8页珍藏版)》请在冰豆网上搜索。
linuxSVN
Linux下SVN服务器的搭建与配置[复制链接]
上一主题下一主题
只看楼主倒序阅读使用道具楼主发表于:
2008-01-17
下载最新的svn压缩包http:
//subversion.tigris.org/downloads/subversion-1.4.5.tar.gz
//解压SubVersion安装包(root用户进行下面的操作)#tarxvzfsubversion-1.4.5.tar.gz
//进入解压后的目录
#cdSubversion-1.4.5
//配置subversion安装
#./configure--with-apxs=/usr/local/apache2/bin/apxs--prefix=/usr/local/subversion
--with-apr=/usr/local/apache2--with-apr-util=/usr/local/apache2--with-ssl--with-zlib
--enable-maintainer-mode
#make
//安装
#makeinstall
//创建库文件所在的目录(svnroot用户进行下面的操作)
#mkdir/home/svnroot/repository
//进入subversion的bin目录
#cd/usr/local/subversion/bin
//创建仓库"test"
#./svnadmincreate/home/svnroot/repository/test
#cd/home/svnroot/repository/test
//看看是不是多了些文件,如果是则说明Subversion安装成功了
#ls–l
#cd/usr/local/subversion/bin
//这条语句将把路径/home/user/import下找到的文件导入到你创建的Subversion仓库中去,
//提交后的修订版为1。
#./svnimport/home/user/importfile:
///home/svnroot/repository/test–m"注释"
//不让其他人有该目录的权限
#chmod700/home/svnroot/repository
修改Apache配置文件
#cd/usr/local/apadche2/bin
//启动Apache
#./apachect1start
#vi/usr/local/apache2/conf/httpd.conf
//在最下面添加
LoadModuledav_svn_modulemodules/mod_dav_svn.so
LoadModuleauthz_svn_modulemodules/mod_authz_svn.so
DAVsvn
SVNParentPath/home/svnroot/repository///svn父目录
AuthzSVNAccessFile/home/svnroot/repository/authz.conf//权限配置文件
AuthTypeBasic//连接类型设置
AuthName"Subversion.zoneyump"//连接框提示
AuthUserFile/home/svnroot/repository/authfile//用户配置文件
Requirevalid-user//采用何种认证
//其中authfile是通过"htpasswd[–c]/home/svnroot/repository/authfileusernamepassword"来创建的
//"Requirevalid-user"告诉apache在authfile中所有的用户都可以访问。
如果没有它,
//则只能第一个用户可以访问新建库
6.权限管理
1)增加用户
#htpasswd[-c]/home/svnroot/repository/authfilewooin
//第一次设置用户时使用-c表示新建一个用户文件。
回车后输入用户密码,完成对用户的增加
#htpasswdauthfile用户名(加入新的用户)
2)权限分配
#vi/home/svnroot/repository/authz.conf
[test:
/]//这表示,仓库test的根目录下的访问权限
wooin=rw//test仓库wooin用户具有读和写权限
bao=r//test仓库bao用户具有读权限
[test2:
/]//test2仓库根目录下的访问权限
wooin=r//wooin用户在test2仓库根目录下只有读权限
bao=//bao用户在test2仓库根目录下无任何权限
[/]//这个表示在所有仓库的根目录下
*=r//这个表示对所有的用户都具有读权限
#[groups]//这个表示群组设置
#svn1-developers=wooin,bao//这个表示某群组里的成员
#svn2-developers=wooin
#[svn1:
/]
#@svn1-developers=rw//如果在前面加上@符号,则表示这是个群组权限设置
将这个设置完成后。
重启Apache,就可以通过
http:
//localhost/svn/test
这个URL来访问仓库了,当然,受权限的限制,必须是合法用户才能访问且具有相应的权限
7.一些备忘:
1.svncheckouthttp:
//localhost/svn/hello.world
2.svncommit时的默认编辑器的环境变量$SVN_EDITOR=vi需要手动设定,用kate好像有问题
3.如果linux的登录用户名密码都和svn的其中一个用户名密码相同时,在checkout的时候不会要求输入用户名密码直接就可以checkout出来。
比如:
linux有个用户wooin,svn也有一个用户wooin,并且密码都是一样的,当用wooin登录linux后,执行checkout,可以直接提取出源码文件,不用输入认证信息。
4.在svn使用过程中牵扯到几种权限:
文件系统的权限,linux系统权限,svn用户的权限,apache进程的权限。
文件系统的权限,linux系统权限:
这里相同的意思,就是平时大家使用linux时文件夹和文件的访问权限。
在svn建立仓库,文件夹,配置文件的时候用svnroot用户,并将仓库权限设置为700,不允许其他用户直接通过文件系统查看,只能由svnroot进行管理。
apache进程的权限:
因为所有跟仓库传输的操作都是通过apache进程进行的,所以即使你给svn用户设置了很大的权限,但是apache进程没有访问仓库或者相关文件的权限也没有用,apache进程的权限设置在/usr/local/apache2/conf/httpd.conf文件中配置,找到文件中的这两行:
Userdaemon#将daemon改为svnroot,让apache进程以svnroot的身份运行
Groupdaemon
svn用户的权限:
就是在repository/authz.conf文件中设置的权限信息,是svn用来管理仓库访问权限的。
5.svn服务器设置有两种方式:
http和svnserve。
这里介绍的是http方法
6.在/etc/profile的结尾设置一些svn启动时要做的工作#startapacheserverforsvn
/usr/sbin/apachectlstart
exportSVN_EDITOR=vi
7.APRlibraries安装SVN的时候最好指定--with-apr=和--with-apr-util=参数到Apache安装的根目录
(ServerRoot)下,而不是使用缺省的SVN安装包中自带的apr。
否则如果你安装的Apache
版本不同有可能导致APR库不匹配,出现类似:
Can'tsetpositionpointerinfile'/svn/test/db/revs/1':
Invalidargument的错误。
Updated2006-04-2016:
30--比如说如果你安装的是apache2.2.0版本,就需要在编译安装svn的时候指定
--with-apxs和--with-apr参数到你的apache2.2.0安装目录下:
./configure--divfix=${subversionInstallFolder}/
--with-apxs=${apacheInstallFolder}/bin/apxs/
--with-apr=${apacheInstallFolder}/
--with-apr-util=${apacheInstallFolder}/
--with-ssl/
--with-zlib/
--enable-maintainer-mode
linux下搭建SVN服务器完全手册
很详细,很好,很强大,好喜欢,绝对不是我原创,转载自:
系统环境
RHEL5.4最小化安装(关iptables,关selinux)+ssh+yum
一,安装必须的软件包.
yuminstallsubversion(SVN服务器)
mysql-server(用于codestriker)
httpdmod_dav_svnmod_perl(用于支持WEB方式管理SVN服务器)
sendmail(用于配置用户提交代码后发邮件提醒)
wgetgcc-c++makeunzipperl*(必备软件包)
ntsysvvim-enhanced(可选)
二,基本的SVN服务器配置
1,新建一个目录用于存储SVN所有文件
#mkdir/home/svn
2,新建一个版本仓库
#svnadmincreate/home/svn/project
3,初始化版本仓库中的目录
#mkdirprojectproject/serverproject/clientproject/test(建立临时目录)
#svnimportproject/file:
///home/svn/project-m"初始化SVN目录"
#rm-rfproject(删除临时建立的目录)
4,添加用户
要添加SVN用户非常简单,只需在/home/svn/project/conf/passwd文件添加一个形如“username=password"的条目就可以了.为了测试,我添加了如下内容:
[users]
#harry=harryssecret
#sally=sallyssecret
pm=pm_pw
server_group=server_pw
client_group=client_pw
test_group=test_pw
5,修改用户访问策略
/home/svn/project/conf/authz记录用户的访问策略,以下是参考:
[groups]
project_p=pm
project_s=server_group
project_c=client_group
project_t=test_group
[project:
/]
@project_p=rw
*=
[project:
/server]
@project_p=rw
@project_s=rw
*=
[project:
/client]
@project_p=rw
@project_c=rw
*=
[project:
/doc]
@project_p=rw
@project_s=rw
@project_c=rw
@project_t=rw
*=
以上信息表示,只有pm有根目录的读写权,server_group能访问server目录,client_group能访问client目录,所有人都可以访问doc目录.
6,修改svnserve.conf文件,让用户和策略配置升效.
svnserve.conf内容如下:
[general]
anon-access=none
auth-access=write
password-db=/home/svn/project/conf/passwd
authz-db=/home/svn/project/conf/authz
7,启动服务器
#svnserve-d-r/home/svn
8,测试服务器
#svncosvn:
//192.168.60.10/project
Authenticationrealm:
//192.168.60.10: 3690>92731041-2dae-4c23-97fd-9e1ed7f0d18d Passwordfor'root': Authenticationrealm: //192.168.60.10: 3690>92731041-2dae-4c23-97fd-9e1ed7f0d18d Username: server_group Passwordfor'server_group': svn: Authorizationfailed(server_group没用根目录的访问权) #svncosvn: //192.168.60.10/project Authenticationrealm: //192.168.60.10: 3690>92731041-2dae-4c23-97fd-9e1ed7f0d18d Passwordfor'root': Authenticationrealm: //192.168.60.10: 3690>92731041-2dae-4c23-97fd-9e1ed7f0d18d Username: pm Passwordfor'pm': Aproject/test Aproject/server Aproject/client Checkedoutrevision1.(测试提取成功) #cdproject/server #vimmain.c #svnaddmain.c #svncommitmain.c-m"测试一下我的C程序,看什么看,不行啊? ? " Addingmain.c Transmittingfiledata. Committedrevision2.(测试提交成功) 三,配置SVN服务器的HTTP支持 1,转换SVN服务器的密码 由于SVN服务器的密码是明文的,HTTP服务器不与支持,所以需要转换成HTTP支持的格式。 我写了一个Perl脚本完成这个工作. 脚本内容如下: #cd/home/svn/project/conf/ #catPtoWP.pl #! /usr/bin/perl #writebyhuabo,2009-11-20 usewarnings; usestrict; #openthesvnpasswdfile open(FILE,"passwd")ordie("Cannotopenthepasswdfile! ! ! \n"); #cleartheapachepasswdfile open(OUT_FILE,">webpasswd")ordie("Cannotopenthewebpasswdfile! ! ! \n"); close(OUT_FILE); #begin foreach( if($_=~m/^[^#].*=/){ $_=~s/=//; `htpasswd-bwebpasswd$_`; } } #./PtoWP.pl(先给该脚本加可执行权限,然后执行以转换密码) Addingpasswordforuserpm Addingpasswordforuserserver_group Addingpasswordforuserclient_group Addingpasswordforusertest_group 现在目录下会多一个webpasswd文件。 2,修改httpd.conf,添加关于SVN服务器的内容 编辑/etc/httpd/conf/httpd.conf,在最后添加如下信息: DAVsvn SVNPath/home/svn/project/ AuthTypeBasic AuthName"svnforproject" AuthUserFile/home/svn/project/conf/webpasswd AuthzSVNAccessFile/home/svn/project/conf/authz Satisfyall Requirevalid-user 3,启动HTTPD服务器 #servicehttpdrestart Stoppinghttpd: [FAILED] Startinghttpd: [OK]
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- linux SVN