news 2026/4/23 13:56:50

wandb报错并且AttributeError: ‘_thread.RLock‘ object has no attribute ‘_recursion_count‘

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
wandb报错并且AttributeError: ‘_thread.RLock‘ object has no attribute ‘_recursion_count‘

WandB 退出错误说明

错误信息

Exception ignored in atexit callback: <function _start_and_connect_service.<locals>.teardown_atexit> BrokenPipeError: [Errno 32] Broken pipe Exception ignored in: <function ResourceTracker.__del__ at 0x...> AttributeError: '_thread.RLock' object has no attribute '_recursion_count'

错误性质

这些是非关键错误(Non-critical errors),发生在程序正常退出时的清理过程中。

为什么会出现?

  1. 程序正常完成:训练已经成功完成,wandb 已经同步了所有数据
  2. 清理阶段问题:在程序退出时,wandb 和 multiprocess 尝试清理资源
  3. 异步操作冲突:退出时某些异步操作(如网络连接关闭)可能已经中断

错误分析

1. WandB BrokenPipeError

BrokenPipeError: [Errno 32] Broken pipe

原因

  • WandB 在程序退出时尝试关闭连接
  • 但连接可能已经被系统或其他进程关闭
  • 这是清理阶段的竞态条件

影响

  • 不影响训练结果
  • 不影响 checkpoint 保存
  • WandB 数据已经同步(从日志可以看到 “Synced 5 W&B file(s)”)

2. ResourceTracker AttributeError

AttributeError: '_thread.RLock' object has no attribute '_recursion_count'

原因

  • Python multiprocess 的资源跟踪器在清理时的问题
  • 可能是 Python 版本兼容性问题
  • 发生在__del__析构函数中

影响

  • 不影响训练结果
  • 不影响数据保存
  • ⚠️ 可能有一些资源没有完全清理(但会被系统回收)

验证训练是否成功

检查 checkpoint

# 查看最新的 checkpointls-lh /root/autodl-tmp/verl/checkpoints/verl_example_gsm8k/deepseek_llm_7b_function_rm/# 查看 checkpoint 内容cat/root/autodl-tmp/verl/checkpoints/verl_example_gsm8k/deepseek_llm_7b_function_rm/latest_checkpointed_iteration.txt

检查 WandB 记录

从日志可以看到:

  • ✅ WandB 已经同步:Synced 5 W&B file(s)
  • ✅ 可以查看运行记录:https://wandb.ai/xxx/verl_example_gsm8k/runs/ny8yfg5m

检查训练指标

从日志可以看到训练指标已经记录:

  • actor/pg_loss: 0.00065
  • actor/ppo_kl: 0.00011
  • critic/advantages/mean: 0.0
  • 等等

解决方案

方案 1: 忽略错误(推荐)

这些错误不影响训练结果,可以安全忽略。训练已经成功完成。

方案 2: 抑制 WandB 退出错误

如果不想看到这些错误信息,可以在脚本中添加:

# 在脚本开头添加exportWANDB_SILENT=true# 或exportPYTHONWARNINGS="ignore::UserWarning"

方案 3: 更新依赖

如果问题持续,可以尝试更新相关包:

pipinstall--upgrade wandb multiprocess

方案 4: 使用环境变量抑制

# 抑制 atexit 错误exportPYTHONUNBUFFERED=1# 或者在 Python 代码中importwarnings warnings.filterwarnings('ignore')

总结

  • 训练成功完成:所有数据已保存
  • WandB 同步成功:数据已上传
  • Checkpoint 已保存:可以继续训练或使用
  • ⚠️退出错误:不影响结果,可以忽略

建议

  1. 检查训练结果:确认 checkpoint 和 WandB 记录正常
  2. 继续使用:这些错误不影响后续使用
  3. 如果担心:可以查看 WandB 网页确认所有数据都已记录

相关链接

  • WandB 运行记录:https://wandb.ai/xxx/verl_example_gsm8k/runs/ny8yfg5m
  • 项目页面:https://wandb.ai/xxx/verl_example_gsm8k
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/23 10:09:54

低代码平台的扩展能力:活字格服务端编程实战

低代码平台的扩展能力&#xff1a;活字格服务端编程实战 引言 在当今数字化转型浪潮中&#xff0c;低代码平台因其快速开发和易用性而备受青睐。然而&#xff0c;企业级应用往往需要处理复杂的业务逻辑和特殊需求&#xff0c;这些需求可能超出标准低代码功能的范畴。活字格低…

作者头像 李华
网站建设 2026/4/23 6:42:05

Strix AI安全测试工具:新手快速上手终极指南

Strix AI安全测试工具&#xff1a;新手快速上手终极指南 【免费下载链接】strix ✨ Open-source AI hackers for your apps &#x1f468;&#x1f3fb;‍&#x1f4bb; 项目地址: https://gitcode.com/GitHub_Trending/strix/strix Strix作为开源的AI驱动安全测试工具&…

作者头像 李华
网站建设 2026/4/23 11:24:40

轻松掌握GoldenDict-ng:跨平台词典查询工具完全指南

轻松掌握GoldenDict-ng&#xff1a;跨平台词典查询工具完全指南 【免费下载链接】goldendict-ng The Next Generation GoldenDict 项目地址: https://gitcode.com/gh_mirrors/go/goldendict-ng 在信息爆炸的时代&#xff0c;拥有一款强大的词典查询工具至关重要。Golden…

作者头像 李华
网站建设 2026/4/23 12:47:32

C语言链表的相关操作

本文实现了一个学生信息管理的单向链表系统。头文件定义了链表结构体(包含学号、姓名、成绩)和基本操作接口。源文件实现了创建/销毁链表、插入/删除/查找节点、判断空链表、获取链表长度等功能&#xff0c;并提供了两种格式的打印函数。测试程序演示了创建链表、添加3个学生节…

作者头像 李华
网站建设 2026/4/23 14:31:08

无人机遥控器技术要点与算力解析

无人机遥控器的“图&#xff08;高清视频&#xff09;、数&#xff08;遥测数据&#xff09;、控&#xff08;控制指令&#xff09;一体”技术&#xff0c;其核心在于将原本分离的视频传输、数据传输和飞行控制功能深度融合与协同处理。其技术要点、算力需求和运行方式与传统遥…

作者头像 李华
网站建设 2026/4/23 14:13:23

用Guava写出优雅代码!

最近在看一个同学代码的时候&#xff0c;发现代码中大量使用了 Google 开源的 Guava 核心库中的内容&#xff0c;让代码简单清晰了不少&#xff0c;故学习分享出 Guava 中我认为最实用的功能。Guava 项目是 Google 公司开源的 Java 核心库&#xff0c;它主要是包含一些在 Java …

作者头像 李华