[rollout, perf, cfg] fix: Add global step info and support more profile control params for rollout profiling (sglang backend)#5025
Conversation
…le control params for rollout profiling (sglang backend)
There was a problem hiding this comment.
Code Review
This pull request introduces global step awareness for rollout profiling and expands support for sglang-specific profile control parameters. The changes correctly integrate global_step into the profiling process and add new configuration options for TorchProfilerToolConfig. However, there are a couple of high-severity issues related to the profiling logic in async_sglang_server.py that need to be addressed to ensure correct and predictable behavior.
|
The 'Repo id error' in NPU unit tests appears to be unrelated to this PR, could you please verify? |
Local Test Status Summary
Can you check this for me? Thanks! |
|
The test case The failure of these two test cases is likely due to the impact of other CI jobs. A potential solution would be to increase the container shared memory (shm-size) for both test cases. |
### What does this PR do? **Description** This PR addresses issues with profiler configuration for inference engines (vLLM and SGLang) and refactors the profiler code for better cohesion and maintainability. **Key Changes:** - vLLM Profiler Configuration Fix: Implemented automatic setup of profiler-related environment variables for vLLM engine before process launch. Users no longer need to manually set vLLM environment variables. Added support for configuring the profiler via profiler_config for newer vLLM versions, ensuring compatibility. - SGLang Profiler Bug Fix: Fixed a bug introduced in [@pr 5025](#5025) regarding SGLang profiler data collection. Corrected the argument construction logic to ensure accurate profiling parameters are passed to the SGLang backend. - Code Refactoring & Cohesion: Centralized profiler logic by introducing adapter functions (build_vllm_profiler_args, build_sglang_profiler_args) within the profiler component. These adapters encapsulate the logic for constructing engine-specific profiler arguments, improving code organization and readability. - Testing: Added comprehensive unit tests to verify the correctness of the new adapter functions and ensure regression testing for the fixed bugs. ### Checklist Before Starting - [x] Search for similar PRs. Paste at least one query link here: ... - [x] Format the PR title as `[{modules}] {type}: {description}` (This will be checked by the CI) - `{modules}` include `fsdp`, `megatron`, `veomni`, `sglang`, `vllm`, `rollout`, `trainer`, `ci`, `training_utils`, `recipe`, `hardware`, `deployment`, `ray`, `worker`, `single_controller`, `misc`, `perf`, `model`, `algo`, `env`, `tool`, `ckpt`, `doc`, `data`, `cfg`, `reward` - If this PR involves multiple modules, separate them with `,` like `[megatron, fsdp, doc]` - `{type}` is in `feat`, `fix`, `refactor`, `chore`, `test` - If this PR breaks any API (CLI arguments, config, function signature, etc.), add `[BREAKING]` to the beginning of the title. - Example: `[BREAKING][fsdp, megatron] feat: dynamic batching` ### Test > For changes that can not be tested by CI (e.g., algorithm implementation, new model support), validate by experiment(s) and show results like training curve plots, evaluation results, etc. ### API and Usage Example > Demonstrate how the API changes if any, and provide usage example(s) if possible. ```python # Add code snippet or script demonstrating how to use this ``` ### Design & Code Changes > Demonstrate the high-level design if this PR is complex, and list the specific changes. ### Checklist Before Submitting > [!IMPORTANT] > Please check all the following items before requesting a review, otherwise the reviewer might deprioritize this PR for review. - [x] Read the [Contribute Guide](https://github.com/volcengine/verl/blob/main/CONTRIBUTING.md). - [x] Apply [pre-commit checks](https://github.com/volcengine/verl/blob/main/CONTRIBUTING.md#code-linting-and-formatting): `pre-commit install && pre-commit run --all-files --show-diff-on-failure --color=always` - [x] Add / Update [the documentation](https://github.com/volcengine/verl/tree/main/docs). - [x] Add unit or end-to-end test(s) to [the CI workflow](https://github.com/volcengine/verl/tree/main/.github/workflows) to cover all the code. If not feasible, explain why: ... - [ ] Once your PR is ready for CI, send a message in [the `ci-request` channel](https://verl-project.slack.com/archives/C091TCESWB1) in [the `verl` Slack workspace](https://join.slack.com/t/verl-project/shared_invite/zt-3855yhg8g-CTkqXu~hKojPCmo7k_yXTQ). (If not accessible, please try [the Feishu group (飞书群)](https://applink.larkoffice.com/client/chat/chatter/add_by_link?link_token=772jd4f1-cd91-441e-a820-498c6614126a).) - [ ] If your PR is related to the `recipe` submodule, please also update the reference to the submodule commit via `git submodule update --remote` or `cd recipe && git pull origin main`.
### What does this PR do? **Description** This PR addresses issues with profiler configuration for inference engines (vLLM and SGLang) and refactors the profiler code for better cohesion and maintainability. **Key Changes:** - vLLM Profiler Configuration Fix: Implemented automatic setup of profiler-related environment variables for vLLM engine before process launch. Users no longer need to manually set vLLM environment variables. Added support for configuring the profiler via profiler_config for newer vLLM versions, ensuring compatibility. - SGLang Profiler Bug Fix: Fixed a bug introduced in [@pr 5025](verl-project#5025) regarding SGLang profiler data collection. Corrected the argument construction logic to ensure accurate profiling parameters are passed to the SGLang backend. - Code Refactoring & Cohesion: Centralized profiler logic by introducing adapter functions (build_vllm_profiler_args, build_sglang_profiler_args) within the profiler component. These adapters encapsulate the logic for constructing engine-specific profiler arguments, improving code organization and readability. - Testing: Added comprehensive unit tests to verify the correctness of the new adapter functions and ensure regression testing for the fixed bugs. ### Checklist Before Starting - [x] Search for similar PRs. Paste at least one query link here: ... - [x] Format the PR title as `[{modules}] {type}: {description}` (This will be checked by the CI) - `{modules}` include `fsdp`, `megatron`, `veomni`, `sglang`, `vllm`, `rollout`, `trainer`, `ci`, `training_utils`, `recipe`, `hardware`, `deployment`, `ray`, `worker`, `single_controller`, `misc`, `perf`, `model`, `algo`, `env`, `tool`, `ckpt`, `doc`, `data`, `cfg`, `reward` - If this PR involves multiple modules, separate them with `,` like `[megatron, fsdp, doc]` - `{type}` is in `feat`, `fix`, `refactor`, `chore`, `test` - If this PR breaks any API (CLI arguments, config, function signature, etc.), add `[BREAKING]` to the beginning of the title. - Example: `[BREAKING][fsdp, megatron] feat: dynamic batching` ### Test > For changes that can not be tested by CI (e.g., algorithm implementation, new model support), validate by experiment(s) and show results like training curve plots, evaluation results, etc. ### API and Usage Example > Demonstrate how the API changes if any, and provide usage example(s) if possible. ```python # Add code snippet or script demonstrating how to use this ``` ### Design & Code Changes > Demonstrate the high-level design if this PR is complex, and list the specific changes. ### Checklist Before Submitting > [!IMPORTANT] > Please check all the following items before requesting a review, otherwise the reviewer might deprioritize this PR for review. - [x] Read the [Contribute Guide](https://github.com/volcengine/verl/blob/main/CONTRIBUTING.md). - [x] Apply [pre-commit checks](https://github.com/volcengine/verl/blob/main/CONTRIBUTING.md#code-linting-and-formatting): `pre-commit install && pre-commit run --all-files --show-diff-on-failure --color=always` - [x] Add / Update [the documentation](https://github.com/volcengine/verl/tree/main/docs). - [x] Add unit or end-to-end test(s) to [the CI workflow](https://github.com/volcengine/verl/tree/main/.github/workflows) to cover all the code. If not feasible, explain why: ... - [ ] Once your PR is ready for CI, send a message in [the `ci-request` channel](https://verl-project.slack.com/archives/C091TCESWB1) in [the `verl` Slack workspace](https://join.slack.com/t/verl-project/shared_invite/zt-3855yhg8g-CTkqXu~hKojPCmo7k_yXTQ). (If not accessible, please try [the Feishu group (飞书群)](https://applink.larkoffice.com/client/chat/chatter/add_by_link?link_token=772jd4f1-cd91-441e-a820-498c6614126a).) - [ ] If your PR is related to the `recipe` submodule, please also update the reference to the submodule commit via `git submodule update --remote` or `cd recipe && git pull origin main`.
What does this PR do?
Checklist Before Starting
[{modules}] {type}: {description}(This will be checked by the CI){modules}includefsdp,megatron,veomni,sglang,vllm,rollout,trainer,ci,training_utils,recipe,hardware,deployment,ray,worker,single_controller,misc,perf,model,algo,env,tool,ckpt,doc,data,cfg,reward,like[megatron, fsdp, doc]{type}is infeat,fix,refactor,chore,test[BREAKING]to the beginning of the title.[BREAKING][fsdp, megatron] feat: dynamic batchingTest
To validate the functionality of each profile control parameter for the sglang rollout backend, orthogonal test cases were designed (minimizing redundant combinations while covering all key parameter values). The test results are as follows:
API and Usage Example
Design & Code Changes
Checklist Before Submitting
Important
Please check all the following items before requesting a review, otherwise the reviewer might deprioritize this PR for review.
pre-commit install && pre-commit run --all-files --show-diff-on-failure --color=alwaysci-requestchannel in theverlSlack workspace. (If not accessible, please try the Feishu group (飞书群).)recipesubmodule, please also update the reference to the submodule commit viagit submodule update --remoteorcd recipe && git pull origin main.