SVN自动化

SVN自动化

正文共:5007 字

预计阅读时间: 13 分钟

平时自己多用Git来做版本控制,但很多公司内部依旧使用SVN,核心原因其实就是SVN够用了,懒得换,虽然自己用git,但对git理解也算特别深刻,而转到SVN发现是类似的,所以借此机会内化一下SVN的处理。

文章内容的结构会先理清楚SVN的声明周期,接着会在Centos下搭建SVN服务,接着创建一个项目并使用客户端手动进行SVN操作,最后使用shell命令进行自动化上传。

SVN生命周期

  • 创建版本库首先创建版本库,版本库其实就是一个空间,用于开发者存储所有的工作成果,版本库不仅可以放文件,还会保留每次修改的历史记录,每个文件的变动历史。


  • 检出 CheckoutCheckout会从版本库中创建一个工作副本,工作副本是开发者的私人工作空间,可以进行内容修改,然后提交到版本库中。


  • 更新 updateupdate用来更新版本库,该操作会将工作副本与版本库进行同步。因为版本库由整个团队共用,当他人提交了自己的修改后,自己的工作副本就过期了。此时就需要还是用update更新操作从版本库中拉取最新的代码更新到自己的工作副本中。


  • 执行变更当你检出Checkout获得自己的工作副本后,通常会进行编辑等操作,此时就发生了变更,变更的内容只有通过commit操作才会成为版本库的一部分。删除操作也一样,如果没有进行commit操作,版本库中的文件是不会删除的。


  • 复查变化当你对工作副本进行修改后,此时你的工作副本就与版本库不相同,此时在commit前复查一下自己的修改比较好status操作会列出当前工作副本中所进行的改动,status操作只提供一个变动列表,但并不会显示详细信息。


  • 修复错误当你对工作副本做了很多修改后,突然不想要这些修改了,可以执行revert操作,revert操作会重置对工作副本的修改,他可重置一个或多个文件或文件夹,也可以对整个工作副本进行重置。revert操作UI将销毁待变革列表并将工作副本恢复到原始状态。


  • 解决冲突合并时,可能发生冲突。merge操作会自动处理可以安全合并的内容,其他会被当做冲突,如hello.py文件在一个分支上被修改了,在另一个分支上被删除了,这种情况需要人为进行处理,resolve操作可以帮助你找到冲突,并告诉版本库应该如果处理这些冲突。


  • 提交更改commit操作用来将更改从工作副本到版本库,这个操作会修改版本库中的内容,其他开发者可以通过更新他们的工作副本来查看这些修改。在提交前,这些修改必须添加到待变更列表中,列表中记录了将会被提交的改动,在提交时通常会提供可以提供一个注释来说明为何会进行这些修改。commit是原子操作,,要买完全提交成功,要么失败回滚,不会出现提交到一半的情况。


  • Centos搭建SVN服务

    SVN分成两块,一块是server进程,通常在服务器上用于与SVN客户端交互,另一块就是SVN客户端client进程,即开发者使用的,开发者使用SVN通常就是使用client端输入相应的SVN命令与Server端交互,以实现相应的效果,这里我们先来搭建SVN服务,即Server端,流程比较简单。

  • 下载安装SVN服务端,在Centos中,使用yum一步完成

    1. yum install -y subversion

  • 创建一个目录,使用svnadmin将其设为SVN的版本库

    1. mkdir -p /home/svn/project

    2. svnadmin create /home/svn/project/


  • svnadmin将该目录设置为版本库后,就会在该目录中生成相应的文件,这里会在 /home/svn/project生成相应的目录,其中conf目录下有三个比较重要的文件,分别为: authz权限配置文件 passwd用户名口令文件 svnserver.conf svn服务综合配置文件



  • 配置authz, vim/home/svn/project/conf/authz,输入如下内容


    1. [groups]            

    2. #用户组

    3. admin = admin,root,test  

    4. #用户组所对应的用户

    5. [/]                

    6. #库目录权限

    7. @admin = rw        

    8. #用户组权限

    9. *=r              

    10. #非用户组权限

    [groups]配置段中配置行格式为: <用户组> = <用户列表>版本库路径权限段的段名格式为: [<版本库名>:<路径>],如果为 [/]表示整个svn目录,通常用单库svnserver方式

  • 配置用户口令文件passwd,输入如下内容:

    1. [users]

    2. # harry = harryssecret

    3. # sally = sallyssecret

    4. admin = Admin1234

    5. root = root1234

    6. test = test1234

  • 配置svn服务综合配置文件svnserver.conf

    1. [general]

    2. #匿名访问的权限,可以是read,write,none,默认为read

    3. anon-access=none

    4. #使授权用户有写权限

    5. auth-access=write

    6. #使用哪个文件作为账号文件

    7. password-db=passwd

    8. #使用哪个文件作为权限文件

    9. authz-db=authz

    10. #认证命名空间,subversion会在认证提示里显示,并且作为凭证缓存的关键字

    11. realm=/home/svn/project

    该文件仅由一个[general]配置段组成。


  • anon-access: 控制非鉴权用户访问版本库的权限,取值范围为"write"、"read"和"none"。 即"write"为可读可写,"read"为只读,"none"表示无访问权限。 缺省值:read



  • auth-access: 控制鉴权用户访问版本库的权限。取值范围为"write"、"read"和"none"。 即"write"为可读可写,"read"为只读,"none"表示无访问权限。 缺省值:write



  • authz-db: 指定权限配置文件名,通过该文件可以实现以路径为基础的访问控制。 除非指定绝对路径,否则文件位置为相对conf目录的相对路径。 缺省值:authz



  • realm: 指定版本库的认证域,即在登录时提示的认证域名称。若两个版本库的 认证域相同,建议使用相同的用户名口令数据文件。 缺省值:一个UUID(Universal Unique IDentifier,全局唯一标示)。



  • 然后就可以启动SVN服务器了,命令为:


    1. svnserve -d -r 目录 --listen-port 端口号

    -r: 配置方式决定了版本库访问方式。

    --listen-port: 指定SVN监听端口,不加此参数,SVN默认监听3690

    具体而言:

    1. svnserve -d -r /home/svn/project/

    -r参数配置不同,SVN启动方式不同,SVN可以以两种不同的方式访问。

    第一种:-r直接指定到版本库,这种模式称为单库svnserver方式

    1. svnserve -d -r /home/svn/project/

    authz配置文件对应版本库权限的配置通常为:

    1. [groups]

    2. admin=user1

    3. dev=user2

    4. [/]

    5. @admin=rw

    6. user2=r

    这种情况下,一个svnserver只能为一个版本库工作。访问地址通常为 svn://192.168.0.1/,这样就可以方位project版本库了

    第二种:-r指定版本库的上级目录,称为多库svnserve方式

    1. svnserve -d -r /home/svn

    这种情况下,一个svnserve可以为多个版本库工作,但创建情况与上面讲解的内容有所不同,需要做一些调整。

    authz配置文件中对版本库的权限配置通常为:

    1. [groups]

    2. admin=user1

    3. dev=user2

    4. [project:/]

    5. @admin=rw

    6. user2=r


    7. [project01:/]

    8. @admin=rw

    9. user2=r

    如果此时你还用[/],则表示所有库的根目录,同理,[/src]表示所有库的根目录下的src目录。

    使用类似这样的URL:svn://192.168.0.1/runoob 即可访问runoob版本库。

    此时可以通过命令查看centos中是否运行起了SVN相应的进程

    1. ps -aux | grep svn

  • 配置防火墙端口,你的SVN进程指定了使用哪个端口,防火墙要相应的开启它 centos6中防火墙其实是iptables,centos7中防火墙为Firewalld,如SVN默认是3690端口,则防火墙要开放3690端口。配置完防火墙后,记得重启。

  • SVN多库svnserve方式

    上面的内容没有详细的讲清楚SVN多库模式,即多个SVN版本库被管理,多库模式才是实际中常见的模式,所以这里具体来实践一下,首先mkdir创建多个目录,然后使用svnadmin在这些目录下创建对应的版本库,如下:

    1. mkdir /home/svn/Resource_1

    2. mkdir /home/svn/Resource_2

    3. svnadmin /home/svn/Resource_1

    4. svnadmin /home/svn/Resource_2

    接着为了方便配置,将其中一个版本库中的配置文件拷贝下来,如拷贝Resource_1下的配置文件,这里拷贝到/home/svn/conf中,此时/home/svn/conf中就有如下文件

    1. [root@localhost conf]# ls

    2. authz  passwd  svnserve.conf

    3. [root@localhost conf]# pwd

    4. /home/svn/conf

    先修改authz文件,规则一样,<用户组>=<用户名>,不同的SVN版本库可以指定不同的用户组,给予不同的权限,如下

    1. [groups]


    2. admin=root

    3. user=test


    4. [Resource_1:/]

    5. @admin=rw


    6. [Resource_2:/]

    7. @user=rw

    上面的配置指明,admin用户组下的用户才有权限操作Resource1,而user用户组下的用户才有权限操作Resource2,admin用户组下只有一个名为root的用户,user用户组下只有一个名为test的用户。

    接着编辑passwd文件,定义不同用户的账号和密码

    1. [users]

    2. root=root123

    3. test=test123

    最后编写总配置文件svnserve.conf,指定要使用的配置文件,svnserve.conf关键配置如下:

    1. [general]

    2. anon-access = none

    3. auth-access = write

    4. password-db = passwd

    5. authz-db = authz

    最后,最重要的就是SVN启动方式,启动时要指定svn版本库的上层目录,然后还要指定对应的配置文件

    1. svnserve -d -r /home/svn/ --config-file /home/svn/conf/svnserve.conf

    这样所有版本库对应的配置都是 /home/svn/conf/svnserve.conf,管理起来非常方便。

    使用SVN客户端

    windows的SVN客户端使用比较简单,因为有比较成熟的客户端,使用比较简单,本人使用的为Mac,在Mac下当然也有SVN客户端,但我更喜欢命令行,所以使用的方式都是以命令行的方式进行的。

    Mac下安装SVN客户端

    1. brew install svn

  • 第一步检出checkout,复制版本库,在本地生成对应的副本

    1. svn checkout svn://192.168.100.62 --username=admin

    https://raw.githubusercontent.com/ayuLiao/images/master/svn1.png

  • 修改自己的工作副本,如通过touch来创建一个名为test的文件,使用add命令加载进内容,然后再用commit命令将add命令添加的内容体检,简单命令如下:

    1. svn add test.txt

    2. svn commit -m 'touch test.txt'

    命令非常简单。

  • 如果你与多人合作,此时在编写代码时,一个好的习惯就是在编写前update一下SVN项目,保证自己工作副本中的代码是最新的。

    1. svn update .

    小结

    考虑字数原因,到这里就先系统的介绍SVN服务端与客户端的情况,下一篇会通过shell与python分别写两个思路不同的脚本来实现自动上传

    参考文章

    SVN 教程http://www.runoob.com/svn/svn-tutorial.html

    CentOS 7 安装配置SVN服务器https://www.jianshu.com/p/4e3dd253a209

    ©著作权归作者所有,转载或内容合作请联系作者
    • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
      沈念sama阅读 162,547评论 4 374
    • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
      沈念sama阅读 68,787评论 2 308
    • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
      开封第一讲书人阅读 112,175评论 0 254
    • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
      开封第一讲书人阅读 44,752评论 0 223
    • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
      茶点故事阅读 53,169评论 3 297
    • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
      开封第一讲书人阅读 41,056评论 1 226
    • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
      沈念sama阅读 32,195评论 2 321
    • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
      开封第一讲书人阅读 30,980评论 0 214
    • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
      沈念sama阅读 34,724评论 1 250
    • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
      茶点故事阅读 30,872评论 2 254
    • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
      茶点故事阅读 32,344评论 1 265
    • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
      沈念sama阅读 28,667评论 3 264
    • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
      茶点故事阅读 33,379评论 3 245
    • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
      开封第一讲书人阅读 26,202评论 0 9
    • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
      开封第一讲书人阅读 26,992评论 0 201
    • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
      沈念sama阅读 36,189评论 2 286
    • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
      茶点故事阅读 35,987评论 2 279

    推荐阅读更多精彩内容