主要观点总结
本文详细分析了OpenRLHF中PPO-Ray训练架构设计的优势和特点,包括为什么使用Ray、整体流程、Ray核心知识、代码细节等。Ray作为一个分布式计算框架,可以帮助解决传统rlhf框架在训练时遇到的问题,如突破单卡显存限制、实现更多并行计算、独立优化训练和推理过程等。文章通过详细阐述,展示了如何使用Ray进行定制化部署,并介绍了Ray的核心概念、任务、Actor以及集群架构。此外,文章还提供了代码细节,包括训练入口、部署模型实例、部署vllm_engines实例、ds_rank0与vllm_ranks之间的通讯以及PPO-Actor/Critic的训练流程。
关键观点总结
关键观点1: 为什么使用Ray
为了解决传统rlhf框架在训练时存在的问题,如突破单卡显存限制、实现更多并行计算、独立优化训练和推理过程等,文章介绍了使用Ray作为分布式计算框架的优势。
关键观点2: 整体流程
文章详细阐述了使用Ray进行定制化部署的整体流程,包括非共同部署和共同部署的例子,并介绍了Ray的核心概念、任务、Actor以及集群架构。
关键观点3: 代码细节
文章提供了代码细节,包括训练入口、部署模型实例、部署vllm_engines实例、ds_rank0与vllm_ranks之间的通讯以及PPO-Actor/Critic的训练流程,帮助读者更好地理解PPO-Ray训练架构的设计和实现。
文章预览
本文着重分析OpenRLHF中的 PPO-Ray训练架构设计 ,没有使用过Ray的朋友也可以通过本文快速上手,本文共分成四块: 1. 为什么用Ray 2. 使用图例抽象出整体训练流程 3. Ray核心知识速过 4. 使用图例,进一步抽象出核心代码细节,包括: 训练入口 部署PPO-Actor/Ref/Critic/RM实例 部署vllm_engines实例 PPO-Actor与vllm_engines之间的通讯 PPO-Actor/Critic训练 一、为什么要使用Ray 对于通常的rlhf框架, 在训练时会在单卡上同时部署actor/ref/reward/critic四类模型 ,这种单一的部署方式可能存在如下问题: 难以突破单卡显存的限制。 无法实现更多的并行计算 。例如在收集exp阶段,拿到(prompt, responses)结果的四类模型其实可以做并行推理;在训练阶段,拿到exp的actor和critic也可以做并行训练。但受到单卡显存等因素影响,通常的rlhf框架中使用更多的是串行。 无法独立优化训练和推
………………………………