博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
tortoiseSVN如何发现和解决冲突?
阅读量:6253 次
发布时间:2019-06-22

本文共 1542 字,大约阅读时间需要 5 分钟。

版本冲突原因:

假设A、B两个用户都在版本号为100的时候,更新了kingtuns.txt这个文件,A用户在修改完成之后提交kingtuns.txt到服务器,这个时候提交成功,这个时候kingtuns.txt文件的版本号已经变成101了。同时B用户在版本号为100的kingtuns.txt文件上作修改,修改完成之后提交到服务器时,由于不是在当前最新的101版本上作的修改,所以导致提交失败。

 

版本冲突现象:

冲突发生时,subversion会在当前工作目录中保存所有的目标文件版本[上次更新版本、当前获取的版本(即别人提交的版本)、自己更新的版本、目标文件]。

假设文件名是kingtuns.txt

对应的文件名分别是:

kingtuns.txt.r101

kingtuns.txt.r102

kingtuns.txt.mine

kingtuns.txt。同时在目标文件中标记来自不同用户的更改。

 

版本冲突解决:

场景:

1、现在A、B两个用户都更新kingtuns.txt文件到本地。

 

 

 

2、文档中原始文件内容如下:

 

 

 

3、A用户修改文件,添加内容“A用户修改内容”完成后提交到服务器

 

 

 

 

 

4、B用户修改文件,添加内容“B用户修改内容”完成后提交到服务器

 

 

B用户提交更新至服务器时提示如下:

 

 

B用户将文件提交至服务器时,提示版本过期:首先应该从版本库更新版本,然后去解决冲突,冲突解决后要执行svn resolved(解决),然后在签入到版本库。在冲突解决之后,需要使用svn resolved(解决)来告诉subversion冲突解决,这样才能提交更新。

 

解决冲突有三种选择:

 

A、放弃自己的更新,使用svn revert(回滚),然后提交。在这种方式下不需要使用svn resolved(解决)

 

B、放弃自己的更新,使用别人的更新。使用最新获取的版本覆盖目标文件,执行resolved filename并提交(选择文件—右键—解决)。

 

C、手动解决:冲突发生时,通过和其他用户沟通之后,手动更新目标文件。然后执行resolved filename来解除冲突,最后提交。

 

解决步骤如下:

1、  在当前目录下执行“update”(更新)操作

 

 

2、  在冲突的文件上(选中文件--右键菜单—TortoiseSVN—Edit conflicts(解决冲突)),出现如下窗口

 

Theirs窗口为服务器上当前最新版本

Mine窗口为本地修改后的版本

Merged窗口为合并后的文件内容显示

     

3、  如果要使用服务器版本,在Theirs窗口选中差异内容,右键,选择Use this text block(使用这段文本块)。

同理如果要使用本地版本,在协商后,在Mine窗口右键,选择Use this text block(使用这段文本块)。

 

    

4、  修改完成后,保存kingtuns.txt文件内容。

 

5、  在B用户的冲突目录下,选中文件--右键菜单—TortoiseSVN—Resolved(解决)。会列出冲突的文件列表,如果确认已经解决,点OK。

 

 

6、  冲突解决

 

      

7、提交解决冲突后的文件。

 

 

 

 

如何降低冲突解决的复杂度:

1、当文档编辑完成后,尽快提交,频繁的提交/更新可以降低在冲突发生的概率,以及发生时解决冲突的复杂度。

2、在提交时,写上明确的message,方便以后查找用户更新的原因,毕竟随着时间的推移,对当初更新的原因有可能会遗忘

3、养成良好的使用习惯,使用SVN时每次都是先提交,后更新。每天早上打开后,首先要从版本库获取最新版本。每天下班前必须将已经编辑过的文档都提交到版本库。

 

转载于:https://www.cnblogs.com/YuyuanNo1/p/7838184.html

你可能感兴趣的文章
c/c++处理参数
查看>>
编译ycm库
查看>>
云计算行业的微笑曲线仍在,价值传递的中间环节并未减少
查看>>
CI 失败的五大原因
查看>>
指令汇B新闻客户端开发(二) 主页面布局
查看>>
高通Qualcomm平台lk(light kernel)启动流程2——aboot_init()
查看>>
【LeetCode从零单排】No26.Remove Duplicates from Sorted Array
查看>>
java-CompletionService
查看>>
【前沿】TensorFlow Pytorch Keras代码实现深度学习大神Hinton NIPS2017 Capsule论文
查看>>
中断和异常的概念
查看>>
Xdebug是一个开放源代码的PHP程序调试器
查看>>
无线安全技术:移动医疗技术及应用概述
查看>>
携程数据库全线崩溃引热议 总结网友奇葩的“数据库门”
查看>>
【★】选择好游戏认准这30个特质!
查看>>
CIO与CMO推动数据驱动的营销战略
查看>>
IPv4还没终结 IPv6时代已悄然到来
查看>>
你所不知道的大数据:一条微博得到王思聪手机号
查看>>
不可思议的德国汉堡,一座不能被忽略的城市!
查看>>
【喜大普奔】GN5i华东华南可以购买啦
查看>>
Power AI:堪称机器学习的“破壁人”
查看>>