linux SVN.docx

上传人:b****5 文档编号:6439129 上传时间:2023-01-06 格式:DOCX 页数:8 大小:20.69KB
下载 相关 举报
linux SVN.docx_第1页
第1页 / 共8页
linux SVN.docx_第2页
第2页 / 共8页
linux SVN.docx_第3页
第3页 / 共8页
linux SVN.docx_第4页
第4页 / 共8页
linux SVN.docx_第5页
第5页 / 共8页
点击查看更多>>
下载资源
资源描述

linux SVN.docx

《linux SVN.docx》由会员分享,可在线阅读,更多相关《linux SVN.docx(8页珍藏版)》请在冰豆网上搜索。

linux SVN.docx

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]

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 工程科技 > 能源化工

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1