一、 准备好相关的几个安装包
我下的是最新的
Apr : apr-1.3.8.tar.gz 和 apr-util-1.3.9.tar.gz
Apache : httpd-2.2.13.tar.gz
Subversion: 我不知道apr和apache最新的能和哪个subversion搭配
就在官网上找一个发布时间跟apr、apache差不多的版本(放心我安装成功了,你可大胆的跟我做)
subversion-1.5.6.tar.gz 和 subversion-deps-1.5.6tar.gz
二、 安装和配置步骤:
1.安装apr-1.3.8.tar.gz
tar –zvxf apr-1.3.8.tar.gz (解压)
cd apr-1.3.8 (进入apr…所在的目录)
./configure /* (安装不指定路径时 默认安装到/usr/local/apr)
make ; make install (安装)
2. 安装 apr-util-1.3.9.tar.gz
tar –zvxf apr-util-1.3.9.tar.gz
cd apr-util-1.3.9
./configure - -with-apr=/usr/local/apr
make ; make install
3. 安装httpd-2.2.13.tar.gz
cd /usr/local
mkdir apache
(不手动建的话,等哈很麻烦的)
回到刚才的目录
tar –zvxf httpd-2.2.13.tar.gz
cd httpd-2.2.13
./configure --prefix=/usr/local/apache --with-apr=/usr/local/apr/bin/apr-1-config --with-apr-util=/usr/local/apr/bin/apu-1-config --enable-modules=so --enable-dav
--enable-maintainer-mode --enable-rewrite
make ; make install
安装之后重新启动apache服务
/usr/local/apache/bin/apachectl –k start / restart
用浏览器查看http://192.168.18.110(Linux系统IP地址),得到it works,说明apache已经配置成功了。
4.安装subversion
tar –zvxf subversion-1.5.6.tar.gz
tar –zvxf subversion-deps-1.5.6.tar.gz (这两个自动解压成一个包 subversion-1.5.6)
cd subversion-1.5.6
(# 如果linux系统上已经装有apr或者apr-util ,移除 apr存在的版本,subversion解压后的文件里有apr相关的文件,需要移除)
rm –rf apr
rm -rf apr-util
说明:SVN 依赖的APR版本要正确。如果Apache为2.0.x,对应的APR版本应为0.9.x;Apache为2.2.x,对应的APR版本应为1.2.x。 由于subversion-deps包里的APR是0.9.x的,因此编译svn时要删除从deps里解压出来的apr, apr-util,改而使用apache 2.2里提供的。(这里指定为开始安装的apr目录),这一点知识非常重要,自己之前多次安装都没成功,现在才明白是在这一点被卡住了,但最终还是被我解 决了, 学习,和不断实践 会使你不断成长!
(先跑去建/usr/local/svn)
cd /usr/local
mkdir svn
(不知道为什么我不手动建目录的话,它不给我自动建)
cd cd subversion-1.5.6
./configure
--prefix=/usr/local/svn
--with-apxs=/usr/local/apache/bin/apxs
--with-apr=/usr/local/apr/bin/apr-1-config
--with-apr-util=/usr/local/apr/bin/apu-1-config
--with-ssl
--with-zlib
--enable-maintainer-mode
make
make install
确定一下svn有没有安装成功
/usr/local/svn/bin/svnserve --version
会看到相关版本信息!
(如果:
执行了configure,make后
make install时出错:
/bin/sh /usr/local/httpd-2.2.3/srclib/apr/libtool --mode=install /usr/bin/install -c -m 755 libaprutil-1.la /usr/local/apache2/lib
libtool: install: error: cannot install `libaprutil-1.la' to a directory not ending in /usr/local/apache22/lib
make[2]: *** [install] Error 1
则在./configure 后
make clean
make
make install
)
完了再看看apache 的相关模块有没有加载!如下! (这一步可以不做)
LoadModule dav_svn_module modules/mod_dav_svn.so
LoadModule authz_svn_module modules/mod_authz_svn.so
到此如果一直都顺利的话就基本没什么问题!继续往下!
开始建立版本库
/usr/local/svn/bin/svnadmin create /svn/project/www (创建仓库"www" )
ls /svn/project/www (查看有没有创建好,如果多了一些文件则说明版本库已经创建好)
(如果出现“无法创建顶级目录”的错误,请先
cd /
mkdir svn
)
导入项目文件到版本库
/usr/local/svn/bin/svn import /home/test file:///svn/project/www -m "init"
这条语句将把路径/share/www下找到的项目文件导入到你创建的/svn/project/www 仓库中去,提交后的修订版为1
配置提高svn版本库的安全性
chmod –R 700 /svn/project/www (不让其他人有该目录的权限)
注意:直接这么chmod会导致svn客户端无法访问,同时需要修改apache配置文件./conf/httpd.conf文件,(如果你的水平不够高 的话, 这一步可以先跳过,以免给自己找麻烦!等把服务完全搞定后再来进一步提高安全性) 在httpd.conf文件中有这么一段内容:
User daemon
Group daemon
把上述内容改成:
User apache
Group apache
(我的系统在安装apache的时候,自动增加了apache用户和apache组,如果你系统没有这个用户和组,则请自己添加该用户和组)
修改svn仓库的所有者
chown -R apache:apache /svn/project
5、配置apache支持svn
vi /usr/local/apache/conf/httpd.conf (编辑httpd.conf文件)
在文件末尾添加
<Location /svn>
DAV svn
SVNParentPath /svn/project (此处配置你的版本库根目录)
AuthType Basic (连接类型设置 基本验证)
AuthName "Hello welcome to here" (此处字符串内容修改为提示对话框标题)
AuthUserFile /svn/passwd (访问版本库用户的文件,用apache 的htpasswd命令生成)
AuthzSVNAccessFile /svn/auth.conf (此处修改为访问版本库权限的文件)
Require valid-user ("Require valid-user"告诉apache在authfile中所有的用户都可以访问)
</Location>
保存文件退出!
重新启动apache
/usr/local/apache/bin/apachectl –k restart
(如果启动httpd 80端口被占用
lsof -i:80 查看使用80端口的进程
kill pid (kill 所有的pid)
)
打开浏览器访问http://192.168.18.110/svn/project/www 会提示输入用户名密码,检测是否配置成功
对svn的用户和权限配置管理
6、配置svn权限管理(即authz.conf的配置)
1. 添加用户:
/usr/local/apache/bin/htpasswd –c /svn/passwd user1
第一次设置用户时使用-c表示新建一个用户文件。回车后输入用户密码,完成对用户的增加,第二次添加用户不需要带-c参数
2. 权限分配:
vi /svn/auth.conf (进入文件auth.conf,对其进行编辑)
[groups]
Admin=usr1,user2 (这个表示admin群组里的成员 user1,user2)
Develop=u1, u2 (这个表示Develop群组里的成员 u1,u2)
[www:/] (这表示,仓库www的根目录下的访问权限)
user1 = rw (www仓库user1用户具有读和写权限)
user2 = r ( www仓库userl用户具只有读权限)
@develop=rw (这表示 群 develop的成员都具有读写权限)
[/] (这个表示在所有仓库的根目录下)
* = r (这个表示对所有的用户都具有读权限)
注意:在编辑authz.conf文件时,所有行都必须要顶头写,否则会报错
7、重启apache服务和启动svn服务
/usr/local/apache/bin/apachectl –k restart
就可以通过 http://192.168.18.110/svn/project/www 这个URL来访问仓库了,当然,受权限的限制,必须是合法用户才能访问且具有相应的权限
客户端
windows客户端用TortoiseSVN-1.4.4.9706-win32-svn-1.4.4.msi 也许有更高版本,我没有测试
Eclipse插件:software update > url=http://subclipse.tigris.org/update_1.0.x
注意:
如果输入用户名密码后出现:
Could not open the request SVN filesystem
请检查你的/usr/local/apache/conf/httpd.conf 是否正确
如果客户端出现:
org.tigris.subversion.javahl.clientexception ra layer request failed
请检查你的url.username password
如果系统时间和现实时间相差太大,可能会导致安装出问题,修改系统时间的命令:
Date –s (修改linux系统时间)
访问过程中出现的两个问题:
1. svn: Can’t create directory ‘/subversion/main/db/transactions/0-1.txn’: Permission denied
解答:设置svn配置库库文件夹的权限(chmod -R 777 /svn/project/www) 2. Error: 服务器发送了意外的返回值(403 Forbidden),在响应 “CHECKOUT” 的请求
Error: “/svn/www/!svn/ver/1/111/bbb.txt” 中
解答:提交人没有权限,可设置提交权限 即可。
------------------------------------------------------------------------------
描述一下如何快速启动svnserve服务 , 从四个方面来讲解, 希望通过本节的介绍大家能够掌握启动svnserve服务的方法,下面就让我们一起来学习启动svnserve 服务 吧。
Subversion 使用手记-启动svnserve服务
svnserve 是一个轻量级的服务, 使用自定义的协议通过TCP/IP与客户端通讯。客户端通过由 svn:// 或者 svn+ssh:// 开始的URL访问svnserve服务器。
1.启动服务器
端口监控(inetd)模式
如果你打算用端口监控来启动处理客户的访问请求的进程,你可以通过传入参数-i来启动:
svnserve -i
当使用-i参数启动服务的时候,svnserve服务 通过stdin和stdout用自定义协议和客户端
通讯。同时服务侦听3690端口。
2.独立端口监控进程 (一般用这个启动svn服务器 )
使用参数-d启动服务作为一个独立的端口监控进程。
svnserve -d
当运行svnserve在独立端口监控模式时,你可以使用--listen-port=和--listen-host=参数来自定义需要的端口和主机名称。当前模式默认的端口是3690。
当 然,也有第三种方法启动svnserve,也就是使用“隧道模式”,使用-t参数启动服务。这个模式要求远程服务程序,如RSH或SSH,已经成功验证用 户,并且使用已经校验的用户启动一个属于该用户的svnserve进程。当使用该模式提供服务时,要确认启动的用户帐户具备对Repository的读/ 写权限。
3.设置项目目录
当svnserve开始运行时,它将会暴露所有的Repository到网络上。不过,当客户端需要获取一个Repository的内容时,需要指定Reopsitory的绝对路径。例如:一个Repository放在文件路径
C:/Project Repository/Project1
那么当客户端访问时,需要指定绝对路径:
svn://host/C:/Project Repository/Project1
所以,为了增加保密性,你可以使用参数-r指定需要暴露的Repository的路径,当用户访问时,只需指定Repository的名称即可。例如上面的Repository,当启动服务时,使用如下的方法:
svnserve -d -r C:/Project Repository
那么当客户端访问时,则使用
svn://host/Project1
就可以获取数据了。启动svnserve服务 中的设置项目目录介绍完毕,我们再来看一下内置的验证和授权问题。
4.内置的验证和授权
当客户端连接到一个svnserve进程时,下面的流程就会触发:
1、客户选择一个指定的Repository;
2、服务处理Repository的配置文件 conf/svnserve.conf文件,并且开始执行在其中定义的所有验证和授权策略;
3、依赖与情形和授权策略:
a)客户端也许允许匿名访问而不需要验证,或者
b)客户但也许需要在任何时候被要求验证,或者
c)假如处于"隧道模式"中,客户端将声明自己已经可以被外部验证。
很显然,如上所说,用户文件是一个名为svnserve.conf的,放在conf目录下的文件。
现在我们来看看如何配置这个文件:
这个配置文件放置在Repository的目录中的conf目录下,它有两个节点:
[general]
[users]
其中,[general]的配置信息有:
anon-access = read
auth-access = write
其中表示对于验证有效的以及没通过验证的用户可以做什么事情。分别有read, write和none
[users]的标签的配置内容有:
USERNAME = PASSWORD
password-db = passwd
realm = My First Repository
其 中表示,用户名对应的密码是什么,或者指定一个存储用户名和密码的文件的相对或绝对路径以及指定了Repository的验证领域。如果两个 Repository有相同的验证领域,那么它们应该有相同的密码数据库,反之亦然。默认的领域就是指向当前的Repository的路径,与服务器的 Repository的根目录相关。本节关于启动svnserve服务 的内容介绍到这里。
---------------------------------------------------------------------
linux svn命令大全