几天前,我开始将壹個
新的 Libcloud 网站迁移到我们的
Apache SVN 网站资源库的工作。
在这次迁移中,我进行了壹堆提交到SVN资源库的操作,这些提交操作是由新增(增加源代码,并且为新的网站生成静态文件)和删除(删除旧网站上的源代码和数据)组成。
在某些时候,我已经更新了网站内容,并且重新生成了网站,并且想再次提交更新过的文件。
当这些更新和删除操作在传输的时候,所有的壹切看上去都很好,但是就在服务器准备响应所有这些更新时,我接收到了如下的错误信息:
Transmitting file data ............svn: Commit failed (details follow):
svn: Delta source ended unexpectedly
我以前从来没有接到过这种错误信息,但是我猜测这個问题可能与壹些怪异的壹致性问题有关系,在此之前我增加新的网站文件和删除旧文件的时候有看到过这种问题。
当时我是这麽做的,我在提交和之后壹個大的提交之间运行了几次 svn update,尽管我觉得这不应该,但是我从服务器端接收到了旧的更新,因为本地资源库应该拥有所有的更新内容,并且表现出壹個最新的状态。
其中壹個我执行的提交操作很庞大,包含了大量的更新内容,所以我立即猜测到这可能与Apache GEO 负载均衡的 SVN 配置和壹些奇怪的复制/不同步的问题有关系。我等了好几分钟,然后再次运行 svn update 命令,这次问题似乎被解决了,我接收到了所有的更新内容,这些内容在壹致性问题出现之前就已经存在于本地了。看上去,我要麽再次重定向到相同的
SVN 服务器,要麽把现在所有的变化完全复制到另一台服务器上(非常需要,我不能够100%肯定当前的复制是同步的还是不同步的)。
无论如何,现在回到最初的问题上去。
在我遇到这個错误信息的时候,我尝试了如下事情:
1、我检查了 svn status 的输出内容;
2、我尝试使用命令 svn update -r <rev> 检出壹個早期的版本;
3、我尝试了clean checkout (使用命令 svn co <repo url> clean-checkout);
没有壹個方法是奏效的。
svn status 只显示已经存在的文件的更新状态(M),而且这种更新不包含增加的新文件,在我重新添加了更新过的文件之后(是的,这些文件并不包含.svn 目录),我尝试了上述的方法2和方法3,但是我仍然在提交的时候接收到了相同的错误信息。
在这种情况下,我彻底没撤了,而且我不想把这個问题报告给还不存在的ASF基础架构团队,所以我开始尝试用 Google 来找到问题的解决方案。最后我无功而返,但是至少有壹個共识就是这似乎是由壹种壹致性问题引起的,它发生在本地 checkout 出来的版本和远程资源库之间,就像我前面所猜测的那样。
为了找出到底是哪個文件或者文件夹引起的这個问题,我写了壹小段脚本,用于将所有的文件壹個接壹個的提交。
这样做对于项目成员们而言没有任何价值,甚至可能让他们不高兴,因为这样做会导致100多条提交记录,而且每条提交记录都会生成壹個发送给commits@ 邮件列表的通知邮件。
#!/bin/bash
FILES=$(svn status generated/ | awk '{print $2}')
for file in ${FILES}; do
svn commit ${file} -m "Regenerate website."
done
在这些提交操作中,除了三個文件提交失败以外,其它的都提交成功了。对于这三個叛逆的文件,服务器端返回了壹個错误信息说,这些文件不属于资源库的壹部分。这就是壹致性问题,因为 svn status 显示这些文件已经被更新过,并且没有新的内容引入。
为了解决这個问题,我尝试移除了这些文件(svn rm),把它们再重新加回来(svn add)最后提交更新。
# backup to-be removed files (exclude .svn directories)
svn rm generated/blog/tags/dir1
svn rm generated/blog/tags/dir2
svn rm generated/blog/tags/dir3
# re-added changed files back
svn add generated/blog/tags/*
svn commit -m "Regenerate website."
这次的做法解决了问题,在文件传输的过程中我没有再接收到任何错误信息。
我仍然不是很确信到底是什么导致了这個问题,因为这些文件在本地和远端状态上有明显的不壹致,但是我仍然很高兴解决了这個问题,我不需要再处理 SVN 了。
2014年01月01日最后更新:Justin
确认了 Apache SVN 配置使用了异步的复制方式,这解释了我前面遇到的第壹個问题。他同样提到,为了避免发生类似问题,我可以在使用 svn relocate 的时候明确的选择只使用 master 工作的方式。
英文原文出处:http://www.tomaz.me/2014/01/01/resolving-delta-source-ended-unexpectedly-svn-issue.html ,中文译文首发开源中国社区http://my.oschina.net/bairrfhoinn/blog/195733
,转载请注明原始出处。
分享到:
相关推荐
**SVN 客户端与 Web 客户端详解** SVN(Subversion)是一种广泛使用的版本控制系统,用于管理软件项目的源代码和其他文件的版本。它允许团队成员协作开发,跟踪文件更改,合并代码,并轻松回溯到任何历史版本。...
64位版本的SVN客户端是为了在64位操作系统上运行而设计的,可以更高效地利用系统资源,处理大型项目和大量文件。 在描述中提到的"包含中文包"意味着这个SVN客户端已经集成了中文语言支持,这对于中国用户或者需要...
svn客户端安装和使用svn客户端安装和使用svn客户端安装和使用svn客户端安装和使用svn客户端安装和使用svn客户端安装和使用svn客户端安装和使用svn客户端安装和使用svn客户端安装和使用svn客户端安装和使用svn客户端...
ubuntu下源码安装svn客户端,简单方便。
- **冲突解决**:当多个人修改同一部分代码时,客户端会提示冲突,用户需要手动解决。 - **日志查看**:查看文件或目录的历史变更记录,便于回溯和理解项目历史。 7. 配置SVN客户端: 用户可以根据需要配置...
Linux下的Subversion(SVN)客户端是用于版本控制系统的一个强大工具,它允许用户协同工作,跟踪文件和目录的更改历史。本指南将详细介绍如何在Linux系统上安装和配置SVN客户端,以帮助您更好地理解和使用这个强大的...
7. 冲突解决:在多个人修改同一部分代码时,SVN会检测到冲突并提示用户手动解决。 二、SVN客户端的使用场景 1. 软件开发:在开发大型软件项目时,SVN帮助团队成员协同工作,管理源代码,确保代码的一致性和质量。 ...
【SVN客户端】是版本控制系统Subversion(简称SVN)的一部分,主要负责用户与服务器之间的交互,便于开发者在团队协作中管理和同步代码。SVN客户端提供了直观的图形用户界面,使得用户无需深入理解命令行操作,也能...
**SVN客户端的使用方法详解** SVN(Subversion)是一种版本控制系统,用于管理多个用户对同一份文件或项目代码的协作编辑。使用SVN客户端可以帮助团队成员有效地协同工作,跟踪文件的历史版本,防止冲突,并实现...
通常,将SVN命令行工具添加到系统PATH环境变量是必要的,但SlikSVN设计得更为友好,解压后可以直接在命令提示符中运行svn命令,或者在IDE中集成使用。 “打卡idea集成开发软件”是指将SlikSVN配置到IntelliJ IDEA...
"svn客户端svn客户端svn客户端"的标题和描述反复提及,强调了其在协同开发中的核心地位。 TortoiseSVN是专为Windows设计的一个强大的SVN客户端,它无缝地集成到文件资源管理器中,使得版本控制操作直观易用。...
标题中的“myeclipse中svn版本与客户端版本出现冲突问题与解决方法”涉及到的是在使用MyEclipse集成开发环境(IDE)时,遇到Subversion(SVN)版本控制工具与客户端版本不兼容的问题。这个问题通常发生在升级或更换...
相较于早期的版本控制工具如RCS(Revision Control System)和CVS(Concurrent Versions System),SVN在分支管理和冲突解决方面具有显著优势,因此被众多开发者视为CVS的现代化替代品。 在Windows操作系统上,SVN...
对于初学者,了解 SVN 的命令行工具(如 `svn.exe`)以及图形化客户端(如 TortoiseSVN)的使用方法很重要。图形客户端通常提供更直观的界面,通过右键菜单可以直接访问大部分 SVN 功能。 在实际开发中,团队成员...
在本文中,我们将深入探讨SVN客户端的下载、安装和基本使用方法。 首先,SVN客户端是与SVN服务器交互的工具,它允许用户进行版本控制操作,如检出、提交、更新和合并代码。下载SVN客户端是开始使用SVN的第一步。在...
本篇将深入解析 SVN 客户端的基本使用方法,特别关注 TortoiseSVN,这是一个广泛使用的图形化 SVN 客户端。 1. **安装与配置** 在开始使用 SVN 客户端前,你需要确保已安装了客户端软件,例如 TortoiseSVN,并且已...
描述中的"非常实用"和"安装方便"突出了SVN客户端易用性和高效性的特点,这对于开发者来说非常重要,因为它们可以提高工作效率,减少错误并增强团队协作。 1. **SVN基本概念**: - **仓库(Repository)**:存储...
标题中的“mac版本的svn客户端”指的是在苹果Mac操作系统上使用的Subversion(SVN)客户端软件。Subversion是一个开源的版本控制系统,用于管理文件和目录的变更历史,它允许用户协同工作,跟踪文件的修改历史,并能...
在安装完成后,你可以像在Windows中一样,通过RabbitVCS在Linux系统中进行提交、更新、对比、解决冲突等SVN操作,极大地提高了在Linux环境下的工作效率。如果你遇到任何问题,不要犹豫,与其他开发者交流,共同学习...
svn服务端客户端安装包