ModelScope模型使用与EAS部署调用

本文涉及的产品
视觉智能开放平台,视频资源包5000点
视觉智能开放平台,分割抠图1万点
视觉智能开放平台,图像资源包5000点
简介: 本文以魔搭数据的模型为例,演示在DSW实例中如何快速调用模型,然后通过Python SDK将模型部署到阿里云PAI EAS服务,并演示使用EAS SDK实现对服务的快速调用,重点针对官方关于EAS模型上线后示例代码无法正常调通部分进行了补充。

模型地址

操作步骤

1、创建DSW实例

镜像版本选择:dsw-registry-vpc.cn-hangzhou.cr.aliyuncs.com/pai/modelscope:1.13.3-pytorch2.1.2tensorflow2.14.0-gpu-py310-cu121-ubuntu22.04


2、代码快速测试模型功能

import cv2
from modelscope.outputs import OutputKeys
from modelscope.pipelines import pipeline
from modelscope.utils.constant import Tasks

img_cartoon = pipeline(Tasks.image_portrait_stylization, 
                       model='damo/cv_unet_person-image-cartoon_compound-models')
img_path = 'https://modelscope.oss-cn-beijing.aliyuncs.com/test/images/image_cartoon.png'
result = img_cartoon(img_path)
cv2.imwrite('result.png', result[OutputKeys.OUTPUT_IMG])
print('finished!')


3、Python SDK部署模型

# 安装PAI Python SDK
pip install alipai>=0.4.3

# 配置阿里云相关服务信息
python -m pai.toolkit.config


from pai.common.utils import random_str
from pai.session import get_default_session
from pai.modelscope.model import ModelScopeModel

# 获取阿里云PAI平台相关默认配置,如遇到配置问题,请参考
# https://help.aliyun.com/zh/pai/user-guide/install-and-configure-pai-python-sdk
sess = get_default_session()

# ModelScope模型信息:https://www.modelscope.cn/models/lskhh/moran-cv_unet_person-image-cartoon-genshin_compound-models/files
hub = {
    "MODEL_ID": "lskhh/moran-cv_unet_person-image-cartoon-genshin_compound-models",
    "TASK": "image-portrait-stylization",
    "MODEL_VERSION": "v1.0.5",
    "DEPLOY_ENV": "eas",
}

# 创建 ModelScopeModel 对象
m = ModelScopeModel(
    command="python -u /usr/src/app/app.py",
    port=9000,
    image_uri=f"eas-registry-vpc.{sess.region_id}.cr.aliyuncs.com/pai-eas/modelscope-inference:eas-deploy-common-v17.3.2",
    environment_variables=hub
)

# 部署服务到阿里云PAI平台
# 请注意,部署服务会产生EAS费用账单
p = m.deploy(
    service_name=f"taro_ms_serving_{random_str(6)}",  # 设置模型服务的名称
    instance_type="ecs.gn6v-c8g1.2xlarge",
    # 额外的服务部署配置,如指定服务端超时时间、配置额外硬盘空间等
    options={
        "metadata.rpc.keepalive": 300000,
        "features.eas.aliyun.com/extra-ephemeral-storage":"30Gi",
    },
)

4、控制台查看模型部署情况

图片.png

图片.png

5、EAS SDK调用服务

安装包:pip install -U eas-prediction --user

import requests
import base64
import json
from eas_prediction import PredictClient, TFRequest
from eas_prediction import StringRequest

# http://12825281********.cn-hangzhou.pai-eas.aliyuncs.com/api/predict/taro_ms_serving_ydv5hf
client = PredictClient('http://12825281********.cn-hangzhou.pai-eas.aliyuncs.com', 'taro_ms_serving_ydv5hf')
client.set_token('NDE0ZTk3N2UxNTI0ZmZhNDkzMzE0MGQ2ZjFiZD***************==')
client.init()
# 读取网页图片
url = "https://modelscope.oss-cn-beijing.aliyuncs.com/test/images/image_cartoon.png"
resp = requests.get(url)
image_data = resp.content
base64_data = base64.b64encode(image_data).decode('utf-8')
data = {
    'input': {
        'image': base64_data
    }
}
req = StringRequest(json.dumps(data))  # json格式化request body,否则请求出错
res = client.predict(req)
result = json.loads(res.response_data.decode())
result_img = base64.b64decode(result['Data']['output_img'])

保存图片

!pip install Pillow

from PIL import Image
import io

# 假设 binary_data 是包含图片二进制数据的变量
binary_data = result_img
# 使用 io.BytesIO 将二进制数据转换成文件对象
image_file = io.BytesIO(binary_data)
# 用 PIL 打开这个文件对象
image = Image.open(image_file)
# 可以选择在这里对图片进行任何处理,如缩放、裁剪等
# 保存为 PNG 格式的文件
image.save('output1.png', format='PNG')

图片.png


更多参考

阿里云机器学习PAI EAS部署TensorFlow Model

eas-python-sdk

相关文章
|
4天前
|
人工智能 物联网
如何将Together AI上基于Qwen2-7B训练的模型部署到ModelScope平台
如何将Together AI上基于Qwen2-7B训练的模型部署到ModelScope平台
40 10
|
2月前
|
自然语言处理 监控 API
"阿里云ModelScope深度测评:从预训练模型到一键部署,揭秘高效模型开发背后的秘密,开发者必备利器!"
【10月更文挑战第23天】阿里云ModelScope是一款便捷的模型开发、训练、部署和应用平台。它提供丰富的预训练模型,涵盖自然语言处理、计算机视觉等领域,支持一键式模型训练和部署,具备模型版本管理和监控功能,显著降低开发门槛,提高模型应用效率。
105 0
|
3月前
|
弹性计算 Serverless API
海量大模型如何一键部署上云,函数计算 x ModelScope 社区给出答案
得益于阿里云函数计算的产品能力,魔搭 SwingDeploy 后的模型推理 API 服务默认具备极致弹性伸缩(缩零能力)、GPU 虚拟化(最小 1GB 显存粒度)、异步调用能力、按用付费、闲置计费等能力,这些能力帮助算法工程师大大加快了魔搭开源模型投入生产的生命周期。
|
5月前
|
人工智能 开发框架 物联网
赢万元奖金 | 第七届CCF开源创新大赛ModelScope开源模型应用挑战赛开启报名!
第七届CCF开源创新大赛(后简称“大赛”) 由中国计算机学会(CCF)主办,长沙理工大学、CCF开源发展委员会联合承办。
|
7月前
|
人工智能 开发工具 Swift
ModelScope联手OpenDataLab:直接调用7000+开源数据集,赋能AI模型加速研发
魔搭社区和OpenDatalab浦数合作,共同开启一场模型与数据的深度融合,旨在为中国开发者打造更加高效、开放的AI体验。
|
7月前
|
网络安全 Docker 容器
modelscope-funasr部署后,但是无法通过html链接,是为什么呀?
在虚拟机上成功部署了Docker化的modelscope-funasr服务,日志显示初始化正常。防火墙已关闭,但尝试通过HTML页面访问时连接失败。
|
8月前
|
机器学习/深度学习 人工智能 Swift
PAI x ModelScope: 在PAI使用ModelScope模型
在当前的人工智能领域,特别是大语言模型、文生图等领域,基于预训练模型完成机器学习模型的开发部署已成为重要的应用范式,开发者们依赖于这些先进的开源预训练模型,以简化机器学习应用的开发并加速创新。
|
8月前
|
自然语言处理
在ModelScope中,你可以通过设置模型的参数来控制输出的阈值
在ModelScope中,你可以通过设置模型的参数来控制输出的阈值
206 1
|
8月前
|
API 语音技术
ModelScope-FunASR**有支持热词又支持时间戳的模型**。
【2月更文挑战第30天】ModelScope-FunASR**有支持热词又支持时间戳的模型**。
236 2
|
8月前
|
人工智能 API 决策智能
Modelscope结合α-UMi:基于Modelscope的多模型协作Agent
基于单个开源小模型的工具调用Agent,由于模型容量和预训练能力获取的限制,无法在推理和规划、工具调用、回复生成等任务上同时获得比肩大模型等性能。

热门文章

最新文章