DeepSeek-V3/R1 满血版 671B 全参数微调的开源解决方案,包含从训练到推理的完整代码和脚本,以及实践中积累一些经验和结论,由中国科学院自动化研究所和中科闻歌联合推出。

🌟 项目亮点

  • 实现了包含 DeepSeek-V3/R1 训练逻辑的 modeling 文件(详见 ./model,根据 Deepseek-V3 论文并结合 Deepseek-V2 的 modeling 文件进行代码逻辑补全);
  • 实现了基于数据并行(DeepSpeed ZeRO)+ 序列并行(SP)的 DeepSeek-V3/R1 671B 满血版全参数微调;
  • 总结了模型训练和部署全流程踩坑经验、遇到的问题及解决方案。

🚀 快速开始

1. 硬件配置

单台服务器配置如下表,集群中共 32 台相同配置的机器,共享 100TB 存储空间,挂载路径为 /nfs。机器操作系统为 Ubuntu 22.04,机器之间使用 IB 网络进行通信,GPU 之间通过 NVLink 通信,CUDA 版本为 12.6。

组件 规格/版本 查看详细配置命令
GPU 8 x NVIDIA H100 80GB HBM3 nvidia-smi
CPU Intel® Xeon® Platinum 8463B (96 Cores) lscpu
内存 2.0TB DDR4 free -h
存储 100TB NVMe SSD df -h
网络 InfiniBand 400G ibstat
操作系统 Ubuntu 22.04 uname -a
CUDA CUDA 12.6 nvcc -V

2. 环境配置

我们基于 xtuner 框架进行扩展和改进,使其支持 Deepseek V3/R1(即 DeepseekV3ForCausalLM 模型架构)的全参数微调,支持数据并行(DeepSpeed ZeRO based DP)和序列并行(Sequence Parallel, SP)。

安装 Python 环境,可根据项目中 requirements.txt 安装依赖包,并将 ./code/xtunerDeepseekV3ForCausalLM 训练相关的核心代码覆盖原始 xtuner package 的对应代码即可。

conda create -n ds_env python=3.10
conda activate ds_env
pip install -r requirements.txt

# 覆盖核心代码 这里修改为你的环境路径
YOUR_ENV_PATH='/nfs/miniconda3/envs/ds_env/lib/python3.10/site-packages'
cp -r ./code/xtuner $YOUR_ENV_PATH

3. 数据准备

我们基于 OpenAI 标准数据格式进行扩展以兼容 reasoning 数据,每条原始训练数据格式如下。如果有思考过程,则 assistant 角色的 reasoning_content 字段非空。

{ 
 "messages": [    
 {"role": "system", "content": "You are a helpful assistant."},    
 {"role": "user", "content": "用户问题"},   
 {"role": "assistant", "content": "最终回答", "reasoning_content": "思考过程"} 
  ]
 }

为了简化处理逻辑,我们将 reasoning_contentcontent 按照 Deepseek 的训练格式合并到 content 字段中。此外,为了兼容多轮对话的训练逻辑,还为 assistant 角色的每轮添加了 loss 字段,仅对值为 truecontent 内容计算 loss。

{ 
 "messages": [  
   {"role": "system", "content": "You are a helpful assistant."},    
   {"role": "user", "content": "用户问题"},    
   {"role": "assistant", "content": "<think>\n思考过程\n</think>\n\n最终回答", "loss": true}  
   ]
  }

为了更清晰地展示数据存储格式,我们提供了一份转换后的数据样例文件 ./data/train_example.json 以供参考。

在实际训练时,程序会根据 Deepseek V3/R1 的训练模版自动转换为如下格式,这里仅供展示:

<|begin▁of▁sentence|>You are a helpful assistant.<|User|>用户问题<|Assistant|><think>\n思考过程\n</think>\n\n最终回答<|end▁of▁sentence|>

4. 启动训练

我们提供了训练代码和训练启动脚本,其中:

  • ./code/scripts/sft_deepseek.py:sft训练所需的配置文件,包括超参数设置、model和tokenizer配置、训练策略等,模型训练相关的配置均在此文件修改。
  • ./code/scripts/sft_deepseek.sh:sft训练启动脚本,该脚本为单个节点的执行文件,因此需要通过 slurm 或 pdsh 在每台机器执行。对于每台机器,训练启动命令的唯一不同为 NODE_RANK 值,如果共 32 台机器,则该编号分别从 0 到 31。

以 pdsh 为例,启动训练需要以下步骤:

  1. 将本项目 ./model 中提供的包含训练所需代码逻辑的 modeling_deepseek.py 文件覆盖从 huggingface 等托管平台下载的对应原始文件;
  2. 使用 pdsh 启动训练,在 0 号机器执行命令 pdsh -R ssh -w node[0-31] 'bash ./code/scripts/sft_deepseek.sh',即可启动 32 台机器的模型全参数微调任务。其中,node[0-31] 需根据你的机器 hostname 或 IP 地址进行修改。训练过程中,可通过 tensorboard 对训练过程(loss变化等)进行可视化。

以下是我们做的几组实验的结论,包括在不同并行策略等配置下模型训练的可行性。训练数据 ~100k,训练上下文长度为 32k。表中报告了每次实验使用的机器数量(nodes)、序列并行度(sp)、数据并行方式(dp)、单卡 batch size(bs)、迭代轮次(epoch)、学习率(lr)、单卡显存(mem)、实验记录和备注(notes)。

nodes sp dp bs epoch lr mem notes
16 8 zero3_offload 2 1 2e-7 ~30GB ✅ 可训练
32 8 zero3_offload 1 1 1e-5 ~32GB ✅ 可训练
32 4 zero3_offload 1 1 2e-7 ~25GB ✅ 可训练
32 1 zero3_offload 1 1 2e-7 ~30GB ✅ 可训练
32 4 zero3_offload 2 1 2e-7 ~74GB ✅ 可训练(推荐)
32 1 zero3_offload 2 1 2e-7 OOM ❌ 显存溢出
32 4 zero3 1 1 2e-7 OOM ❌ 显存溢出
32 1 zero3 1 1 2e-7 OOM ❌ 显存溢出

以下是训练过程中的一个截图,我们观察到,从 DeepSeek V3 对我们构建的 reasoning 数据进行全参数微调时,起始 loss 通常在 3.5 左右,经过 1 epoch 训练后,loss 收敛到 1.2 左右。

img

训练日志

5. 模型权重转换

训练过程中建议使用至少 100TB 的 SSD 大容量存储,因为单个 pth 中间结果大约占 7.4TB 硬盘空间。训练完成后,我们需要将 pth 转换为主流推理框架(如vllm等)较好兼容的 huggingface 格式。在单台机器节点执行 bash ./code/scripts/convert_pth_to_hf.sh 即可完成模型权重格式转换,可根据实际情况修改脚本中的 pth 路径和权重保存路径。

需要注意的是,由于本过程对 CPU 内存有较大需求,因此可以通过虚拟内存进行扩展,防止 Out-of-memory。Swap(交换分区) 是 Linux 的虚拟内存,作用是当物理内存(RAM)不够用时,把部分数据存入磁盘,释放 RAM。

sudo fallocate -l 8192G /tmp/swapfile  # 创建 8T 交换文件
sudo chmod 600 /tmp/swapfile
sudo mkswap /tmp/swapfile
sudo swapon /tmp/swapfile
free -h  # 检查 swap 是否增加

6. 模型推理部署

根据 Deepseek V3 Github 的介绍,可以使用多种方式进行模型本地化部署。我们使用 vLLM 对全参数微调后的模型进行简单部署测试。这里假设已经根据 vLLM 官网文档的指引创建了名为 vllm 的环境。

如果使用 slurm 集群,可参考我们提供的脚本并执行 sbatch 命令 sbatch ./code/scripts/vllm_deploy_slurm.sh 即可提交作业。半精度(bf16/fp16)模型建议使用4台机器32卡进行部署,如需配置 ray 或 api server 的端口号,可自行修改 sh 文件。

如果需要通过 pdsh 启动部署(假设使用 node0~node3 四台机器),可参考以下步骤:

  1. 设置环境变量(node0~node3)。
export HEAD_ADDR="node0"
export DASHBOARD_PORT=8265
export HEAD_PORT=6379
export RAY_TMPDIR=/tmp/ray_tmp/
export RAY_ADDRESS=$HEAD_ADDR:$HEAD_PORT
  1. 启动 Ray Head(node0)。
pdsh -R ssh -w node0 "source /nfs/miniconda3/etc/profile.d/conda.sh && conda activate vllm && \
ray start --block --head --port=$HEAD_PORT --dashboard-port=$DASHBOARD_PORT --temp-dir=$RAY_TMPDIR"
  1. 启动 Ray Worker(node1~node3)。
pdsh -R ssh -w node1,node2,node3 "source /nfs/miniconda3/etc/profile.d/conda.sh && conda activate vllm && \
ray start --block --address=$HEAD_ADDR:$HEAD_PORT"
  1. 启动 vLLM(node0)。
pdsh -R ssh -w node0 "source /nfs/miniconda3/etc/profile.d/conda.sh && conda activate vllm && \
vllm serve /path/of/your/deepseek_sft_ckpt \
    --tensor-parallel-size 8 \    
    --pipeline-parallel-size 4 \   
    --served-model-name deepseek-r1-sft \    
    --max-model-len 32768 \    
    --trust-remote-code \    
    --enable-reasoning \    
    --reasoning-parser deepseek_r1"

启动完成后,可通过 curl 命令测试接口是否正常启动:

curl -X POST http://node0:8000/v1/chat/completions -d '{"model": "deepseek-r1-sft", "messages":[{"role":"user", "content": "hello"}]}' -H "Content-Type: application/json"

我的DeepSeek部署资料已打包好(自取↓)
https://pan.quark.cn/s/7e0fa45596e4

但如果你想知道这个工具为什么能“听懂人话”、写出代码 甚至预测市场趋势——答案就藏在大模型技术里!

❗️为什么你必须了解大模型?

1️⃣ 薪资爆炸:应届大模型工程师年薪40万起步,懂“Prompt调教”的带货主播收入翻3倍

2️⃣ 行业重构:金融、医疗、教育正在被AI重塑,不用大模型的公司3年内必淘汰

3️⃣ 零门槛上车:90%的进阶技巧不需写代码!会说话就能指挥AI

(附深度求索BOSS招聘信息)
在这里插入图片描述

⚠️警惕:当同事用DeepSeek 3小时干完你3天的工作时,淘汰倒计时就开始了。

那么,如何系统的去学习大模型LLM?

作为一名从业五年的资深大模型算法工程师,我经常会收到一些评论和私信,我是小白,学习大模型该从哪里入手呢?老师啊,我自学没有方向怎么办?老师,这个地方我不会啊。如果你也有类似的经历,一定要继续看下去!当然这些问题啊,也不是三言两语啊就能讲明白的。

所以我综合了大模型的所有知识点,给大家带来一套全网最全最细的大模型零基础教程。在做这套教程之前呢,我就曾放空大脑,以一个大模型小白的角度去重新解析它,采用基础知识和实战项目相结合的教学方式,历时3个月,终于完成了这样的课程,让你真正体会到什么是每一秒都在疯狂输出知识点。

篇幅有限,⚡️ 朋友们如果有需要全套 《2025全新制作的大模型全套资料》,扫码获取~
在这里插入图片描述

👉大模型学习指南+路线汇总👈

我们这套资料呢,会从基础篇、进阶篇和项目实战篇等三大方面来讲解。
在这里插入图片描述
在这里插入图片描述

👉①.基础篇👈

基础篇里面包括了Python快速入门、AI开发环境搭建及提示词工程,带你学习大模型核心原理、prompt使用技巧、Transformer架构和预训练、SFT、RLHF等一些基础概念,用最易懂的方式带你入门大模型。
在这里插入图片描述

👉②.进阶篇👈

接下来是进阶篇,你将掌握RAG、Agent、Langchain、大模型微调和私有化部署,学习如何构建外挂知识库并和自己的企业相结合,学习如何使用langchain框架提高开发效率和代码质量、学习如何选择合适的基座模型并进行数据集的收集预处理以及具体的模型微调等等。
在这里插入图片描述

👉③.实战篇👈

实战篇会手把手带着大家练习企业级的落地项目(已脱敏),比如RAG医疗问答系统、Agent智能电商客服系统、数字人项目实战、教育行业智能助教等等,从而帮助大家更好的应对大模型时代的挑战。
在这里插入图片描述

👉④.福利篇👈

最后呢,会给大家一个小福利,课程视频中的所有素材,有搭建AI开发环境资料包,还有学习计划表,几十上百G素材、电子书和课件等等,只要你能想到的素材,我这里几乎都有。我已经全部上传到CSDN,朋友们如果需要可以微信扫描下方CSDN官方认证二维码免费领取【保证100%免费
在这里插入图片描述
相信我,这套大模型系统教程将会是全网最齐全 最易懂的小白专用课!!
在这里插入图片描述

Logo

欢迎加入DeepSeek 技术社区。在这里,你可以找到志同道合的朋友,共同探索AI技术的奥秘。

更多推荐