如何将新模型推向张量流服务?

时间:2019-04-11 12:47:49

标签: python tensorflow tensorflow-serving

我需要一种使用 Python 3 将新训练的模型推送到运行 tenserflow-serving 的已部署容器的方法。

找到了tfx软件包(https://www.tensorflow.org/tfx/guide/pusher),但仅适用于 python 2.7

还发现了这个问题,指出该功能存在:How to add a new model in tensorflow serving 但是我仍然缺少如何使用 Python 3 部署新模型的良好指南。

1 个答案:

答案 0 :(得分:0)

我已经创建了一个模型,并将其保存在路径“ / usr / local / google / home / abc / Jupyter_Notebooks / export”中。

然后,我将其提交给Tensorflow Serving Docker Container,并推断出该模型并获得结果。

在命令提示符下运行的命令,用于实现上述说明,如下所示:

sudo docker run -d --name sb tensorflow/serving

sudo docker cp /usr/local/google/home/abc/Jupyter_Notebooks/export sb:/models/export

sudo docker commit --change "ENV MODEL_NAME export" sb rak_iris_container

sudo docker kill sb

sudo docker pull tensorflow/serving

sudo docker run -p 8501:8501 --mount type=bind,source=/usr/local/google/home/abc/Jupyter_Notebooks/export,target=/models/export -e MODEL_NAME=export -t tensorflow/serving &

saved_model_cli show --dir /usr/local/google/home/abc/Jupyter_Notebooks/export/1554294699 --all

curl -d '{"examples":[{"SepalLength":[5.1],"SepalWidth":[3.3],"PetalLength":[1.7],"PetalWidth":[0.5]}]}' \
  -X POST http://localhost:8501/v1/models/export:classify

上述推论的输出是

{
    "results": [[["0", 0.998091], ["1", 0.00190929], ["2", 1.46236e-08]]
    ]
}

使用以下代码保存模型:

feature_spec = tf.feature_column.make_parse_example_spec(my_feature_columns)
serving_input_receiver_fn = tf.estimator.export.build_parsing_serving_input_receiver_fn(feature_spec)
export_dir = classifier.export_savedmodel('export', serving_input_receiver_fn)
print('Exported to {}'.format(export_dir))

以上命令的输出为:

导出到b'/ usr / local / google / home / abc / Jupyter_Notebooks / export / 1554980806'