热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

SVN自动化

SVN自动化正文共:5007 字预计阅读时间: 13 分钟平时自己多用Git来做版本控制,但很多公司内部依旧使用SVN,核心原因其实就是SVN够用了,懒得换,虽然自己用git,但对
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: 控制非鉴权用户访问版本库的权限,取值范围为&#8221;write&#8221;、&#8221;read&#8221;和&#8221;none&#8221;。 即&#8221;write&#8221;为可读可写,&#8221;read&#8221;为只读,&#8221;none&#8221;表示无访问权限。 缺省值:read

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

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

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

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



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


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

    &#8211;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


    推荐阅读
    • 在CentOS上部署并使用FFmpeg多媒体处理工具
      最近在进行音频处理时需要用到FFmpeg,本文将详细介绍如何在CentOS系统上部署并使用这一强大的多媒体处理工具。首先,从官方网站下载FFmpeg的最新版本,然后通过Xftp工具将下载的压缩包(如ffmpeg-4.3.1.tar.xz)传输到服务器上。接下来,解压文件并按照官方文档进行编译安装。安装完成后,可以通过命令行工具验证FFmpeg是否成功安装,并开始进行多媒体文件的转换和处理。此外,文章还将介绍一些常用的FFmpeg命令和参数,帮助用户快速上手。 ... [详细]
    • Linux入门教程第七课:基础命令与操作详解
      在本课程中,我们将深入探讨 Linux 系统中的基础命令与操作,重点讲解网络配置的相关知识。首先,我们会介绍 IP 地址的概念及其在网络协议中的作用,特别是 IPv4(Internet Protocol Version 4)的具体应用和配置方法。通过实际操作和示例,帮助初学者更好地理解和掌握这些基本技能。 ... [详细]
    • 在Linux系统中,为了提高安全性,可以通过设置命令执行超时和用户超时注销来防止因用户长时间未操作而带来的安全隐患。具体而言,可以通过编辑 `/etc/profile` 文件,添加或修改相关参数,确保用户在指定时间内无操作后自动注销。此外,还可以利用 `timeout` 命令来限制特定命令的执行时间,进一步增强系统的稳定性和安全性。 ... [详细]
    • 公司计划部署邮件服务器,考虑到已有域名,决定自行搭建内部邮件服务器。经过综合考量,最终选择在Linux环境中进行搭建,并记录了相关配置和实践过程。本文将详细介绍Postfix的基本设置步骤和实践经验,帮助读者快速掌握邮件服务器的搭建方法。 ... [详细]
    • Git基础操作指南:掌握必备技能
      掌握 Git 基础操作是每个开发者必备的技能。本文详细介绍了 Git 的基本命令和使用方法,包括初始化仓库、配置用户信息、添加文件、提交更改以及查看版本历史等关键步骤。通过这些操作,读者可以快速上手并高效管理代码版本。例如,使用 `git config --global user.name` 和 `git config --global user.email` 来设置全局用户名和邮箱,确保每次提交时都能正确标识提交者信息。 ... [详细]
    • 如何将PHP文件上传至服务器及正确配置服务器地址 ... [详细]
    • Ceph API微服务实现RBD块设备的高效创建与安全删除
      本文旨在实现Ceph块存储中RBD块设备的高效创建与安全删除功能。开发环境为CentOS 7,使用 IntelliJ IDEA 进行开发。首先介绍了 librbd 的基本概念及其在 Ceph 中的作用,随后详细描述了项目 Gradle 配置的优化过程,确保了开发环境的稳定性和兼容性。通过这一系列步骤,我们成功实现了 RBD 块设备的快速创建与安全删除,提升了系统的整体性能和可靠性。 ... [详细]
    • Spring框架中的面向切面编程(AOP)技术详解
      面向切面编程(AOP)是Spring框架中的关键技术之一,它通过将横切关注点从业务逻辑中分离出来,实现了代码的模块化和重用。AOP的核心思想是将程序运行过程中需要多次处理的功能(如日志记录、事务管理等)封装成独立的模块,即切面,并在特定的连接点(如方法调用)动态地应用这些切面。这种方式不仅提高了代码的可维护性和可读性,还简化了业务逻辑的实现。Spring AOP利用代理机制,在不修改原有代码的基础上,实现了对目标对象的增强。 ... [详细]
    • CentOS 7环境下Jenkins的安装与前后端应用部署详解
      CentOS 7环境下Jenkins的安装与前后端应用部署详解 ... [详细]
    • 在 openSUSE Tumbleweed 系统上搭建 51 单片机开发环境并进行编程实践。首先,通过 `sudo zypper in emacs` 命令安装文本编辑器 Emacs。接着,使用 `sudo zypper in sdcc` 安装 SDCC 编译器。最后,利用 `wget` 下载 sdcflash Python 脚本,以便于单片机的烧录和调试。此外,还介绍了如何配置开发环境,确保各组件协同工作,提高开发效率。 ... [详细]
    • 在搭建Hadoop集群以处理大规模数据存储和频繁读取需求的过程中,经常会遇到各种配置难题。本文总结了作者在实际部署中遇到的典型问题,并提供了详细的解决方案,帮助读者避免常见的配置陷阱。通过这些经验分享,希望读者能够更加顺利地完成Hadoop集群的搭建和配置。 ... [详细]
    • 夸克网盘电脑版上线,实现三端同步备份与高效编辑播放功能 ... [详细]
    • 技术日志:Ansible的安装及模块管理详解 ... [详细]
    • 2023年必备的六大Web3安全交互策略与实践
      2023年必备的六大Web3安全交互策略与实践 ... [详细]
    • 本文探讨了文件传输过程中的优化与安全策略。具体而言,研究了如何将客户端的文件高效上传至服务器。通过使用结构体对象,可以封装文件的相关信息,如位置和大小,并利用缓冲区存储实际数据,从而实现高效的数据传输。此外,文章还讨论了在传输过程中确保数据完整性和安全性的多种方法,包括加密技术和身份验证机制。 ... [详细]
    author-avatar
    通贯戬_461
    这个家伙很懒,什么也没留下!
    PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
    Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有