SKIL/工作流程/嵌入式SKIL

嵌入式SKIL

除了提供几乎所有用于创建高效机器学习管道的工具之外,SKIL还可以非常方便地作为嵌入式应用程序。这对于一个DevOps团队来说是非常有用的,可以让他们的模型在最短的时间内运行起来,并且可以减少麻烦。通过不同的工具和SKIL脚本的组合,你 可以轻松地将SKIL嵌入到应用程序管道中。

用例

此文档将显示许多可以嵌入SKIL的用例。

1. 服务于单一模式

让我们通过Docker文件来查看SKIL部署的用例,它为在TensorFlow中训练的单个模型提供服务。此方案的源代码在此处可用。
让我们看看这个场景的“Dockerfile”源代码:

FROM skymindops/skil-ce

USER root

ADD deploy_model.py /deploy_model.py
ADD data_directory/output_graph.pb /model.pb
ADD deploy_model.sh /deploy_model.sh

RUN chmod 755 /deploy_model.sh

RUN yum install -y epel-release 
RUN yum install -y python-pip 
RUN pip install numpy skil-client

# PLD
EXPOSE 9008 
# File Server
EXPOSE 9508
# Zeppelin
EXPOSE 8080
# DL4J UI first port
EXPOSE 9002 
# ModelHistoryServer port
EXPOSE 9100

CMD ["/deploy_model.sh"]
image.gif

在添加的文件中,有一个python脚本(deploy_model.py),它将与“skil-clientt”(skil的rest client api)交互以部署模型文件(model.pb)。另外,还有一个shell脚本(deploy_model.sh)来启动SKIL并执行python脚本并部署模型。
在这个用例中,SKIL嵌入到管道中,以部署Dockerfile旁边的data_directory中存在的经过训练的TensorFlow模型(名为output_graph.pb)。如果你没有一个冻结的TensorFlow模型,那么可以通过运行freeze_model.py脚本来训练MNIST模型。它将自动下载mnist数据集,训练模型并将其冻结到data_directory/output_graph.pbfile路径。

python freeze_model.py
image.gif

之后,你可以运行以下脚本来构建Docker镜像,以便SKIL部署和服务所需的模型。只需确保根据要部署的模型的配置更改输入和输出名称(如果使用的是其他模型)。你可以在这里更换。

docker build -t skymindops/skil-ce:mnist .

docker run --rm -it -p 9008:9008 -p 8080:8080 -p9100:9100 -p8888:8888 skymindops/skil-ce:mnist
image.gif

测试
现在,在日志显示“Model server started successfully!”,你可以请求部署在SKIL模型服务器上的模型。
测试前,确保安装了TensorFlow和skil-clients。你可以通过运行:

# Install pip if you don't have it (Uncomment the following two lines)
# curl "https://bootstrap.pypa.io/get-pip.py" -o "get-pip.py"
# python get-pip.py

# Install the libraries now
pip install --upgrade tensorflow
pip install skil-client
image.gif

如果部署的模型是来自freeze_graph.py脚本的模型,那么请求模式将如下所示:

from tensorflow.examples.tutorials.mnist import input_data

import pprint
import unittest

import numpy
import skil_client
from skil_client import *
from skil_client.rest import ApiException

work_directory = 'data_directory'
mnist = input_data.read_data_sets(work_directory, one_hot=True)

example_index = 10
input = mnist.test.images[example_index]
label = mnist.test.labels[example_index]

debug = False

host = "localhost" # 重命名这个为你正在使用的主机

config = Configuration()
config.host = "{}:9008".format(host)  # 如果你使用一个不同的端口则修改这里
config.debug = debug
api_client = ApiClient(configuration=config)
# create an instance of the API class
api_instance = skil_client.DefaultApi(api_client=api_client)

# authenticate
pp = pprint.PrettyPrinter(indent=4)
try:
    print("Authenticating with SKIL API...")
    credentials = skil_client.Credentials(user_id="admin", password="admin") # 用你的skil服务器使用的ID和密码更新此文件
    token = api_instance.login(credentials)
    pp.pprint(token)
    # add credentials to config
    config.api_key['authorization'] = token.token
    config.api_key_prefix['authorization'] = "Bearer"
except ApiException as e:
    print("Exception when calling DefaultApi->login: %s\n" % e)

deployment_name = "mnist"
model_name = "tf_model_mnist"

# Making the request
classification_response = api_instance.multipredict(
    deployment_name=deployment_name,
    model_name=model_name,
    body=MultiPredictRequest(
        id="12345",
        needs_pre_processing=False,
        inputs=[
            # This is the actual image data
            INDArray(
                ordering='c',
                shape=[int(len(input))],
                data=input.tolist()
            ),
            # This is the keep_prob placeholder data
            INDArray(
                ordering='c',
                shape=[1],
                data=[1.0]
            )
        ]
    )
)

pp.pprint(classification_response)
print('Actual Label: {}'.format(label))
image.gif

2. 多Zeppelin服务器

当SKIL启动时,它将在默认情况下创建一个zeppelin服务器。笔记本在zeppelin服务器内部运行。当zeppelin服务器执行笔记本时,它实际上不能做任何其他事情。此外,由于笔记本是全局的,因此,如果在一个笔记本中创建一个“foo”变量,其他使用其他笔记本的用户将可以看到它(并且可能会弄乱它们的代码)。所以,如果你想让多个人在一个skil集群中工作,你需要zeppelin服务器。
你可以使用skil zeppelinskil zeppelinInterpreter命令创建额外的zeppelin服务器。在最简单的形式中,用法如下:

# Uncomment the following lines if you don't have SKIL_HOME and JAVA_HOME variables set
# export SKIL_HOME=/opt/skil
# export JAVA_HOME=/usr/lib/jvm/java-1.8.0-openjdk

# Authenticating first 
$SKIL_HOME/sbin/skil login --userId admin --password admin # You might have a different userId and password, replace them accordingly.

# Creating a zeppelin server
$SKIL_HOME/sbin/skil zeppelin --name Zeppelin2 --interpreterPort 6560 --zeppelinPort 8140

# Creating the interpreter process
$SKIL_HOME/sbin/skil zeppelinInterpreter --interpreterPort 6560
image.gif

你可以连接到端口8140上的新Zeppelin服务器,就像连接到默认的Zeppelin实例一样。你还可以在skil用户界面的“进程(PROCESSES)”选项卡下查看新的Zeppelin解释器进程。还可以使用以下命令查看进程列表。

$SKIL_HOME/sbin/skil processes
image.gif

Docker容器

要在Docker容器中运行新的Zeppelin服务器,只需取消对deploy_model.sh脚本中的以下行的注释。

Zeppelin 服务器的默认参数

zeppelin和zeppelinInterpreter子命令的其他参数及其默认值为:

对于 "skil zeppelin"

| 参数 | 默认值 |
| master | local[*] |
| zeppelinHost | 0.0.0.0 |
| zeppelinPort | 8080 |
| zeppelinUserName | admin |
| zeppelinPassword | admin |
| zeppelinMemory | 1000 |
| zeppelinHome | /tmp/zeppelinhome |
| zeppelinNotebookDirectory | /tmp/zeppelinhome/notebooks |
| zeppelinWarDir | /tmp/zeppelinhome |
| zeppelinConfDir | /tmp/zeppelinhome/conf |
| zeppelinBinDir | /tmp/zeppelinhome/bin |
| zeppelinInterpreterDir | /tmp/zeppelinhome/interpreter |
| zeppelinLocalRepo |
/tmp/zeppelinhome/local-repo |
| deleteInterpreterRepoOnStartup | False |
| interpreterPort | 6500 |
| zeppelinLogFile | /tmp/zeppelinhome/zeppelin.log |

对于 "skil zeppelinInterpreter"

| 参数 | 默认值 |
| zeppelinHome | /tmp/zeppelinhome |
| zeppelinInterpreterDir |
/tmp/zeppelinhome/interpreter |
| interpreterPort | 6500 |

SKIL CLI

有关如何编写SKIL脚本的更多选项,请查看 SKIL CLI.

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,732评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,496评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,264评论 0 338
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,807评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,806评论 5 368
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,675评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,029评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,683评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 41,704评论 1 299
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,666评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,773评论 1 332
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,413评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,016评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,978评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,204评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,083评论 2 350
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,503评论 2 343

推荐阅读更多精彩内容