项目故障排查指南
本文件提供了在使用本项目时可能遇到的常见问题及其解决方案. 如果您在这里找不到解决方案, 请查阅相关文档或提交一个问题.
常见问题
-
问题:
make init或make sync失败, 或遇到依赖冲突.- 解决方案:
- 确保您的 Python 版本符合
pyproject.toml中requires-python的要求(当前为 3.13+). - 尝试清理
uv缓存:uv clean. - 检查
pyproject.toml和uv.lock文件, 手动解决潜在的依赖冲突. - 确保您的网络连接正常, 可以访问 PyPI.
-
问题:
make命令无法执行, 提示“command not found”.- 解决方案: 确保您的系统安装了
make工具.- Linux/macOS: 通常预装.
- Windows: 可以通过 Chocolatey (
choco install make) 或 Scoop (scoop install make) 安装, 或者安装 Git for Windows (它通常包含make).
- 解决方案: 确保您的系统安装了
-
问题: 训练时遇到
torch.cuda.is_available()返回False, 即使有 GPU.- 解决方案:
- 确保您安装了正确版本的 PyTorch, 并且它与您的 CUDA 驱动版本兼容.
- 检查您的 CUDA 驱动是否已正确安装并更新到最新版本.
- 确认您的 GPU 设备已正确识别并启用.
- 如果使用 Docker, 确保容器以
--gpus all或类似方式运行.
-
问题: 训练过程中出现内存不足 (OOM) 错误.
- 解决方案:
- 减小
batch_size: 这是最直接有效的方法. - 减小模型大小: 尝试减小
hidden_size或num_layers. - 启用自动混合精度 (AMP): 在
config.py中设置optimization.use_amp = True, 或在命令行中不使用--no-amp. AMP 可以显著减少显存占用. - 启用
torch.compile: 在config.py中设置optimization.use_compile = True, 或在命令行中不使用--no-compile. 虽然主要用于加速, 但有时也能帮助优化内存. - 梯度累积: 如果您的任务支持, 可以通过增大
gradient_accumulation_steps来模拟更大的批次大小, 同时保持较小的实际batch_size.
-
问题: 分词器抛出
KeyError, 提示字符不在词汇表中.- 解决方案: 当前的
SimpleCharacterTokenizer是字符级别的, 并且词汇表是根据初始化时提供的语料库构建的. 确保您尝试编码的文本只包含在初始化分词器时语料库中存在的字符. 如果需要处理更广泛的字符集, 您可能需要更新分词器或其初始化语料.
- 解决方案: 当前的
LoRA / QLoRA 相关问题
-
问题: 应用 LoRA 后模型输出与原始模型完全相同.
- 解决方案: LoRA 的 B 矩阵初始化为零, 因此初始输出应该相同. 确保:
- 您已正确调用
apply_lora(model, ...). - 训练时只优化 LoRA 参数:
optimizer = AdamW(get_lora_parameters(model), lr=1e-4). - 确认 LoRA 参数的
requires_grad=True.
-
问题: QLoRA 推理速度比预期慢.
- 解决方案: QLoRA 在每次 forward 时需要反量化权重, 这会增加开销:
- 对于推理, 考虑使用标准 LoRA 并在训练后
merge_lora(model). - QLoRA 主要优势是训练时的内存节省, 而非推理速度.
KVCache 相关问题
-
问题: 使用 KVCache 时生成的文本与不使用时不同.
- 解决方案: 确保:
- 在新序列开始前调用
cache.reset()重置缓存. max_seq_len足够大以容纳完整生成.- 首次 forward 传入完整 prompt, 后续 forward 只传入新生成的 token.
-
问题: KVCache 超出预分配长度导致错误.
- 解决方案: 增大
max_seq_len或在生成循环中检查cache.seq_len < cache.max_seq_len.
- 解决方案: 增大
提交问题
如果您在这里找不到解决方案, 请在我们的 GitHub 仓库上提交一个问题: GitHub Issues. 请提供详细的错误信息、复现步骤和您的环境配置.