nano-vllm学习

看代码步骤

复制代码
 1. 调度:决定下一步运行哪些序列
seqs, is_prefill = self.scheduler.schedule()

其中seqs表示被调度的序列列表。

seqs是一个包含 Sequence对象的列表,这些是被调度器选中、将要送入模型进行本次推理的序列。

这些序列的来源:

新请求:第一次运行的序列(需要预填充)

进行中的请求:已生成部分token,需要继续生成的序列

混合批次:可能同时包含新序列和进行中序列

3. 后处理:更新序列状态

self.scheduler.postprocess(seqs, token_ids)更新序列状态什么意思

在 LLM 推理中,每个用户请求对应一个Sequence(序列)对象。每次模型生成一个新的 token 后,需要更新这个序列的状态。具体包括:

1.添加新生成的 token 到序列中

python 复制代码
# 在 Sequence 类中可能有这样的逻辑:
for seq, new_token_id in zip(seqs, token_ids):
    seq.generated_token_ids.append(new_token_id)  # 添加到已生成列表
    seq.total_tokens += 1  # 总token数+1

2.检查序列是否应该结束

需要检查各种停止条件:

  • 是否生成了结束符(EOS token)

  • 是否达到最大生成长度

  • 是否满足特定的停止字符串条件

python 复制代码
# 伪代码示例
for seq in seqs:
    # 检查EOS token
    if new_token_id == config.eos_token_id:
        seq.is_finished = True
    
    # 检查最大长度
    if len(seq) >= seq.max_tokens:
        seq.is_finished = True
    
    # 检查停止字符串
    current_text = tokenizer.decode(seq.generated_token_ids)
    if any(stop_str in current_text for stop_str in seq.stop_strings):
        seq.is_finished = True

3.更新KV缓存的元数据

在vLLM的内存管理中,每个序列的KV缓存存储在特定的内存块中。更新状态包括:

  • 记录当前使用了哪些内存块

  • 如果序列结束,标记这些块为可回收状态

  • 更新序列在内存块中的位置指针

  1. 更新调度器的内部数据结构

调度器需要维护不同状态的序列:

  • 运行中:正在生成token的序列

  • 等待中:等待调度的序列

  • 已完成:生成结束的序列

postprocess会将已完成的序列从运行队列移到完成队列。

实际例子

假设有两个序列:

  • 序列A:已生成 ["你好", "世界"],还需要继续生成

  • 序列B :已生成 ["今天天气", "不错"],刚生成了结束符<eos>

执行 postprocess后:

  1. 序列A的token列表变为 ["你好", "世界", "新token"]

  2. 序列B标记为已完成

  3. 序列B的KV缓存被释放

  4. 序列B从运行队列移除

相关推荐
格鸰爱童话6 分钟前
向AI学习项目技能(六)
java·人工智能·spring boot·python·学习
H_老邪23 分钟前
spring boot 学习之路-1.0
spring boot·后端·学习
东京老树根1 小时前
SAP学习笔记 - BTP SAP Build02 - Deploy,开始URL,Approve,Reject,履历确认,Log,Context
笔记·学习
头疼的程序员1 小时前
计算机网络:自顶向下方法(第七版)第九章 学习分享(一)
学习·计算机网络
小墨同学boy2 小时前
越用越强不是广告语:拆解 Hermes Agent 的三层学习机制
人工智能·学习
才知道的3 小时前
stm32F407学习DAY.27 ADC
stm32·嵌入式硬件·学习
Orange_sparkle3 小时前
learn claude code学习记录-S02
java·python·学习
小郑加油3 小时前
python学习Day1:python的安装与环境搭载
python·学习·小白记录,保姆式教程
CheerWWW4 小时前
C++学习笔记——栈内存与堆内存、宏、auto、std::array
c++·笔记·学习
知识分享小能手4 小时前
MongoDB入门学习教程,从入门到精通,在生产环境中设置MongoDB(21)
数据库·学习·mongodb