[main] add pd transfer for ascend scheduler (#2753)
### What this PR does / why we need it?
For offline scenarios, adjust the scheduling process to prioritize the
prefill phase of all requests, then process the decode phase of all
requests.
### How was this patch tested?
```
max_num_seqs=24,
additional_config={
"ascend_scheduler_config":{
"enabled": True,
"enable_pd_transfer": True,
"decode_max_num_seqs": 24,
"enable_chunked_prefill": False
}
},
```
| input | output | num prompts | max_num_seqs | dp | tp | scheduler |
tps |
| ------ | ------ | ---------- | ---------------- | ---- | ---- |
---------------- | --------------- |
| dapo-math-17K | 2K | 384 | 24 | 2 | 1 | v1 | 234.06 |
| dapo-math-17K | 2K | 384 | 24 | 2 | 1 | pd transfer | 239.59(+2.4%) |
| dapo-math-17K| 2K | 384 | 24 | 4 | 1 | v1 | 222.85 |
| dapo-math-17K| 2K | 384 | 24 | 4 | 1 | pd transfer | 225.81(+1.3%) |
- vLLM version: v0.10.1.1
- vLLM main:
6fb2788163
---------
Signed-off-by: CaranLic <740821011@qq.com>
This commit is contained in:
@@ -705,3 +705,34 @@ class TestAscendScheduler(TestBase):
|
||||
|
||||
# Confirm no memory leak.
|
||||
self.assert_scheduler_empty(scheduler)
|
||||
|
||||
def test_scheduler_with_pd_transfer(self):
|
||||
scheduler = self.create_scheduler()
|
||||
scheduler.phase = "prefill"
|
||||
requests = create_requests(num_requests=32)
|
||||
for request in requests:
|
||||
scheduler.add_request(request)
|
||||
|
||||
# 1st iteration, move 16 requests from waiting to running for prefill
|
||||
scheduler_output = scheduler.schedule()
|
||||
model_runner_output = make_output(scheduler)
|
||||
scheduler.update_from_output(scheduler_output, model_runner_output)
|
||||
first_iter_prefilled_req_num = len(scheduler.running)
|
||||
self.assertEqual(len(scheduler_output.scheduled_new_reqs),
|
||||
scheduler.max_num_running_reqs)
|
||||
self.assertEqual(scheduler_output.scheduled_cached_reqs.num_reqs, 0)
|
||||
self.assertEqual(len(scheduler_output.finished_req_ids), 0)
|
||||
|
||||
# 2nd iteration, move 16 prefilled requests to finished_prefill_reqs
|
||||
# and move 16 requests from waiting to running for prefill
|
||||
scheduler_output = scheduler.schedule()
|
||||
model_runner_output = make_output(scheduler)
|
||||
scheduler.update_from_output(scheduler_output, model_runner_output)
|
||||
self.assertEqual(len(scheduler.finished_prefill_reqs),
|
||||
first_iter_prefilled_req_num)
|
||||
|
||||
# 3rd iteration, all requests prefilled, change scheduler phase to decode
|
||||
scheduler_output = scheduler.schedule()
|
||||
model_runner_output = make_output(scheduler)
|
||||
scheduler.update_from_output(scheduler_output, model_runner_output)
|
||||
self.assertEqual(scheduler.phase, "decode")
|
||||
|
||||
Reference in New Issue
Block a user