首页 > 其他分享 >海量大模型如何一键部署上云?函数计算 x ModelScope 社区给出答案

海量大模型如何一键部署上云?函数计算 x ModelScope 社区给出答案

时间:2024-10-22 16:50:26浏览次数:1  
标签:部署 SwingDeploy 模型 ModelScope 一键 上云 开源 API OpenAI

作者:魔搭官方

大模型在过去一年多时间里的一路技术狂奔,深刻的改变了今天模型和AI的整体应用生态,也给开发者提供纷繁复杂的模型选择。在多样化大模型的背后,OpenAI 得益于在领域的先发优势,其 API 接口今天也成为了业界的一个事实标准。许多开源工具和框架,包括 LlamaIndex,LangChain 等,都提供了与 OpenAI API 接口的标准对接方式,让开发者能方便地调用模型服务,进行各种工具以及应用的开发。无论是闭源模型还是开源模型,都能通过接口标准化,让广大开发者基于已有的丰富教程、示例代码和最佳实践指南,实现模型使用的真正落地。

对于 AI 应用开发,相比直接本地加载模型进行推理,模型的 API 服务化接口提供了更轻量化以及可扩展的潜力。开源模型从 checkpoint 转换为模型服务,并通过大家熟悉 OpenAI API 来提供服务,无疑时让模型能力能更好被集成的助推器。我们也希望 ModelScope 社区上开源的,多种多样的大模型,都能够被迅速服务化,并通过 OpenAI API 的接口开放给广大开发者,激发更多在模型应用上的创造力。这是我们在 ModelScope 推出一键部署 OpenAI API 兼容的模型服务的初衷。

SwingDeploy

SwingDeploy 是魔搭社区推出的模型一键部署服务,支持将魔搭上的各种(包括语音,视频,NLP 等不同领域)模型直接部署到用户指定的云资源上。并能在部署后通过 ModelScope pipeline 提供通用性的 API 调用。而有鉴于 LLM 领域,OpenAI API 接口的便利性,以及大模型领域高效推理框架(包括 Ollama+llama.cpp,vLLM,LMDeploy,SGLang 等)的迅速发展,我们这一期针对 LLM,专门提供了能够提供 OpenAI API 兼容的的模型服务部署能力。而在这许多大模型推理框架中,Ollama 基于 llama.cpp,提供了包括 CPU 在内的多硬件支持,也是这期 SwingDeploy 在这一能力上首选使用的推理框架。

得益于阿里云函数计算的产品能力,魔搭 SwingDeploy 后的模型推理 API 服务默认具备极致弹性伸缩(缩零能力)、GPU 虚拟化(最小 1GB 显存粒度)、异步调用能力、按用付费、闲置计费等能力,这些能力帮助算法工程师大大加快了魔搭开源模型投入生产的生命周期。

Ollama 推理框架

Ollama 是基于开源的 llama.cpp 项目开发的模型推理工具框架。得益于 llama.cpp 提供的高效模型推理和多硬件适配,Ollama 使得开发者能通过命令行,迅速在不同的硬件环境上拉起大模型服务。更重要的是,作为一个开源项目,Ollama 保持了与 llama.cpp 对接的开放性:除了 Ollama 官方提供的大模型以外,开发者可以通过导入指定的 GGUF 模型文件,并通过 Modelfile 配置文件自定义模型推理参数。与此同时,Ollama 提供了 OpenAI API 兼容的接口,为模型的使用提供了便利。

从模型到 OpenAI API:上手实操

SwingDeploy 提供了将 ModelScope 上的开源模型,部署到云上并提供 OpenAI API 接口的服务。

前置工作: 首先从魔搭站点的模型服务页面进入部署服务:https://www.modelscope.cn/my/modelService/deploy。如果之前没有用过 SwingDeploy 服务,需要先配置一下 ModelScope 账号和阿里云账号的绑定,并开通 FC 服务授权。

注:开通服务和授权均为免费,另外绑定阿里云账号的话,还可以在 ModelScope Notebook 上薅 100 个小时的 GPU 免费算力。

按照页面上的提示一步步操作即可。绑定授权都完成后长这样:

一键部署:完成准备工作后,点击新建部署,就可以进入部署页面。

在这里,我们可以看到,在“原生部署”链路之外,新增了“OpenAI API 兼容部署”页面。当前首先支持了 Ollama 推理框架。在这个页面上,可以选择想要部署的模型。这里我们以 Qwen2-7B-Instruct 为例,点击一键部署即进入函数计算 FC 的部署页面,点击“创建应用”即开始部署。

取决于您具体选择的模型,模型部署大概需要几分钟到十几分钟的时间,耐心等待一下即可。

部署完成后,就可以直接使用 OpenAI API 来调用 Qwen2-7B 这个模型了。从“立即使用”入口,就可以获取使用的范例代码:

需要注意的是,这个部署是您自己的专有部署,鉴权信息就是模型服务地址(base_url),不需要填入特殊的 API Key。我们把范例代码拷贝并执行,就可以直接调用模型服务:

from openai import OpenAI
model_id = 'qwen/Qwen2-7B-Instruct-GGUF'
client = OpenAI(    base_url='https://ms-fc-dapp-func-<replace with your  id>.cn-hangzhou.fcapp.run/v1',    api_key='ollama')
response=client.chat.completions.create(    model=model_id,    messages=[{"role":"user", "content":"Hello! 你是谁?"}],    stream=True)
for chunk in response:    print(chunk.choices[0].delta.content, end='')

到这里,通过几个简单的步骤,我们就完成了一个 Qwen2-7B 的 OpenAI 接口兼容 API 服务的部署。现在通过 OpenAI 的 SDK 或者 API,就能够接入到众多与 OpenAI 兼容的工具链或其他生态服务中了。

在上面部署的流程中,我们全程使用了默认配置,实际是在 CPU 机器上,部署了 Qwen2 的 70 亿参数规模模型的一个 GGUF 量化(Q5_K_M)版本。接下来我们再展开介绍一下这个链路上的可配置参数。

自定义部署硬件与模型 API 参数

除了默认的参数以外,SwingDeploy 同时支持开发者对于部署模型所使用的参数进行配置。我们这里进一步展开一下做介绍。

展开“高级配置”,就可以看到可用的额外选项:

这里我们逐一说明一下:

  • 模型版本号: ModelScope 上的模型可以有不同的版本,这里可做选择(默认使用最新的 master 版本)。
  • 模型文件: GGUF 格式极大简化了大语言模型文件的管理,可通过单模型文件完成推理。而且借助 llama.cpp 提供的丰富量化能力,一个模型 repo 下的不同 GGUF 文件,通常对应的是不同量化精度与量化方法。平台默认选用的是 Q5_K_M 版本,在推理精度以及推理速度,资源消耗之间做一个较好的均衡。如果有特殊的需求,也可以选择更高的精度--例如 FP16 版本,或者更激进的量化(更小的模型文件)-- 例如 Q2_K 版本。

Modelfile 配置:Modelfile 是 Ollama 框架进行模型参数设定的配置文件,SwingDeploy 为当前支持的模型都提供了默认可用的配置,但是也允许您自定义配置,点击页面上的“编辑”即可进行修改。

比如这里我们把模型部署使用的 SYSTEM prompt 修改为:

You are a lovely cat, you answer each question ending with "meow~"(喵~)

这里我们选用了 Gemma2 模型,并通过 SYSTEM prompt 的配置让模型扮演一只小猫,每个回答都要以“meow~”(喵~)来做结尾。

模型部署后,再进行调用:

可以看到,这时候同样使用 OpenAI API 调用,模型确实展现出了符合预期的行为。当然,部分配置也可以在每次通过 OpenAI 的 API/SDK 接口调用的时候修改(例如 temperature,top_p, top_k 等参数)。

部署类型:SwingDeploy x Ollama 框架,支持在 CPU 或 GPU 上的部署,在这里可以按需进行选择。同时在 FC 的部署页面上,也可以选择更多的不同规格,这里不再赘述。

当前 SwingDeploy 提供基于阿里云函数计算(FC)的 serverless 服务,模型的部署可以根据 API 调用的时间来收费:整体的部署成本,尤其是 CPU 部署成本,相当可控。具体细节可以参见函数计算 FC [ 1] 的产品页面说明。

What‘s Next

OpenAI API 作为今天大模型应用生态的事实标准,已经在业界,包括各个开源社区,被广泛的接受。ModelScope 社区的 SwingDeploy,打通了从开源模型,直接转换为 OpenAI API 兼容的模型服务之间的通路。这为开发者通过 API 服务,迅速上手不同的开源模型,将模型能力接入不同的应用生态,提供了较大的便利性。后续我们会有更多的功能上线:

  • 扩大模型支持的范围。 当前一期主要提供了包括 qwen2,gemma2, llama3.1 等一系列头部开源模型的直接部署能力。后续我们计划开放对所有的开源大模型支持,只要是 GGUF 格式的 LLM 模型,均可以通过 SwingDeploy 迅速部署位 OpenAI API 服务。
  • 添加不同模型 API 接口支持。 目前 SwingDeploy 上的 OpenAI API 兼容首先提供了 LLM 模型支持(OpenAI 的 Chat Completions 接口),后续会添加包括 embedding,多模态 VL 模型,乃至语音等各种模型的支持,全面补全基于 OpenAI API 生态使用各种开源模型的生态。
  • 引入 Ollama 以外的其他推理框架(如 vLLM、LMdeploy、SGLang 等)的支持。

相关链接:

[1] 函数计算 FC

https://www.aliyun.com/product/fc

标签:部署,SwingDeploy,模型,ModelScope,一键,上云,开源,API,OpenAI
From: https://www.cnblogs.com/alisystemsoftware/p/18493255

相关文章

  • 拼多多商品详情,一键获取的“魔法”
    亲爱的朋友们,你是否曾在拼多多上看到一件心仪的商品,却因为繁琐的手动操作而望而却步?是否在想,如果能有一种“魔法”,让我们能快速获取商品的详细信息,那该多好!今天,我要告诉你,这种“魔法”真的存在,它就是——PDDAPI!首先,让我们来聊聊拼多多。这个平台以其独特的团购模式和亲民的价格,......
  • VMD-DBO-CNN-BiLSTM四模型多变量时间序列光伏功率预测一键对比 Matlab代码
    基于VMD-DBO-CNN-BiLSTM、VMD-CNN-BiLSTM、VMD-BiLSTM、BiLSTM四模型多变量时间序列光伏功率预测一键对比(仅运行一个main即可)[原创未发表]Matlab代码每个模型的预测结果和组合对比结果都有!运行步骤:1.先运行main1进行VMD分解2.在运行main2进行四模型一键对比代码......
  • 基于NRBO、CPO、TTAO、FVIM-CNN-LSSVM/CNN-LSSVM回归预测 5 模型一键对比 Matlab
    基于NRBO-CNN-LSSVM、CPO-CNN-LSSVM、TTAO-CNN-LSSVM、FVIM-CNN-LSSVM、CNN-LSSVM五模型多变量回归预测一键对比(仅运行一个main即可)Matlab代码代码解释:(优化算法均为24年算法)优化参数为:批次数、正则化系数、学习率【牛顿拉夫逊算法、冠豪猪算法、三角拓扑聚合算法、四向......
  • 抖音小店商家电话采集系统 一键导出抖音商家联系方式软件
    分享作者:1143561141(v同q)抖音作为目前最受欢迎的短视频平台之一,吸引了大量商家在平台上开设小店。许多人希望能够快速获取商家的联系方式,以便合作或咨询产品信息。本教程将介绍如何使用Python编写一个抖音小店商家电话采集系统,通过一键导出商家的联系方式。步骤一:安装必要的工具......
  • 免费试用、快速上云,注册还能100%中奖,竟有这种好事?!
    活动时间内完成注册亚马逊云科技账号,即可获得以下福利免费试用,带你体验快速上云热门场景,带你手把手轻松搭建51CTO博客专属福利,100%获得精美礼品罗技无线键鼠套装绿联充电宝50元京东E卡丰厚奖品等你来拿!中奖率100%!活动时间:即日起至10月31日24时51CTO博客福利领取流程:在活动有效期内......
  • 当coretypes.dll守护者缺席:一键解锁应用程序故障自救秘籍
    在计算机的世界里,每一个小小的文件都承载着巨大的责任。而coretypes.dll,这个看似不起眼的动态链接库文件,却是许多应用程序正常运行的守护神。它负责提供核心类型定义和功能支持,一旦丢失或损坏,你的应用程序可能会立刻陷入困境,出现无法启动、崩溃或功能异常等问题。然而,面对这......
  • 星海智算:【镜像教程】MimicBrush:神奇画刷,一键搞定局部重绘!
    [MimicBrush 镜像教程 ]—— 欢迎使用星海智算——MimicBrush✦ 模型介绍 MimicBrush是由阿里巴巴、香港大学和蚂蚁集团联合研发的创新AI图像编辑工具。它允许用户通过简单操作,精准替换图片局部,轻松实现高质量的艺术修图。其特色功能包括先进的图像识别技术、自......
  • Windows & Office 永久激活工具!小白一键就能搞定~
    HEUKMSActivator中文版是一款简洁高效的KMS/OEM智能激活工具,适用所有Windows、Office版本,无需联网即可一键激活,支持UEFI的KMS激活工具。KMS服务是微软对Windows、Office等产品的批量许可服务,利用KMS可以激活局域网内的产品。该工具利用KMS机制在系统搭建KMS服务器,从而实现在线或......
  • 一键生成黑神话悟空小红书封面+文案,抓住流量,狠狠赚一笔!
    前段时间,一款名为《黑神话:悟空》的单机游戏爆火出圈,关于它的消息几乎刷爆了所有的社交媒体。虽然很多人对游戏不感冒,但你仍然可以抓住热点,发周边内容来狠狠地赚一笔。快手、抖音、小红书等各个平台流量都很火爆,比如有人制作了悟空的时装走秀视频:还有其他博主搞出了一堆的周边内......
  • SolidWorks一键重命名、使之独立、创建新版
    在老铁们的大力支持之下,第5版终于面世了。本宏程序基于solidworks2021版设计,未在其余版本的solidworks下测试。本程序文件共享在网盘中,关注微信公众号“全栈开发的码农”并回复消息“一键重命名”即可获得下载链接和提取码。下载程序文件后,在solidworks打开任意文档,添加并运行宏。......