您的位置:首页 > 运维架构 > Apache

Linux系统RedHat9.0 上配置SVN+APACHE服务参考Linux系统RedHat9.0 上配置SVN+APACHE服务参考Linux系统RedHat9.0 上配置SVN+APACHE服务

2012-07-06 23:51 435 查看
查看了好多网页,加上自己不断出错不断的解决,终于解决了在linux系统上配置svn服务的问题

现将我参考的资料加上自己安装时遇到的问题等总结一下,供大家参考)

一、 准备好相关的几个安装包

我下的是最新的

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” 中

解答:提交人没有权限,可设置提交权限 即可。

开机自启动服务

设置SVN开机自启动服务,只要启动相关的Apache服务,如何设置请看这里

/article/4097159.html
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: