(llamafactory用多张4090卡,训练qwen14B大模型时oom(out of memory)报错,torch.OutOfMemoryError:CUDA out of memory,Tried to allocate 136MB,GPU 5 has a total capacity of 23.64GB which 16.56MB is free,已解决)
1.问题描述
通过export CUDA_VISIBLE_DVICES=0,1,2,3,4,5,6,7指定使用8张显卡,训练qwen2.5-7B大模型时正常,但训练qwen2.5-14B,qwen2.5-32B模型时报错,torch.OutOfMemoryError:CUDA out of memory,Tried to allocate 136MB,GPU 5 has a total capacity of 23.64GB which 16.56MB is free 。
大概意思就是说GPU显存不足,很明显不符合实际,我的8张4090卡总显存是8*24GB,理论上14B的大模型肯定能跑起来。
linux服务器环境:
系统:Ubuntu22;
硬件:本机512G内存,8张4090显卡;
python:3.10版本;
llamafactory版本:0.9.1.dev0;
cuda版本:12.4版本;
pytorch版本:2.4.0+cuda121(GPU);
大模型:qwen2.5(7B,14B,32B,72B)Instruct版;
2.解决方案
- 减小大模型训练参数: 查一些帖子说是大模型训练参数太大,尝试减小数据量,减小步数,fp16位精度等,依旧不行,未解决,说明不是模型训练参数太大;
- 多余的内存分配给CPU: 从上面的oom报错原因我们可以看出,给GPU分配了136M内存,但实际GPU只剩16M了,导致oom报错,使用ZeRO-offload 技术通过一系列策略,将原本在GPU上处理的一部分数据和任务转移到CPU上,以此来降低GPU内存的占用,解决oom报错问题。
**具体解决方案:**在LLaMA-Factory目录下新建一个run_train_bash.sh新件,具体目录如下图:
在run_train_bash.sh文件中,设置参数如下:
model_name_or_path和output_dir 改成你自己的本地大模型和输出路径就行;
src/train.py 取决于你src目录下的训练启动文件名,这个是llamafactory自带的;
CUDA_VISIBLE_DEVICES:看你有几张卡,需要用几张卡,我的是8张卡;
其它都是训练参数,根据实际需要修改。最重要的是deepspeed ds_config_zero3.json这行,
这个是qwen官网给的。deepspeed 库可以用pip install deepspeed 安装一下。
run_train_bash.sh文件中内容:
CUDA_VISIBLE_DEVICES=0,1,2,3,4,5,6,7 accelerate launch src/train.py \
--deepspeed ds_config_zero3.json \
--stage sft \
--do_train True \
--model_name_or_path /home/admin1/Qwen2.5