• redhat 5下安装SVN


    1.需要两个文件,httpd和subversion. httpd是web服务器,用来通过web访问subversion,httpd可以在apache官方网站上下载到 

    2.新建一个用户:svn
    最好不要让root用户参与到svn的权限管理和日常的运行和维护工作中来,但是下面的一些安装和配置操作还是 需要root用户来完成的,因为有些操作只有root才能做。权限问题很重要。曾经因为权限问题折腾了一天。

    3.编译安装httpd (root用户操作):

    //解压apache2安装包
    # tar xvzf httpd-2.2.2.tar.gz
    //进入解压后的目录
    # cd httpd-2.2.2
    //配置apache安装,前两个参数是必须要加的,你还可以根据您的需要添加其他的参数。
    //后面的参数制定你要把apache安装哪里
    # ./configure --enable-dav --enable-so --prefix=/usr/local/apache2/
    # make
    //安装
    # make install
    # cd /usr/local/apache2/bin
    //启动apache服务
    # ./apachectl start
    //打开浏览器http://localhost/如果有测试页"It works!"出现则证明已经安装成功。

    4.

    安装Subversion

    //解压SubVersion安装包 (root用户进行下面的操作)
    # tar xvzf Subversion-1.3.1.tar.gz
    //进入解压后的目录
    # cd Subversion-1.3.1
    //配置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
    //安装
    # make install
    //创建库文件所在的目录 (svn用户进行下面的操作)
    # mkdir /home/svn/repo
    //进入subversion的bin目录
    # cd /usr/local/subversion/bin
    //创建仓库"Comsys"
    # ./svnadmin create /home/svn/repo/Comsys
    # cd /home/svn/repo/Comsys
    //看看是不是多了些文件,如果是则说明Subversion安装成功了
    # ls –l
    # cd /usr/local/subversion/bin
    //这条语句将把路径/home/user/import下找到的文件导入到你创建的Subversion 仓库中去,
    //提交后的修订版为1。
    # ./svn import /home/user/import file:///home/svn/repo/Comsys –m "注释"
    //不让其他人有该目录的权限
    # chmod 777 -R  /home/svnroot/repo

    5.修改Apache配置文件

    # cd /usr/local/apadche2/bin
    //启动Apache
    # ./apachect1 start
    # vi /usr/local/apache2/conf/httpd.conf
       //在最下面添加
       <Location /svn>
       DAV svn
       SVNParentPath /home/svn/repo/ //svn父目录
       AuthzSVNAccessFile /home/svn/repo/Comsys/conf/authz //权限配置文件
       AuthType Basic //连接类型设置
       AuthName "Subversion.zoneyump" //连接框提示
       AuthUserFile /home/svn/repo/authfile //用户配置文件
       Require valid-user //采用何种认证
       </Location>
       //其中authfile是通过"./htpasswd [–c] /home/svn/repo/authfile username password"来创建的

      //更新用户密码  ./htpasswd -b /home/svn/repo/authfile  username password

       以后添加新的用户方法为:htpasswd /home/svn/repo/authfile uaername
       //"Require valid-user"告诉apache在authfile中所有的用户都可以访问。如果没有它,
       //则只能第一个用户可以访问新建库

    6.重启apache

    # ./usr/local/apache2/bin/apachectl restart
    //打开浏览器访问http://localhost/svn/Comsys,如果有东西显示就说明成功。

    7.权限管理
    1)增加用户

    # htpasswd [-c] /home/svn/repo/authfile wooin
    //第一次设置用户时使用-c表示新建一个用户文件。回车后输入用户密码,完成对用户的增加
    # htpasswd authfile 用户名(加入新的用户)

    2)权限分配

    # vi /home/svn/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来访问仓库了,当然,受权限的限制,必须是合法用户才能访问且具有相应的权限


    备注:

    1。 apache进程的权限:因为所有跟仓库传输的操作都是通过apache进程进行的,所以即使你给svn用户设置了 很大的权限,但是apache进程没有访问仓库或者相关文件的权限也没有用,apache进程的权限设置在 /usr/local/apache2/conf/httpd.conf 文件中配置,找到文件中的这两行:

    User daemon # 将daemon改为svn,让apache进程以svn的身份运行
    Group daemon

    2。

    在/etc/profile的结尾设置一些svn启动时要做的工作

    # start apache server for svn
    /usr/sbin/apachectl start
    export SVN_EDITOR=vi

    3。/home/respository/svn下的文件操作权限有给svn.

    apache日志文件为/usr/local/apache2/log/

    使用#tail -f error_log    /*实时查看日志*/

    在路径#cd /home/svnroot/repo/Comsys/conf

            #vi authz

    [groups]
    admin = fuck1,fuck2   //添加组
    # harry_and_sally = harry,sally
    # harry_sally_and_joe = harry,sally,&joe

    # [/foo/bar]
    # harry = rw
    # &joe = r

       fuck1 = rw //对单人进行权限分配
    # * =
    [/]
    @admin = rw  //对组进行权限分配

    # [repository:/baz/fuz]
    # @harry_and_sally = rw
    #* = r

    查看SVN日志路径

    #cd /home/svnroot/repo/Comsys/db

    #ll

    revs  revprops    /*这两上文件夹下的文件*/

  • 相关阅读:
    LINUX监控一:监控命令
    Kettle并行
    KETTLE集群搭建
    Solr报错Index locked for write for core '***'. Solr now longer supports forceful unlocking via 'unlockOnStartup'
    Solr json,xml等文件数据导入(添加索引)linux下操作
    python对solr进行查询、插入操作(GETPOST)
    Solr-5.3.1 dataimport 导入mysql数据
    解决MySQL数据导入报错Got a packet bigger than‘max_allowed_packet’bytes
    解决防火墙限制远程连接MySQL(导致错误10060可能之一)
    gensim加载word2vec训练结果(bin文件)并进行相似度实验
  • 原文地址:https://www.cnblogs.com/fengqingtao/p/2114283.html
Copyright © 2020-2023  润新知