10年工作经验,专研网站运维。
全部博文(454)
分类: LINUX
2011-04-18 09:28:34
apache的安装 httpd是web服务器,用来通过web访问subversion,我下载到httpd-2.2.2.tar.bz2。解压该文件:
//进入解压后的目录
//配置apache安装,前两个参数是必须要加的,你还可以根据您的需要添加其他的参数。 //后面的参数制定你要把apache安装哪里 ]# ./configure --prefix=/usr/local/apache2 --enable-mods-shared=most --enable-dav --enable-so --enable-rewrite --enable-maintainer-mode --with-included-apr --with-apr=/usr/local/apache2 --with-apr-util=/usr/local/apache2
//安装
//启动apache服务
//打开浏览器"It works!"出现则证明已经安装成功。
//如果配置文件/apache2/conf/httpd.conf中,下面两行没有注释掉的话,需要先注释,然后再启动apache,否则可能报错:"httpd: Syntax error on line 232 of /usr/local/apache2/conf/httpd.conf: API m....."提示不能加载svn的.so文件
//这个时候只要把上面两行注释掉,就能成功运行apache,当然,测试apache成功运行后,把注释干掉,还是要加载这个.so模块 3. 安装Subversion //解压SubVersion安装包 (root用户进行下面的操作)
//进入解压后的目录
//配置subversion安装
--with-apr=/usr/local/apache2 --with-apr-util=/usr/local/apache2 --with-ssl
//安装
//创建库文件所在的目录 (svnroot用户进行下面的操作)
//进入subversion的bin目录
//创建仓库"test"
//看看是不是多了些文件,如果是则说明Subversion安装成功了
//# cd /usr/local/subversion/bin //这条语句将把路径/home/user/import下找到的文件导入到你创建的Subversion 仓库中去, //提交后的修订版为1。 //# ./svn import /home/user/import file:///home/svnroot/repository/test –m "注释" //不让其他人有该目录的权限
//**注意,直接这么chmod会导致svn客户端无法访问,需要修改apache配置文件/conf/httpd.conf文件 //这个文件中有这么一段内容: User nobody Group #-1 //把上述内容改成: User svnroot Group svnroot //(我的系统在安装apache的时候,自动增加了apache用户和apache组,如果你系统没有这个用户和组,则请自己添加该用户和组) //修改svn仓库的所有者
//修改该目录权限只能svnroot拥有
4. 修改Apache配置文件
//启动Apache
5. 重启apache # ./usr/local/apache2/bin/apachectl restart //打开浏览器访问
6. 权限管理 1)增加用户
//第一次设置用户时使用-c表示新建一个用户文件。回车后输入用户密码,完成对用户的增加
2)权限分配
将这个设置完成后。重启Apache,就可以通过 这个URL来访问仓库了,当然,受权限的限制,必须是合法用户才能访问且具有相应的权限
7. 一些备忘: 1. svn checkout
2. svn commit 时的默认编辑器的环境变量$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 文件中配置,找到文件中的这两行: User daemon # 将daemon改为svnroot,让apache进程以svnroot的身份运行 Group daemon
svn用户的权限:就是在repository/authz.conf文件中设置的权限信息,是svn用来管理仓库访问权限的。
5. svn服务器设置有两种方式:http 和 svnserve。这里介绍的是http方法
6. 在/etc/profile的结尾设置一些svn启动时要做的工作 # start apache server for svn /usr/sbin/apachectl start export SVN_EDITOR=vi
7. APR libraries 安装 SVN 的时候最好指定 --with-apr= 和 --with-apr-util= 参数到 Apache 安装的根目录 (ServerRoot)下,而不是使用缺省的 SVN 安装包中自带的 apr 。否则如果你安装的 Apache 版本不同有可能导致 APR 库不匹配,出现类似: Can't set position pointer in file '/svn/test/db/revs/1': Invalid argument 的错误。 Updated 2006-04-20 16:30 -- 比如说如果你安装的是apache 2.2.0版本,就需要在编译安装svn的时候指定 --with-apxs和--with-apr参数到你的apache2.2.0安装目录下: ./configure --prefix=${subversionInstallFolder} / --with-apxs=${apacheInstallFolder}/bin/apxs / --with-apr=${apacheInstallFolder} / --with-apr-util=${apacheInstallFolder} / --with-ssl / --with-zlib / --enable-maintainer-mode
[Thu Mar 31 01:35:55 2011] [error] [client 192.168.0.3] Failed to load the AuthzSVNAccessFile: /home/svnroot/repository/authz.conf:3: Option must end with ':' or '=' [Thu Mar 31 01:35:55 2011] [error] [client 192.168.0.3] Access denied: 'wangban' GET development:/
在做svn钩子脚本的时候
先需要导入这个web的版本,导入的方式,网路上很多,让我苦笑的不得是,很多都是windows的软件,一个linux的软件,教程全部是叫你怎么在windows下面用,我实在是无语了,下面是导入的方式:
导入之前一定要切换到svnroot用户下去执行这些语句
要是以root用户去checkout的话www/cmstest下所检出的文件夹的权限拥有者是root的,不是svnroot,并在以后客户端在调用钩子的时候是以svnroot去update 所以会出现 错误提示钩子没有权限去update
svn checkout file:///home/svnroot/repository/development/ /www/cmstest
更新的方式 svn update file:///home/svnroot/repository/development/ /www/cmstest
commit后自动跟新为钩子(hook)下面的
程序更新后让svn自动发布的shell为
1 #!/bin/sh
2 export lang=en_US.UTF-8
3 export LC_ALL=en_US.UTF-8
4 cd /www/cmstest
5 /usr/local/subversion/bin/svn update file:///home/svnroot/repository/development/ ./