svn 分支(branch)和标签(tag)管理

news2025/1/15 16:50:14

版本控制的一大功能是可以隔离变化在某个开发线上,这个开发线就是分支(branch)。

分支通常用于开发新功能,而不会影响主干的开发。也就是说分支上的代码的编译错误、bug不会对主干(trunk)产生影响。然后等分支稳定之后,可以再合并到主干上。

版本管理系统的一大功能是标记特定版本,以便在任何时候都可以重建某个版本的环境,这个标记版本的动作就是打标签。

svn不需要特殊命令来打分支或者打标签。它使用的是一种“轻量copy”的方式,这种方式有些像unix的硬链接。它不会完整的拷贝仓男裤,而是创建一个内部链接来指向一个特定的版本。基于此,创建分支和标签(tag)非常快,几乎不需要额外耗费仓库的空间。

1.分支与标签(tag)的区别:

  • 创建方式相同

svn中,分支标签(tag)之间没有什么明显的差别,分支和标签的创建方式相同。

  • 使用情景不同

分支主要用于开发新功能。

标签(tag)用于保存一个静态的内容。例如一个阶段性成果。

如果用tag来存储一个动态变化的内容,那么系统会进行警告。

建议tag的名称包含版本号

branch包括 日期+功能点

  • 分支和tag的转换

当我们发布了1.0版本,这个1.0版本在tag中存储。

后来发现1.0版本需要修改。那么

  1. 我们从1.0的tag创建一个分支。

  1. 在分支上修改,直到修改完成。

  1. 然后再从该分支创建新的tag

2.分支操作

这里先让大家有个大致的里阿杰,第3部分我们来实操

为了方便的进行分支操作,创建仓库时,建议采用 trunk tag branches的结构,后期分支操作很容易。

2.1 创建新分支/标签

当我们希望开发一个新功能,那么创建一个新分支,在新分支上开发是个不错的主意,

这样,可以避免新功能开发对主干功能的影响。哇塞!这个技能不错奥!一定要有!

在上面开发已经创建了版本4,现在想在001.txt上新增一个加法功能。

在空白处,点击右键菜单 TortoiseSVN ->Branch/Tag..

左侧选择branches,并在URL中输入标签名称 (注意,正常开发新功能应当在branch上,如果选择tag,那么后期提交直接提交文件会有警告)

输入日志后,点击【ok】

下面这个提示显示分支已经创建了,但是需要你switch 才能切换到该分支

此时如果在工作区空白处点击右键 TortoiseSVN -> Revision graph,则可以看到如下,已经可以看到新的分支了

4.2切换分支

现在我们切换到刚才创建的分支 dev_add

切换分支后,你的工作区的代码就是该分支的代码了,009.txt就和trunk上不同了

注意,如果你把tag作为开发分支,则提交时,会有如下所示的警告奥,

svn认为tag从branch或者trunk中打标签才合理。

点击 commit按钮,既可完成开发

4.3 打标签

创建tag和创建分支(branch)的操作完全相同

只不过tag用于保存里程碑成果。比如0.1版本的软件资产。通常不在tag中修改

例如,实际工作中可能存在如下情景:

  1. 假设图书管理系统V1.0版本代码已经通过测试,现在我们将该成果打标签,在tag中存储(将阶段成果固化)

  1. 后来发现1.0版本有bug。我们从1.0的tag创建一个分支。

  1. 在分支上修改,直到修改完成。

  1. 然后再从该分支创建新的tag。

3.分支实操

下面让我们来完整的走个流程试一试!

3.1创建一个有 trunk/branch/tag的仓库(svn server端)

点击Repositories上点击右键菜单:Create New Repository

仓库名称建议采用英文名称( lianxi)

3.2.将本地项目导入到远程仓库

将导入的trunk地址复制到 “URL of Repository”中

点击 【ok】 按钮提交

3.3检出代码到本地

为了下面的练习效果更明显。

我们新建一个空的文件夹,在空白处点击右键“SVN checkout”将项目checkout导出到本地

输入项目的仓库路径,将代码检出

3.4.分支创建及提交

总的步骤如下,下面我们来一步一步完成

  1. 在主干上:修改009.txt的第1行追加1。 提交日志:修改009的第1行追加1

  1. 在主干上:修改009.txt的第2行追加2。 提交日志:修改009的第2行追加2

  1. 创建分支 demo_20230303_dev_add 提交日志:创建分支demo_20230303_dev_add

  1. 在主干上 修改009.txt的第3行追加3。 提交日志:修改009的第3行追加3

  1. 切换到分支(switch) demo_20230303_dev_add

  1. 在分支demo_20230303_dev_add 上 修改001.txt 删除4-6行,添加 如下的add函数,提交日志:添加add函数

int add(int x , int y)

{

return x+y;

}

  1. 在分支demo_20230303_dev_add 上 修改002.txt 末尾追加----,

提交日志: 修改002.txt 末尾追加----

  1. 将分支合并到主干,提交日志:合并分支demo_20230303_dev_add 到主干

此时主干的代码即包括了主干的修改,又包括分支的修改。

3.4.1 在主干上:修改009.txt的第1行追加1。

提交日志修改009的第1行追加1

修改的文件要提交到版本库,只需要选中改文件,点击右键菜单

3.4.2 在主干上:修改009.txt的第2行追加2。

提交日志:修改009的第2行追加2

3.4.3 创建分支 demo_20230303_dev_add

提交日志创建分支demo_20230303_dev_add

文件夹的空白处点击右键菜单 TortoiseSVN -> Branch/Tag..

点击 To path 文本框后的 【...】,选择branches,并补充分支名称后返回,填写分支日志后点击【ok】

建议分支名称包含日期和功能

完成时,系统提示当前并没有切换到新分支

3.4.4 在主干上 修改009.txt的第3行追加3。

提交日志修改009的第3行追加3

3.4.5 切换到分支(switch) demo_20230303_dev_add

在工作区点击右键菜单 TortoiseSVN -> switch

3.4.6 在分支demo_20230303_dev_add 上 修改001.txt 删除4-6行, 添加 add函数,

提交日志添加add函数

int add(int x , int y)

{

return x+y;

}

提交之后可以查看版本树 (文件夹空白处点击右键菜单 TortoiseSVN ->Revison graph

3.4.7在分支demo_20230303_dev_add 上 修改002.txt 末尾追加----

提交日志修改002.txt 末尾追加----

3.4.8 将分支合并到主干,

提交日志合并分支demo_20230303_dev_add 到主干

先切换到主干,然后执行合并

分支的日志

3.5 打标签

如果

下面我们模拟以下操作步骤:

  1. 假设图书管理系统V1.0版本代码已经通过测试,现在我们将该成果打标签1(将阶段成果固化)

  1. 图书管理系统继续开发主干分支继续修改

  1. 从标签1创建分支

当我们发布了1.0版本,这个1.0版本在tag中存储。

后来发现1.0版本需要修改。那么

  1. 我们从1.0的tag创建一个分支。

  1. 在分支上修改,直到修改完成。

  1. 然后再从该分支创建新的tag

3.6 注意 tag一般只保存阶段成果,不用来保存变化的内容

如果你把tag作为开发分支,则提交时,会有如下所示的警告奥,

svn认为tag从branch或者trunk中打标签才合理。

点击 commit按钮,既可完成开发

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/387700.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

实现echarts主题随项目主题切换

前言 项目中很多时候都带有dark/light两中主题类型,通过switch标签控制,但是echarts图形是通过canvas标签绘制,其背景颜色和字体样式并不会随着项目主题类型的切换而切换。所以需要额外设置监听主题事件,主要实现思路如下&#x…

【LeetCode】982. 按位与为零的三元组

982. 按位与为零的三元组 题目描述 给你一个整数数组 nums &#xff0c;返回其中 按位与三元组 的数目。 按位与三元组 是由下标 (i, j, k) 组成的三元组&#xff0c;并满足下述全部条件&#xff1a; 0 < i < nums.length0 < j < nums.length0 < k < num…

深度学习笔记:数据正规化和抑制过拟合

1 Batch-normalization batch-normalization将输入数据转化为平均值0&#xff0c;标准差为1的分布&#xff0c;该方法可以加速学习并抑制过拟合。batch-normalization作为神经网络特定的一个层出现 batch-normalization计算表达式&#xff1a; 接下来&#xff0c;会对数据进…

tmux 使用看这一篇文章就够了

tmux简介及用途 tmux是一个终端复用工具&#xff0c;允许用户在一个终端会话中同时管理多个终端窗口&#xff0c;提高了终端使用效率&#xff0c;尤其在服务器上进行远程管理时更加实用。在tmux中&#xff0c;可以创建多个终端窗口和窗格&#xff0c;并在这些窗口和窗格之间自…

八、Bean的生命周期

Bean生命周期的管理&#xff0c;可以参考Spring的源码&#xff1a;AbstractAutowireCapableBeanFactory类的doCreateBean()方法。 1 什么是Bean的生命周期 Spring其实就是一个管理Bean对象的工厂。它负责对象的创建&#xff0c;对象的销毁等。 所谓的生命周期就是&#xff1a…

【SpringCloud】SpringCloud教程之Feign实战

目录前言SpringCloud Feign远程服务调用一.需求二.两个服务的yml配置和访问路径三.使用RestTemplate远程调用(order服务内编写)四.构建Feign(order服务内配置)五.自定义Feign配置(order服务内配置)六.Feign配置日志(oder服务内配置)七.Feign调优(order服务内配置)八.抽离Feign前…

论文投稿指南——中文核心期刊推荐(新闻事业)

【前言】 &#x1f680; 想发论文怎么办&#xff1f;手把手教你论文如何投稿&#xff01;那么&#xff0c;首先要搞懂投稿目标——论文期刊 &#x1f384; 在期刊论文的分布中&#xff0c;存在一种普遍现象&#xff1a;即对于某一特定的学科或专业来说&#xff0c;少数期刊所含…

Spring Cloud融合Nacos配置加载优先级 | Spring Cloud 8

一、前言 Spring Cloud Alibaba Nacos Config 目前提供了三种配置能力从 Nacos 拉取相关的配置&#xff1a; A&#xff1a;通过内部相关规则(应用名、扩展名、profiles)自动生成相关的 Data Id 配置B&#xff1a;通过 spring.cloud.nacos.config.extension-configs的方式支持…

Redis十大类型——List常见操作

Redis十大类型——List常见操作 底层数据结构是双端链表 Redis列表是字符串值的链接列表。Redis列表经常用于&#xff1a; 实现堆栈和队列。为后台工作系统构建队列管理。 命令操作简列 lpush &#xff1a; 左侧添加元素rpush &#xff1a; 右侧添加元素lrange &#xff1a; …

LPNet for Image Derain

Lightweight Pyramid Networks for Image Deraining前置知识高斯-拉普拉斯金字塔图像中的高频信息和低频信息为什么高斯-拉普拉斯金字塔可以实现去雨&#xff1f;可能性分析网络结构整体结构&#xff1a;子网结构&#xff1a;递归块结构&#xff1a;后续补充代码 前置知识 这…

数组--java--动态数组--有序数组--底层

java数组基础--java中的数组创建数组空间占用初始化数组访问元素插入查找删除元素动态数组扩容插入和添加重写toString删除二维数组二维数组注意点有序数组实现测试写在开头&#xff1a; 这篇文章包括数组的基础、一点底层的内容和一些稍微深入的东西。 作为第一个深入学习的数…

【2021.12.25】ctf逆向中常见加密算法和编码识别

【2021.12.25】ctf逆向中常见加密算法和编码识别&#xff08;含exe及wp&#xff09; 文章目录【2021.12.25】ctf逆向中常见加密算法和编码识别&#xff08;含exe及wp&#xff09;0、前言1、基础加密手法2、base64&#xff08;1&#xff09;原理&#xff1a;&#xff08;2&#…

利用出厂状态下的闲置主机配置HP M1136打印机

利用出厂状态下的闲置主机配置HP M1136打印机 打印机型号&#xff1a;LaserJet M1136 MFP 主机状态&#xff1a;出厂状态&#xff0c;C盘及储存盘被分成了5片 网络环境&#xff1a;与打印机相连的主机全程无Internet连接&#xff0c;主机处于离线状态。打印机驱动及一些相关软…

Splunk 成功获取Salesforce 数据

1: 先说一下Splunk server 上要安装Splunk Add-on for Salesforce : (https://splunkbase.splunk.com/) 去下载: https://splunkbase.splunk.com/app/3549 2: 下载安装后,看到如下界面: 3: 官方的指导文档: Configure your Salesforce account to collect data…

0301_对应的南京比特物联网

0301_对应的南京比特物联网目录概述需求&#xff1a;设计思路实现思路分析1.流程拓展实现性能参数测试&#xff1a;参考资料和推荐阅读Survive by day and develop by night. talk for import biz , show your perfect code,full busy&#xff0c;skip hardness,make a better …

C#的Version类型值与SQL Server中二进制binary类型转换

使用C#语言编写的应用程序可以通过.NET Framework框架提供的Version类来控制每次发布的版本号&#xff0c;以便更好控制每次版本更新迭代。 版本号由两到四个组件组成&#xff1a;主要、次要、内部版本和修订。 版本号的格式如下所示&#xff0c; 可选组件显示在方括号 ([ 和…

UML 时序图

时序图&#xff08;Sequence Diagram&#xff09;是显示对象之间交互的图&#xff0c;是按时间顺序排列的。 时序图中显示的是参与交互的对象及其对象之间消息交互的顺序。 时序图包括的建模元素主要有&#xff1a;对象&#xff08;Actor&#xff09;、生命线&#xff08;Lif…

项目实战典型案例19——临时解决方案和最终解决方案

临时解决方案和最终解决方案一&#xff1a;背景介绍二&#xff1a;思路&方案四&#xff1a;总结五&#xff1a;升华一&#xff1a;背景介绍 本篇博客是对项目开发中出现的临时解决方案和最终解决方案进行的总结和改进。目的是将经历转变为自己的经验。通过博客的方式分享给…

(蓝桥真题)最长不下降子序列(权值线段树)

样例输入&#xff1a; 5 1 1 4 2 8 5 样例输出&#xff1a; 4 分析&#xff1a;看到这种对其中连续k个数进行修改的我们就应该想到答案是由三部分组成&#xff0c;因为求的是最长不下降子序列&#xff0c;那么我们可以找到一个最合适的断点i&#xff0c;使得答案是由区间[1…

【信息安全案例】——网络信息面临的安全威胁

&#x1f4d6; 前言&#xff1a;2010年&#xff0c;震网病毒&#xff08;Stuxnet&#xff09;席卷全球工业界。其目标是从物理上摧毁一个军事目标&#xff0c;这使得网络武器不仅仅只存在于那个人类创造的空间。网络武器的潘多拉魔盒已经打开。 目录&#x1f552; 1. 信息、信息…