Skip to main content

skyrl-train

Project description

SkyRL-Train: A modular, performant RL framework for post-training LLMs

🌐 NovaSky Github Twitter Hugging Face Collection Discord Documentation

Overview

With a focus on modularity, skyrl-train makes it easy to prototype new training algorithms, environments, and execution plans—without compromising usability or speed.

skyrl-train is for users who want to modify anything:

  • Quickly develop new environments without modifying or understanding the training code.
  • Modify the training execution plan such as model placement, colocation or disaggregation of training and generation, and async RL.
  • Implement custom trajectory generation specific to your use-case, such as custom sampling methods, tree search, etc.
  • … make any other flexible modifications to the RL workflow!

Key Features

The skyrl-train package supports:

  • PPO and GRPO
  • Training Backends: FSDP, FSDP2, Megatron, and DeepSpeed
  • Inference backends: vLLM, SGLang, and any custom OpenAI API compatible endpoint that exposes a method to perform weight sync
  • Ulysses sequence parallelism for long-context training
  • Colocated or disaggregated training and generation (including on heterogeneous hardware)
  • Synchronous RL or async one-off pipelining
  • Simple batched rollouts or Asynchronous rollouts for multi-turn conversations
  • Weight sync via NCCL, gloo, or checkpoint-and-load
  • Integration with skyrl-gym to run any environment in the gymnasium
  • Sequence packing and Flash Attention 2

Documentation

Find skyrl-train documentation at: skyrl.readthedocs.io/en/latest/

Quick Start

A quick start guide for installation and your first training run is provided below.

Requirements

The only requirements are:

  • CUDA version 12.8
  • uv

If you're running on an existing Ray cluster, make sure to use Ray 2.51.1 and Python 3.12. If not, proceed with the installation instructions below.

First, clone the repository:

git clone --recurse-submodules https://github.com/NovaSky-AI/SkyRL
cd SkyRL/skyrl-train

Then, create a new virtual environment and install the dependencies:

# creates a venv at .venv/
uv sync --extra vllm 
source .venv/bin/activate

Then, prepare the dataset:

uv run -- python examples/gsm8k/gsm8k_dataset.py

Finally, before training, make sure to configure Ray to use uv:

export RAY_RUNTIME_ENV_HOOK=ray._private.runtime_env.uv_runtime_env_hook.hook
# or add to your .bashrc
# echo 'export RAY_RUNTIME_ENV_HOOK=ray._private.runtime_env.uv_runtime_env_hook.hook' >> ~/.bashrc

You should now be able to run our example script (assumes at least 4 GPUs):

export WANDB_API_KEY=<your wandb api key>
bash examples/gsm8k/run_gsm8k.sh

For detailed installation instructions, as well as more examples, please refer to our documentation.

Training on a new task or environment

To implement a new task or environment using the SkyRL-Gym interface, please see our Walkthrough Docs.

If you don't want to use the SkyRL-Gym interface, or you have an existing task or agentic pipeline implementation and just want to train with it on top of SkyRL, we recommend you create a simple custom Generator, which requires implementing a single method, generate(). We have one example of a custom Generator at SkyRLGymGenerator which executes environments written in the SkyRL-Gym interface. We are working to provide more example integrations of agent harnesses -- please reach out if you'd like yours to be one of them!

Reproducing SkyRL-SQL

We also test SkyRL by reproducing our prior release SkyRL-SQL, which enabled efficient Multi-Turn RL for Text2SQL. You can find a link to the wandb report here, and a detailed walk through of the reproduction in our documentation.

Acknowledgement

This work is done at Berkeley Sky Computing Lab in collaboration with Anyscale, with generous compute support from Anyscale, Databricks, NVIDIA, Lambda Labs, and AMD.

We adopt many lessons and code from several great projects such as veRL, OpenRLHF, Search-R1, OpenReasonerZero, and NeMo-RL. We appreciate each of these teams and their contributions to open-source research!

Citation

If you find the work in skyrl-train helpful, please consider citing:

@misc{griggs2025skrylv01,
      title={Evolving SkyRL into a Highly-Modular RL Framework},
      author={Tyler Griggs and Sumanth Hegde and Eric Tang and Shu Liu and Shiyi Cao and Dacheng Li and Charlie Ruan and Philipp Moritz and Kourosh Hakhamaneshi and Richard Liaw and Akshay Malik and Matei Zaharia and Joseph E. Gonzalez and Ion Stoica},
      year={2025},
      note={Notion Blog}
}

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

skyrl_train-0.3.1.tar.gz (226.4 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

skyrl_train-0.3.1-py3-none-any.whl (260.8 kB view details)

Uploaded Python 3

File details

Details for the file skyrl_train-0.3.1.tar.gz.

File metadata

  • Download URL: skyrl_train-0.3.1.tar.gz
  • Upload date:
  • Size: 226.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.9.2

File hashes

Hashes for skyrl_train-0.3.1.tar.gz
Algorithm Hash digest
SHA256 93361e3c246600486e94900f9f0d0c9ef8fc98efba2e6074c2c5e2c476cfb7ba
MD5 397f21826c8e96b08facf2a3d5a9b14a
BLAKE2b-256 42448a3b687122df7fc0036efde6d9bd4c53c9ce7c315cb4ebb524e45eab600c

See more details on using hashes here.

File details

Details for the file skyrl_train-0.3.1-py3-none-any.whl.

File metadata

File hashes

Hashes for skyrl_train-0.3.1-py3-none-any.whl
Algorithm Hash digest
SHA256 981cd57d3e1affaa0e9abc3402d35cd76d8fff566e8ac04eb66d3a5f104c2a63
MD5 6adc46d7c4594065181a5ccfc3ff948f
BLAKE2b-256 362060f75d0c9a55386a7efabf3b32e5bddfcd44e587334e4cdd2002c8d534cc

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page