当前位置: 首页 > news >正文

版本控制系统-SVN

SVN

Apache Subversion 通常被缩写成 SVN,是一个开放源代码的版本控制系统。

官网:https://subversion.apache.org
资料:https://svnbook.red-bean.com、https://www.runoob.com/svn/svn-tutorial.html
下载:https://sourceforge.net/projects/win32svn/

与git对比

SVN(Subversion)和Git都是版本控制工具,它们的作用都是帮助程序员管理和追踪代码的变化。以下是两者的主要区别:

  • 分布式和集中式
    Git是一种分布式版本控制系统,每个开发者都有一个完整的代码库。开发者可以在本地创建、提交和合并分支,而不需要连接到中央服务器。这意味着,即使断开与中央服务器的连接,开发者仍然可以继续工作。相比之下,SVN是一种集中式版本控制系统,代码库保存在中央服务器上,每个开发者都从中央服务器获取代码,并将更改提交到中央服务器。

  • 分支和合并
    在Git中,分支和合并是非常简单和快速的。开发者可以轻松地创建和合并分支,这使得并行开发和测试变得容易。相反,在SVN中,分支和合并通常需要复制和合并文件夹,这可能会导致冲突和错误,并且需要大量的手动操作。

  • 性能
    Git通常比SVN更快,特别是在执行诸如提交和拉取等操作时。这主要是因为Git是分布式的,可以在本地缓存文件,而SVN是集中式的,需要连接到中央服务器进行操作。

概念

  • 仓库(Repository):仓库是SVN中存储代码和版本历史记录的地方。它是一个集中存储代码的服务器。
  • 版本(Revision):版本表示代码仓库的一个特定状态,每个提交操作都会创建一个新版本。每个版本都有一个唯一的标识符,通常用一个递增的数字表示。
  • 工作副本(Working Copy):工作副本是从SVN仓库中取出的代码的本地副本。开发者在工作副本中进行修改、添加和删除文件,并通过提交操作将这些更改同步到仓库。
  • 提交(Commit):提交是将工作副本中的更改应用到SVN仓库的操作。提交会创建一个新的版本,并将工作副本中的更改记录到该版本中。
  • 更新(Update):更新是将仓库中的最新代码更新到工作副本的操作。更新操作会将仓库中的最新版本与工作副本进行比较,并将差异部分合并到工作副本中。
  • 分支(Branch):分支是将代码库分成独立的开发线路的操作。通过创建分支,可以在不影响主干代码的情况下进行并行开发、实验或修复。
  • 合并(Merge):合并是将一个分支的更改合并到另一个分支或主干的操作。合并可以将不同分支上的代码更改整合到一起,确保所有修改都被应用。

工具

客户端UI工具:

  • TortoiseSVN:适用于Windows操作系统的图形化界面工具,集成在资源管理器中,可直观地进行版本控制操作。
  • SmartSVN:跨平台的SVN客户端工具,提供可视化界面和强大的功能,支持Windows、Mac和Linux操作系统。
  • Cornerstone:适用于Mac操作系统的SVN客户端,提供直观的用户界面和易用的版本控制功能。
  • RapidSVN:跨平台的SVN客户端,提供简单易用的界面和常用的版本控制功能。

Web端UI工具:

  • VisualSVN Server Manager:适用于Windows操作系统的SVN服务器管理工具,提供基于Web的用户界面,可以管理SVN仓库、权限和用户等。
  • RhodeCode:一个开源的SVN和Git版本控制系统,提供Web界面来管理代码仓库、用户权限和团队协作。
  • ViewVC:一个基于Web的SVN仓库浏览工具,提供源代码的查看、比较和检索等功能。
  • WebSVN:一个基于Web的SVN仓库浏览工具,提供类似文件浏览器的界面,可以查看代码和历史记录。

一般流程

  1. 创建仓库(Repository):首先,在SVN服务器上创建一个仓库,用于存储代码和版本历史记录。

在这里插入图片描述

  1. 检出工作副本(Checkout):在本地机器上执行检出操作,将仓库中的代码复制到本地,创建一个工作副本。这个工作副本是你在本地进行修改和操作的副本。
    在这里插入图片描述
    在这里插入图片描述
    这是典型的SVN仓库结构,其中各目录的作用如下:

    branches(分支):该目录用于存放代码的分支。在软件开发中,分支常被用于并行开发、实验和修复工作。创建分支可以让团队成员在独立的代码线上进行开发,避免干扰主干(trunk)上的稳定代码。一般情况下,每个分支都有自己的文件夹,并且可以独立进行版本控制。

在这里插入图片描述

tags(标签):该目录用于存放代码的标签。标签通常用于标记项目的里程碑版本、发布版本或重要的版本点。在某个特定时间点,将代码的一个快照副本标记为一个标签,以便后续随时查阅和回滚到该版本。标签一般不可修改,用于保留历史记录和实现版本的可追溯性。trunk(主干):该目录用于存放主要的开发代码。主干是项目的核心部分,包含最新的稳定版本和功能。大多数开发工作都在主干上进行,团队成员在这里共享和协同开发代码。主干上的代码会随着时间推移不断更新和演进。通过这种目录结构,SVN提供了一种组织代码和版本控制的方法。分支和标签的目录可以帮助团队进行并行开发和管理重要版本,而主干目录则是项目的主要代码存储区。这样的结构有助于团队协作、版本控制和代码的可追溯性。
  1. 修改文件(Modify):在工作副本中进行代码的修改、添加和删除操作,根据需求进行开发或修复。

  2. 更新工作副本(Update):当其他人提交了新的代码到仓库时,你需要执行更新操作,将仓库中的最新代码更新到你的工作副本中。这样可以保持你的工作副本与仓库同步。
    在这里插入图片描述

  3. 解决冲突(Resolve Conflict):如果在更新操作中遇到冲突,即你和其他人对同一代码部分进行了不兼容的修改,你需要解决冲突。SVN会尝试自动合并不冲突的部分,但对于冲突的部分,你需要手动解决。

  4. 提交修改(Commit):当你完成对代码的修改后,需要执行提交操作,将你的修改应用到仓库中。提交会创建一个新的版本,并将你的修改记录到该版本中。

  5. 分支和合并(Branch and Merge):如果需要进行并行开发、实验或修复,可以创建分支。分支允许你在不影响主干代码的情况下独立开发。完成分支上的工作后,可以将分支上的修改合并回主干或其他分支。

  6. 查看历史记录(View History):SVN记录了仓库中的所有版本历史记录。你可以随时查看每个版本的修改内容和作者等信息。

相关文章:

版本控制系统-SVN

SVN Apache Subversion 通常被缩写成 SVN,是一个开放源代码的版本控制系统。 官网:https://subversion.apache.org 资料:https://svnbook.red-bean.com、https://www.runoob.com/svn/svn-tutorial.html 下载:https://sourceforg…...

【电路笔记】-串联RLC电路分析

串联RLC电路分析 文章目录 串联RLC电路分析1、概述2、瞬态响应3、AC响应4、RCL和CLR配置5、结论 电阻器 、电感器 (L) 和电容器 © 是电子器件中的三个基本无源元件。 它们的属性和行为已在交流电阻、交流电感和交流电容文章中详细介绍。 在本文中,我们将重点讨…...

大数据毕业设计选题推荐-家具公司运营数据分析平台-Hadoop-Spark-Hive

✨作者主页:IT研究室✨ 个人简介:曾从事计算机专业培训教学,擅长Java、Python、微信小程序、Golang、安卓Android等项目实战。接项目定制开发、代码讲解、答辩教学、文档编写、降重等。 ☑文末获取源码☑ 精彩专栏推荐⬇⬇⬇ Java项目 Python…...

【触想智能】工业显示器上市前的检测项目分享

工业显示器在上市前,需要做一项重要的工作,那就是工业显示器出厂前的产品可靠性检测。 工业显示器选择的测试项目相比商用端更为严格,常见的性能测试项目包括高温老化、防尘防水、电磁静电干扰、防摔防撞等,在工业级应用领域&…...

Vue使用epubjs电子书

npmjs: https://www.npmjs.com/package/epubjs 在线电子书转换器 安装: npm i epubjs 简单封装: src/hooks/ import Epub from "epubjs"; import type { Book, Rendition } from epubjs import type { BookOptions } from epubjs/types…...

python机器学习——决策树

决策树 # 模块导入 from sklearn.tree import ExtraTreeRegressor as ETR, DecisionTreeRegressor as DTRExtraTreeRegressor和DecisionTreeRegressor是scikit-learn库中的两种回归模型,用于拟合和预测连续型目标变量。 决策树是一种基于树结构的机器学习算法&…...

__attribute__((__used__)) 和 __attribute__((__section__(“*“ “*“)))的使用

见&#xff1a;haproxy代码 C语言注册函数和调用函数&#xff0c;便于模块化开发和编程。 #include <stdio.h>#ifdef __APPLE__ #define HA_SECTION(s) __attribute__((__section__("__DATA, " s))) #define HA_SECTION_START(s) __asm("…...

webgoat-(A1)SQL Injection

SQL Injection (intro) SQL 命令主要分为三类&#xff1a; 数据操作语言 &#xff08;DML&#xff09;DML 语句可用于请求记录 &#xff08;SELECT&#xff09;、添加记录 &#xff08;INSERT&#xff09;、删除记录 &#xff08;DELETE&#xff09; 和修改现有记录 &#xff…...

Flink的API分层、架构与组件原理、并行度、任务执行计划

Flink的API分层 Apache Flink的API分为四个层次&#xff0c;每个层次都提供不同的抽象和功能&#xff0c;以满足不同场景下的数据处理需求。下面是这四个层次的具体介绍&#xff1a; CEP API&#xff1a;Flink API 最底层的抽象为有状态实时流处理。其抽象实现是Process Functi…...

Transformer:开源机器学习项目,上千种预训练模型 | 开源日报 No.66

huggingface/transformers Stars: 113.5k License: Apache-2.0 这个项目是一个名为 Transformers 的开源机器学习项目&#xff0c;它提供了数千种预训练模型&#xff0c;用于在文本、视觉和音频等不同领域执行任务。该项目主要功能包括&#xff1a; 文本处理&#xff1a;支持…...

Corel VideoStudio 会声会影2024剪辑中间的视频怎么删 剪辑中音乐太长怎么办

我很喜欢视频剪辑软件Corel VideoStudio 会声会影2024&#xff0c;因为它使用起来很有趣。它很容易使用&#xff0c;但仍然给你很多功能和力量。视频剪辑软件Corel VideoStudio 会声会影2023让我与世界分享我的想法&#xff01;“这个产品的功能非常多&#xff0c;我几乎没有触…...

数据结构初阶---复杂度的OJ例题

复杂度的OJ例题 一、消失的数字1.思路一2.思路二3.思路三 二、旋转数组1.思路一2.思路二3.思路三 一、消失的数字 数组nums包含从0到n的所有整数&#xff0c;但其中缺了一个。请编写代码找出那个缺失的整数。你有办法在O(N)时间内完成吗&#xff1f; 链接&#xff1a;力扣&…...

Prometheus|云原生|grafana的admin用户密码重置备忘记录

很久很久以前部署的一个Prometheus套装里的grafana密码给忘记了&#xff0c;回忆总是很痛苦&#xff0c;因此还是在这里简单的记录一下&#xff0c;下次就不需要满世界反翻找了。 一&#xff0c; 改库重置密码为admin grafana密码存放在哪里的&#xff1f; 必须说明一下&am…...

[hive]中的字段的数据类型有哪些

Hive中提供了多种数据类型用于定义表的字段。以下是Hive中常见的数据类型&#xff1a; 布尔类型&#xff08;Boolean&#xff09;&#xff1a;用于表示true或false。 字符串类型&#xff08;String&#xff09;&#xff1a;用于表示文本字符串。 整数类型&#xff08;Intege…...

第六章 树【数据结构和算法】【精致版】

第六章 树【数据结构和算法】【精致版】 前言版权第六章 树6.1 应用实例6.2 树的概念6.2.1树的定义与表示6.2.2 树的基本术语6.2.3树的抽象数据类型定义 6.3 二叉树6.3.1二叉树的定义6.3.2 二叉树的性质6.3.3 二叉树的存储 6.4 二叉树的遍历6.4.1 二叉树的遍历及递归实现**1-二…...

第九章:Dynamic Symbolic Execution

文章目录 Dynamic Symbolic Executionoverviewmotivationdynamic symbolic execution常用的其他技术对比Random Testingsymbolic executionCombined static and symbolic - Dynamic Execution (DSE)step1: 初始化两个具体的值 x,ystep2: 根据定义得出 z 的 concrete value 和 s…...

在搜索引擎中屏蔽csdn

csdn是一个很好的技术博客&#xff0c;里面信息很丰富&#xff0c;我也喜欢在csdn上做技术笔记。 但是CSDN体量太大&#xff0c;文章质量良莠不齐。当在搜索引擎搜索技术问题时&#xff0c;搜索结果中CSDN的内容占比太多&#xff0c;导致难以从其他优秀的博客平台中获取信息。因…...

Linux开发工具的使用(vim、gcc/g++ 、make/makefile)

文章目录 一 &#xff1a;vim1:vim基本概念2:vim的常用三种模式3:vim三种模式的相互转换4:vim命令模式下的命令集- 移动光标-删除文字-剪切/删除-复制-替换-撤销和恢复-跳转至指定行 5:vim底行模式下的命令集 二:gcc/g1:gcc/g的作用2:gcc/g的语法3:预处理4:编译5:汇编6:链接7:函…...

MySQL(10):创建和管理表

基础知识 在 MySQL 中&#xff0c;一个完整的数据存储过程总共有 4 步&#xff0c;分别是&#xff1a;创建数据库、确认字段、创建数据表、插入数据。 要先创建一个数据库&#xff0c;而不是直接创建数据表&#xff1a;从系统架构的层次上看&#xff0c;MySQL 数据库系统从大到…...

Python赋值给另一个变量且不改变原变量

Python赋值给另一个变量且不改变原变量 在Python中&#xff0c;如果你想将一个变量的值赋给另一个变量&#xff0c;同时保持原变量不变&#xff0c;你可以使用复制&#xff08;copy&#xff09;而不是引用&#xff08;reference&#xff09;。Python中的变量通常是通过引用&…...

PHP进销存ERP系统源码

PHP进销存ERP系统源码 系统介绍&#xff1a; 扫描入库库存预警仓库管理商品管理供应商管理。 1、电脑端手机端&#xff0c;手机实时共享&#xff0c;手机端一目了然。 2、多商户Saas营销版 无限开商户&#xff0c;用户前端自行注册&#xff0c;后台管理员审核开通 3、管理…...

npm i 报错:Cannot read properties of null (reading ‘refs‘)

问题: 旧项目要更改东西&#xff0c;重新部署上线的时候&#xff0c;发现页面显示有异常。当时在开发环境是没有问题的。后经排查是一个引入swiper的页面报错了&#xff0c;只要注释掉swiper插件&#xff0c;就没问题了&#xff0c;但这肯定是不行的。 原因&#xff1a; npm和…...

C#学习中关于Visual Studio中ctrl+D快捷键(快速复制当前行)失效的解决办法

1、进入VisualStudio主界面点击工具——>再点击选项 2、进入选项界面后点击环境——>再点击键盘&#xff0c;我们可用看到右边的界面的映射方案是VisualC#2005 3、 最后点击下拉框&#xff0c;选择默认值&#xff0c;点击之后确定即可恢复ctrlD的快捷键功能 4、此时可以正…...

银河E8,吉利版Model 3:5米大车身、45寸大屏、首批8295座舱芯

作者 | Amy 编辑 | 德新 吉利银河E8在曝光后多次引爆热搜&#xff0c;李书福更是赞誉有加&#xff0c;称其为「买了就直接享受」。这款备受瞩目的车型于 10月30日晚首次亮相。 虽然新车外观在今年上海车展上早已曝光&#xff0c;但这次的发布会却带来了不少惊喜。新车架构以及…...

技术分享 | 被测项目需求你理解到位了么?

需求分析是开始测试工作的第一步&#xff0c;产品会先产出一个需求文档&#xff0c;然后会组织需求宣讲&#xff0c;在需求宣讲中分析需求中是否存在问题&#xff0c;然后宣讲结束后&#xff0c;通过需求文档分析测试点并且预估排期。所以对于需求的理解非常重要。 需求文档 …...

[MRCTF2020]你传你呢1

提示 只对php以及phtml文件之类的做了防护content-type.htaccess文件 这里就不整那么麻烦直接抓包测试 首先对后缀测试看过滤了哪些 (php php3 pht php5 phtml phps) 全部被ban了 到这里的后续思路通过上传一些配置文件把上传的图片都以php文件执行 尝试上传图片码, 直接上传成…...

一些对程序员有用的网站

当你遇到问题时 Stack Overflow&#xff1a;订阅他们的每周新闻和任何你感兴趣的主题Google&#xff1a;全球最大搜索引擎必应&#xff1a;在你无法使用Google的时候CSDN&#xff1a;聊胜于无AI导航一号AI导航二号 新闻篇 OSCHINA&#xff1a;中文开源技术交流社区 针对初学…...

小程序使用echarts(超详细教程)

小程序使用echarts第一步就是先引用到小程序里面&#xff0c;可以直接从这里下载 文件很多&#xff0c;我们值下载 ec-canvas 就好&#xff0c;下载完成后&#xff0c;直接放在pages同级目录下 index.js 在我们需要的页面的 js 文件顶部引入 // pages/index/index.js impor…...

js控制输入框中的光标位置

主要逻辑 主要应用selectionStart、selectionEnd来实现 <!DOCTYPE html> <html lang"en"><head><meta charset"UTF-8"><meta name"viewport" content"widthdevice-width, initial-scale1.0"><title…...

Openssl生成证书-nginx使用ssl

Openssl生成证书并用nginx使用 安装openssl yum install openssl -y创库目录存放证书 mkdir /etc/nginx/cert cd /etc/nginx/cert配置本地解析 cat >>/etc/hosts << EOF 10.10.10.21 kubernetes-master.com EOF10.10.10.21 主机ip、 kubernetes-master.com 本…...