背景介绍

当算法工程师在本地使用TensorFlow深度学习框架训练好模型后,会创建模型服务器供应用程序调用实现在线推理。由于部署本身存在一定的复杂性,他们需要考虑如何安装TensorFlow Serving相关的依赖,如何实现模型服务的高可用、请求负载均衡、A/B测试、自动伸缩机制等。Amazon SageMaker可以帮助用户快速创建多台模型服务器进行负载均衡,利用云上多可用区的方式实现高可用,并且在请求量变化时可以根据用户配置的策略进行自动扩展或收缩。本文会介绍如何将本地训练好的TensorFlow模型部署到Amazon SageMaker来快速、灵活地创建TensorFlow模型服务器。

1. TensorFlow Serving请求数据格式

在将模型部署到Amazon SageMaker之前,我们首先要了解TensorFlow Serving的SignatureDefs,它标识了保存模型时所需的接受请求函数的输入与输出,不同SignatureDefs下的请求数据格式不同。TensorFlow Serving支持gRPC API与RESTful API两种方式进行请求,本文以RESTful API的方式为例。

  • SignatureDefs:

https://www.tensorflow.org/tfx/serving/signature_defs

1.1 Classify与Regress API

Classify与Regress 的SignatureDefs分别支持分类与回归的TersorFlow Serving结构化调用方式。即当Serving的输入函数封装了tf.Example(一种灵活的消息类型,表示{“string”: value}的映射,常用来进行训练过程中的数据流式传输或解析feature_column中的特征列),需要调用该API进行推理。

参考以下代码,在保存模型时指定input_receiver_fn作为接受请求函数,其中定义了将feature_column解析为tf.Example消息类型的过程,然后输入给模型进行推理。

def input_receiver_fn(features):example_spec = tf.feature_column.make_parse_example_spec(features)return tf.estimator.export.build_parsing_serving_input_receiver_fn(example_spec, default_batch_size=5)
model.export_savedmodel(export_dir, input_receiver_fn(features))

在创建模型服务器后,若想对服务器进行请求得到推理结果,就需要将数据构造成Classify与Regress API所能接受的格式,如下所示:

{// Optional: serving signature to use.// If unspecifed default serving signature is used."signature_name": <string>,// Optional: Common context shared by all examples.// Features that appear here MUST NOT appear in examples (below)."context": {"<feature_name3>": <value>|<list>"<feature_name4>": <value>|<list>},// List of Example objects"examples": [{// Example 1"<feature_name1>": <value>|<list>,"<feature_name2>": <value>|<list>,...},{// Example 2"<feature_name1>": <value>|<list>,"<feature_name2>": <value>|<list>,...}...]
}

1.2 Predict API

Predict SignatureDefs支持将tensor作为输入和输出,可通用于分类与回归的推理问题类型。参考以下代码,在input_receiver_fn函数中,读取到数据后构造成tensor,作为模型的输入。

def input_receiver_fn ():feature_map = {}for i in range(len(iris_data.CSV_COLUMN_NAMES) -1):feature_map[iris_data.CSV_COLUMN_NAMES[i]] = tf.placeholder(tf.float32,shape=[3],name='{}'.format(iris_data.CSV_COLUMN_NAMES[i]))return tf.estimator.export.build_raw_serving_input_receiver_fn(feature_map)
model.export_savedmodel(export_dir_base=export_dir,serving_input_receiver_fn=input_receiver_fn ())

左右滑动查看更多

该情况下对模型服务器发起请求就需要使用Predict API,其所能接受的数据格式如下所示:

{// (Optional) Serving signature to use.// If unspecifed default serving signature is used."signature_name": <string>,// Input Tensors in row ("instances") or columnar ("inputs") format.// A request can have either of them but NOT both."instances": <value>|<(nested)list>|<list-of-objects>"inputs": <value>|<(nested)list>|<object>
}

左右滑动查看更多

1.3 在Amazon SageMaker中向Serving发送请求

在Amazon SageMaker的SDK(https://sagemaker.readthedocs.io/en/stable/frameworks/tensorflow/sagemaker.tensorflow.html#tensorflow-serving-predictor)中,将上述三种不同的API封装成了三种方法,即创建好Predictor之后,根据上述不同SignatureDefs所能接受的数据格式构造请求,就可以选择调用方法进行推理,Predict API、Classify与Regress API的调用方法如下所示:

2.将已训练好的TensorFlow模型部署到Amazon SageMaker

将模型压缩打包上传到Amazon S3之后,有两种方式可以实现模型的部署。

2.1方法一:不提供inference.py脚本

若不需要对请求中的数据进行前处理和后处理,就不需要提供inference.py脚本,实例化TensorFlowModel对象时只需要指定模型在Amazon S3中的位置,以及相关的role,如下所示:

from sagemaker.tensorflow import TensorFlowModel
model = TensorFlowModel(model_data='s3://mybucket/model.tar.gz', role='MySageMakerRole')
predictor = model.deploy(initial_instance_count=1, instance_type='ml.c5.xlarge')

左右滑动查看更多

部署完成之后,在推理时需要根据Serving所使用的SignatureDefs,将数据构造成SignatureDefs可以接受的格式,再调用相关的API进行推理。比如,若使用Classify API进行推理,则需要先将数据构造成1.1节中提到的请求格式,然后调用Predictor的classify方法,将推理数据作为参数传入,即可得到推理结果。

2.2方法二:提供inference.py脚本

若需要对输入模型的数据进行前处理或对推理产生的结果进行后处理,则需要在实例化TensorFlowModel对象时提供inference.py脚本,通过entry_point参数指定,如下所示:

from sagemaker.tensorflow import TensorFlowModel
model = Model(entry_point='inference.py',model_data='s3://mybucket/model.tar.gz',role='MySageMakerRole')

左右滑动查看更多

在inference.py的代码中需要定义两个函数,分别是input_handler与output_handler。其中input_handler首先需要对传递进来的序列化对象进行解析。比如TensorFlow Serving Predictor默认的serializer为JSONSerializer,那么在input_handler中就需要对json序列化对象解析,之后就可以对数据进行前处理操作。类似地,在推理前需要把处理好的数据转化为SignatureDefs所能接受的格式。注意,构造SignatureDefs数据格式这个过程是在input_handler中定义的,这么做的好处就是用户无需在请求Serving前完成请求数据格式的定义,让前端传入的数据更加简洁灵活。

  • JSONSerializer:

https://sagemaker.readthedocs.io/en/stable/frameworks/tensorflow/sagemaker.tensorflow.html#tensorflow-serving-predictor

同样,在得到推理结果后,可以把数据后处理过程写在output_handler函数中,通过response_centent_type指定序列化对象,将结果返回给前端。

3. 实验

本实验使用已经训练好的iris模型,展示带有inference.py和不带inference.py在Amazon SageMaker上进行模型部署的过程,并调用Classify API进行推理。实验所需环境:

  • 使用cn-northwest-1区域;

  • 在Amazon SageMaker中创建一台Jupyter Notebook实例,创建过程可参考官方文档:https://docs.aws.amazon.com/sagemaker/latest/dg/howitworks-create-ws.html

  • 下载实验所需的材料:git clone https://github.com/micxyj/awsblog-lab-guide.git,进入文件夹,将tf-byom.zip文件,上传至Notebook环境。

实验步骤如下:

  • 打开Notebook命令行,执行以下命令解压zip包;

  • cd SageMaker/unzip tf-byom.zip

  • 双击打开tf_byom.ipynb笔记本文件,逐步执行notebook中的步骤;

  • 可以看到若不提供inference.py,在进行推理前需要构造好Classify SignatureDefs所能接受的数据格式,如下图key为examples的字典:

Amazon SageMaker SDK会把推理数据进行序列化传递给Serving,推理完成之后会将结果反序化回前端。

  • 在提供了inference.py的场景中,由于在input_handler函数中定义了加载列表生成Classify SignatureDefs数据格式,在调用classify进行推理时只需要传入列表数据即可,如下所示:

4. 总结

本文介绍了TensorFlow Serving三种不同SignatureDefs的区别以及调用方法,展示了如何将本地训练的模型在Amazon SageMaker上进行部署与推理。通过使用Amazon SageMaker,用户可以快速地将模型进行部署上线,无需进行复杂的配置便可实现高可用的、可扩展的模型服务器架构。

5. 参考资料

[1] https://www.tensorflow.org/tfx/serving/api_rest

[2] https://www.tensorflow.org/tfx/serving/signature_defs

[3] https://sagemaker.readthedocs.io/en/stable/frameworks/tensorflow/deploying_tensorflow_serving.html

本篇作者

肖元君

亚马逊云科技解决方案架构师

负责基于亚马逊云科技云计算方案的架构咨询和设计实现,同时致力于数据分析与人工智能的研究与应用。

郭韧

亚马逊云科技人工智能和机器学习方向解决方案架构师

负责基于亚马逊云科技的机器学习方案架构咨询和设计,致力于游戏、电商、互联网媒体等多个行业的机器学习方案实施和推广。在加入亚马逊云科技之前,从事数据智能化相关技术的开源及标准化工作,具有丰富的设计与实践经验。

在Amazon SageMaker上快速、灵活构建TensorFlow模型的在线推理服务相关推荐

  1. 在Amazon SageMaker上快速、灵活构建Amazon TensorFlow模型的在线推理服务

    背景介绍 当算法工程师在本地使用Amazon TensorFlow深度学习框架训练好模型后,会创建模型服务器供应用程序调用实现在线推理.由于部署本身存在一定的复杂性,他们需要考虑如何安装TensorF ...

  2. 在 Amazon SageMaker 上玩转 Stable Diffusion: 基于 Dreambooth 的模型微调

    本文将以 Stable Diffusion Quick Kit 为例,详细讲解如何利用 Dreambooth 对 Stable Diffusion 模型进行微调,包括基础的 Stable Diffus ...

  3. Generative AI 新世界 | 大语言模型(LLMs)在 Amazon SageMaker 上的动手实践

    在上一篇<Generative AI 新世界:大型语言模型(LLMs)概述>中,我们一起探讨了大型语言模型的发展历史.语料来源.数据预处理流程策略.训练使用的网络架构.最新研究方向分析(A ...

  4. R语言构建xgboost模型、预测推理:输出预测概率、预测标签

    R语言构建xgboost模型.预测推理:输出预测概率.预测标签 目录 R

  5. [tensorflow]tf.estimator.Estimator构建tensorflow模型

    目录 一.Estimator简介 二.数据集 三.定义特征列 四.estimator创建模型 五.模型训练.评估和预测 六.模型保存和恢复 一.Estimator简介 Estimator是Tensor ...

  6. 使用Amazon SageMaker构建高质量AI作画模型Stable Diffusion

    使用Amazon SageMaker构建高质量AI作画模型Stable Diffusion 0. 前言 1. Amazon SageMaker 与机器学习 1.1 机器学习流程 1.2 Amazon ...

  7. 使用Amazon SageMaker 构建基于自然语言处理的文本摘要应用

    背景介绍 文本摘要,就是对给定的单个或者多个文档进行梗概,即在保证能够反映原文档的重要内容的情况下,尽可能地保持简明扼要.质量良好的文摘能够在信息检索过程中发挥重要的作用,比如利用文摘代替原文档参与索 ...

  8. 20分钟,使用Amazon SageMaker快速搭建属于自己的AIGC应用

    真火! 作为最近一段时间人工智能领域内的顶流之一,AIGC(AI-Generated Content)早已火爆出圈,频登各大互联网平台热搜. cite: 微软亚洲研究院官方微博 这段时间以来,基于深度 ...

  9. 快速上手Amazon SageMaker动手实验室

    最近人工智能爆火啊,前有AIGC后有ChatGPT,ChatGPT倒是可以很简单的体验到,但是AIGC这个似乎需要一点动手能力,而且还要考虑下我们本地的环境了.恰好我最近受邀参加了亚马逊云科技[云上探 ...

最新文章

  1. python将输出结果写入csv,在Python中将彩色输出写入CSV文件
  2. 探React Hooks
  3. Openlayers中多图层遮挡时调整图层上下顺序
  4. nagios利用pyfetion报警最新
  5. sudo: apt-get:找不到命令”的解决方法
  6. 将Spring MVC RESTful Web服务迁移到Spring 4
  7. 微信公众号开发 重要 access_token {errcode:40164,errmsg:invalid ip 114.221.159.11, not in whitelist hint:
  8. 设计模式常见面试题汇总
  9. 内存映射与DMA笔记
  10. Mysql的my.cnf配置文件详情
  11. Spring学习总结(24)——Spring配置文件加载路径总结
  12. 尝试笔记 01 之 CSS 边角上的标签
  13. android4以上版本读写外置sd卡报错的解决办法
  14. Android Multimedia框架总结(十七)音频开发基础知识
  15. c#中excel文件怎么转换为dbf文件
  16. C语言运算符与输入输出
  17. 国猪555555555
  18. 太实用了!Excel VBA常用代码!
  19. 【前端技术】一篇文章搞掂:CSS
  20. CAD7:构造线的使用 【TR剪掉多余的线】

热门文章

  1. python:实现叠加图片(附完整源码)
  2. OSPF ISIS RIP实现总公司与分公司等的互联
  3. 电磁场仿真实验【matlab】静电场边值问题
  4. 如何将SVN上的版本回滚到旧版本
  5. PZT-JH20/8高压电极化装置(20KV以下压电陶瓷同时极化1-8片)
  6. 医院绩效考核上报工作迫在眉睫,如何顺利完成?
  7. jenkin构建报错信息及解决方案
  8. 选购摄像头前必看,摄像头参数科普
  9. 想买折叠手机的你,了解OLED显示很有必要
  10. python 自动输入验证码_python 自动生成验证码并 输入识别