zoukankan      html  css  js  c++  java
  • svn配置使用

     SVN是一种版本管理系统,前身是CVS,是开源软件的基石。即使在沟通充分的情况下,多人维护同一份源代码的一定也会出现混乱的情况,版本管理系统就是为了解决这些问题。


    SVN中的一些概念 : 
    a. repository(源代码库) 
       源代码统一存放的地方。 
    b. Checkout (提取) 
       当你手上没有源代码的时候,你需要从repository checkout一份。 
    c. Commit (提交) 
       当你已经修改了代码,你就需要Commit到repository。 
    d. Update (更新) 
        当你已经Checkout了一份源代码, Update一下你就可以和Repository上的源代码同步,你手上的代码就会有最新的变更。   

     

    Centos 搭建SVN服务,有效的管理代码,以下三步可以快速搞定。

    1、安装          

    [root@www ~]# yum install subversion 

    [root@www ~]# svn -v   判断是否安装成功 
      svnserve, version 1.6.11 (r934486) 出现类型提示,说明安装成功。 

    有了SVN软件后还需要建立SVN库。 
    [root@www ~]# mkdir /opt/svn/repos 
    [root@www ~]# svnadmin create /opt/svn/repos 
    执行上面的命令后,自动在repos下建立多个文件, 分别是conf, db,format,hooks, locks, README.txt。 

     

       

    2、配置

         上面的操作很简单,几个命令就搞定, 下面的操作也不难。

         进入上面生成的文件夹conf下,进行配置,   有以下几个文件authz, passwd, svnserve.conf

         其中authz 是权限控制,可以设置哪些用户可以访问哪些目录,   passwd是设置用户和密码的,    svnserve是设置svn相关的操作。

     

     2 .1先设置passwd 
      [root@www ~]# vi passwd 
    [users]
    # harry = harryssecret
    # sally = sallyssecret
    hello=123
    用户名=密码

    这样我们就建立了hello用户, 123密码  

       2.2 再设置权限authz 
    [root@www ~]# vi authz 

    [/]
    hello= rw

    意思是hello用户对所有的目录有读写权限,当然也可以限定。
    如果是自己用,就直接是读写吧。 


    2.3最后设定snvserv.conf 
    [root@www ~]# vi snsvserv.conf 

    anon-access = none # 使非授权用户无法访问 
    auth-access = write # 使授权用户有写权限 
    password-db = password
    #authz-db = authz   # 访问控制文件 
    realm = /opt/svn/repos # 认证命名空间,subversion会在认证提示里显示,并且作为凭证缓存的关键字。
    采用默认配置. 以上语句都必须顶格写, 左侧不能留空格, 否则会出错.

    好了,通过以上配置,你的svn就可以了。

     

    3、连接

      [root@www ~]# svnserve -d -r /opt/svn/repos 启动svn:


    如果已经有svn在运行,可以换一个端口运行 
    [root@www ~]# svnserve -d -r /opt/svn/repos --listen-port 3391 

    这样同一台服务器可以运行多个svnserver

    好了,启动成功后,就可以使用了。
    建议采用TortoiseSVN, 连接地址为: svn://your server address (如果指定端口需要添加端口  :端口号)

    连接后可以上传本地的文件,有效的管理你的代码。 

     

     

    svn 命令详解

     

    1、将文件checkout到本地目录

    svn checkout path(path是服务器上的目录)

    例如:svn checkout svn://192.168.1.1/pro/domain

    简写:svn co

    2、往版本库中添加新的文件

    svn add file

    例如:svn add test.php(添加test.php)

    svn add *.php(添加当前目录下所有的php文件)

    3、将改动的文件提交到版本库

    svn commit -m “LogMessage“ [-N] [--no-unlock] PATH(如果选择了保持锁,就使用–no-unlock开关)

    例如:svn commit -m “add test file for my test“ test.php

    简写:svn ci

    4、加锁/解锁

    svn lock -m “LockMessage“ [--force] PATH

    例如:svn lock -m “lock test file“ test.php

    svn unlock PATH

    5、更新到某个版本

    svn update -r m path

    例如:

    svn update如果后面没有目录,默认将当前目录以及子目录下的所有文件都更新到最新版本。

    svn update -r 200 test.php(将版本库中的文件test.php还原到版本200)

    svn update test.php(更新,于版本库同步。如果在提交的时候提示过期的话,是因为冲突,需要先update,修改文件,然后清除svn resolved,最后再提交commit)

    简写:svn up

    6、查看文件或者目录状态

    1)svn status path(目录下的文件和子目录的状态,正常状态不显示)

    【?:不在svn的控制中;M:内容被修改;C:发生冲突;A:预定加入到版本库;K:被锁定】

    2)svn status -v path(显示文件和子目录状态)

    第一列保持相同,第二列显示工作版本号,第三和第四列显示最后一次修改的版本号和修改人。

    注:svn status、svn diff和 svn revert这三条命令在没有网络的情况下也可以执行的,原因是svn在本地的.svn中保留了本地版本的原始拷贝。

    简写:svn st

    7、删除文件

    svn delete path -m “delete test fle“

    例如:svn delete svn://192.168.1.1/pro/domain/test.php -m “delete test file”

    或者直接svn delete test.php 然后再svn ci -m ‘delete test file‘,推荐使用这种

    简写:svn (del, remove, rm)

    8、查看日志

    svn log path

    例如:svn log test.php 显示这个文件的所有修改记录,及其版本号的变化

    9、查看文件详细信息

    svn info path

    例如:svn info test.php

    10、比较差异

    svn diff path(将修改的文件与基础版本比较)

    例如:svn diff test.php

    svn diff -r m:n path(对版本m和版本n比较差异)

    例如:svn diff -r 200:201 test.php

    简写:svn di

    11、将两个版本之间的差异合并到当前文件

    svn merge -r m:n path

    例如:svn merge -r 200:205 test.php(将版本200与205之间的差异合并到当前文件,但是一般都会产生冲突,需要处理一下)

    12、SVN 帮助

    svn help

    svn help ci

    13、版本库下的文件和目录列表

    svn list path

    显示path目录下的所有属于版本库的文件和目录

    简写:svn ls

    svn使用心得:

    1.svn创建的仓库只是一个仓库,并不是把文件添加到这。只是用来记录版本的。

    2.在www下的一个目录 下载版本库的文件 svn checkout svn://127.0.0.1/xxx ./

    3.添加www/xxx下的文件到你创建的仓库中 svn add *

    别忘了提交

    svn commit -m "注释"

    这样就好了,在www/xxx 检出文件 svn checkout svn://127.0.0.1/xxx ./

    增加hooks(钩子)文件

    在/var/svn/foo/hooks/目录中

    # start-commit 提交前触发事务

    # pre-commit 提交完成前触发事务

    # post-commit 提交完成时触发事务

    # pre-revprop-change 版本属性修改前触发事务

    # post-revprop-change 版本属性修改后触发事务

    我们这里只需要修改post-commit文件:

    cp post-commit.tmpl post-commit

    编辑该文件

    #!/bin/sh

    # 配置库地址

    REPOS="$1"

    REV="$2"

    # WEB目录

    BASEPATH=/var/www

    # web文件夹名与svn库名相同

    NAME=$(basename $REPOS)

    WEBPATH="$BASEPATH/$NAME"

    # 避免中文信息乱码

    export LANG="zh_CN.UTF-8"或en_US.UTF-8(根据Linux环境b变量中的编码不同改变)

    # 可以配合svnlook命令更新指定目录

    svn update $WEBPATH --username=user1 --password=password1 --no-auth-cache

    保存后需要修改post-commit文件权限为755,否则SVN无法调用执行

    chmod 755 post-commit

  • 相关阅读:
    arm activesync 串口(wince移植篇)
    请问生产成本收集器与标准成本评估有什么关联?
    BAPI / RFC with Delphi(系列之六)--TSAPFunctions使用BAPI创建PO(有登录对话框的delphi源代码)
    关于项目团队的发展阶段特点、问题、应对措施、领导风格
    如何在sap里设置打印机参数
    BAPI / RFC with Delphi(系列之四)--TSAPFunctions使用(有登录对话框的delphi源代码)
    BAPI / RFC with Delphi(系列之七)--TBAPIControl使用BUS1001显示物料(Delphi源代码)
    BAPI / RFC with Delphi(系列之五)--TSAPFunctions和TSAPLogoncontrol使用(无登录对话框Delphi源代码)
    Guice 1.0 用户指南
    BAPI / RFC with Delphi(系列之八)--TBAPIControl使用BUS2012建立PO(Delphi源代码)
  • 原文地址:https://www.cnblogs.com/tblog/p/4684606.html
Copyright © 2011-2022 走看看