svn异常锁死处理方法

背景

在svn使用过程中,有时候会出现默认奇妙锁死的情况。有时候可能在svn执行过程中强制退出等导致。此时,如果输入svn st,查询状态,出现下面场景。

第一步

不考虑人为进行lock情况,这种其实是正常的上锁。

  • 清理本地状态:

    尝试运行 cleanup 命令来修复本地的工作副本状态:

    复制代码
    svn cleanup

    注:TortoiseSVN 用户可以在文件夹上右键 -> TortoiseSVN -> Clean up。

  • 重新更新:

    清理后,尝试更新一下代码,同步服务器状态:

    复制代码
    svn update

如果执行第一步没有恢复正常,并且还是lock状态,比如出现下面的打印。

svn: E200033: database is locked, executing statement 'RELEASE s0'

那么直接进行下面的操作。

第二步

确认是否下SVN占用导致,一般情况下,在svn操作过程中异常退出,大概率SVN进程没有退出。执行 ps 的目的通常是检查是否有残留的 SVN 进程在占用数据库

复制代码
# 查找进程
ps -ef | grep svn

# 杀掉进程 (将 <PID> 替换为实际的进程 ID)
kill -9 <PID>

# 如果是 IDE 卡住,可能需要关闭 IDE 进程
kill -9 <IDE_Process_ID>

#检查svn状态
svn status
  • 后续 :进程杀掉后,再次执行 svn cleanup 通常就能成功了。

如果还是异常不能恢复,或者没有SVN进程残留,那么继续往下排查和操作。

第三步

SVN 的本地状态信息存储在项目根目录下 .svn 隐藏文件夹中的 wc.db 数据库里。我们需要手动清理里面的锁表。如果你不想安装可视化工具,可以通过命令行来备份数据库并重建,以消除锁状态。

步骤:

  1. 进入项目的 .svn 目录

    复制代码
    cd /your/project/path/.svn
  2. 备份原数据库

    复制代码
    mv wc.db wc.db.old
  3. 导出并重建数据库 (此操作会去除损坏的锁状态):

    复制代码
    sqlite3 wc.db.old

    进入 sqlite3 交互模式后,依次输入以下命令:

    复制代码
    .backup main wc.db
    .exit

    (注:如果提示找不到 .backup 命令,说明你的 sqlite3 版本过旧,请使用方法一。)

  4. 重新 Cleanup

    复制代码
    cd /your/project/path
    svn cleanup
相关推荐
2601_961875247 天前
花生十三公考课程|网课|视频
数据库·windows·git·svn·eclipse·github
2601_961875247 天前
花生十三资料网盘|百度云|下载
数据库·windows·git·svn·eclipse·github
WSKH092914 天前
【操作记录】Mac 系统安装并使用 SVN
macos·svn
不想努力只想躺平的菜鸟ing14 天前
svn使用指南
svn
佛山个人技术开发14 天前
GitCode个人技术开发者总结完整使用指南
windows·git·svn·github·gitcode
深度学习040716 天前
SVN 独立服务端部署与客户端使用指南(CentOS/Rocky 9.5 + Windows)
windows·svn
hrw_embedded18 天前
svn架构下研发与产线异地办公程序共享问题?
svn·内网穿透http·研发与产线
snowjlz25 天前
鸿蒙版SVN来了!!!
git·svn·版本控制
2401_8769641325 天前
27考研余炳森概率论|喻老李良2027资料网课
windows·git·考研·svn·eclipse·github·概率论
Do_GH1 个月前
【Linux】09.WSL+SVN部署操作说明
linux·运维·svn