English | 简体中文
LMDeploy 是一个高效且友好的 LLM 模型部署工具箱,功能涵盖了量化、推理和服务。
本文主要介绍 LMDeploy 的基本用法,包括安装、离线批处理和推理服务。更全面的介绍请参考 LMDeploy 用户指南。
使用 pip(python 3.8+)安装 LMDeploy
pip install lmdeploy
只用以下 4 行代码,就可以完成 prompts 的批处理:
from lmdeploy import pipeline
pipe = pipeline("internlm/internlm2-chat-7b")
response = pipe(["Hi, pls intro yourself", "Shanghai is"])
print(response)
LMDeploy 实现了 dynamic ntk,支持长文本外推。使用如下代码,可以把 InternLM2 的文本外推到 200K:
from lmdeploy import pipeline, TurbomindEngineConfig
engine_config = TurbomindEngineConfig(session_len=200000,
rope_scaling_factor=2.0)
pipe = pipeline("internlm/internlm2-chat-7b", backend_engine=engine_config)
gen_config = GenerationConfig(top_p=0.8,
top_k=40,
temperature=0.8,
max_new_tokens=1024)
response = pipe(prompt, gen_config=gen_config)
print(response)
更多关于 pipeline 的使用方式,请参考这里
LMDeploy api_server
支持把模型一键封装为服务,对外提供的 RESTful API 兼容 openai 的接口。以下为服务启动的示例:
lmdeploy serve api_server internlm/internlm2-chat-7b
服务默认端口是23333。在 server 启动后,你可以在终端通过api_client
与server进行对话,体验对话效果:
lmdeploy serve api_client http://0.0.0.0:23333
此外,你还可以通过 Swagger UI http://0.0.0.0:23333
在线阅读和试用 api_server
的各接口,也可直接查阅文档,了解各接口的定义和使用方法。