description |
---|
Describes the components that make up Konduit-Serving |
Konduit-Serving has many internal components that work together to achieve the desired result. Following are the main concepts and components that make up Konduit-Serving:
- CLI
- Jar Package
- Pipelines
- Pipeline Step
- Inference Configuration
This page will go through each one of them and explain what they are used for.
Konduit-Serving comes with a CLI interface (with a konduit
alias) that's responsible for taking care of most aspects of the application. The help command will describe most of what we are able to do with Konduit-Serving. Executing konduit --help
command will show us the following output:
$ konduit --help
---------------------------------------------------------------------------
Usage: konduit [COMMAND] [OPTIONS] [arg...]
Commands:
build Command line interface for performing Konduit Serving builds.
config A helper command for creating boiler plate json/yaml for
inference configuration
inspect Inspect the details of a particular konduit server.
list Lists the running konduit servers.
logs View the logs of a particular konduit server
predict Run inference on konduit servers using given inputs
profile Command to List, view, edit, create and delete konduit
serving run profiles.
pythonpaths A utility command to manage system installed and manually
registered python binaries.
serve Start a konduit server application
stop Stop a running konduit server
version Displays konduit-serving version.
Run 'konduit COMMAND --help' for more information on a command.
---------------------------------------------------------------------------
Each command describes its shorthand description right in front of it. If you want to look at an individual command in detail, you can use the corresponding --help command with them. For example, the help menu for the logs command can be seen by executing, konduit logs --help:
$ konduit logs --help
---------------------------------------------------------------------------
Usage: konduit logs [-f] [-l <value>] server-id
View the logs of a particular konduit server
View the logs of a particular konduit server given an id.
Example usages:
--------------
- Outputs the log file contents of server with an id of 'inf_server':
$ konduit logs inf_server
- Outputs and tail the log file contents of server with an id of 'inf_server':
$ konduit logs inf_server -f
- Outputs and tail the log file contents of server with an id of 'inf_server'
from the last 10 lines:
$ konduit logs inf_server -l 10 -f
--------------
Options and Arguments:
-f,--follow Follow the logs output.
-l,--lines <value> Sets the number of lines to be printed. Default is '10'.
Use -1 for outputting everything.
<server-id> Konduit server id
---------------------------------------------------------------------------
As can be seen, the --help command for an individual help command describes its functionality in detail along with some explicit examples and use cases. It also describes each individual optional/non-optional argument that can be used with it. This can come in very handy while learning about konduit-serving for the first time and is a useful starting place to play around with a specific command. You can do the same for the rest of the commands. Which are:
- build
- config
- inspect
- list
- logs
- predict
- metrics
- profile
- pythonpaths
- serve
- stop
- version
Each Konduit-Serving distribution whether it is for Windows, Linux or MacOS comes contained in a JAR file. So, you'll need a Java Virtual Machine present in the system where you're using Konduit-Serving as a Model Pipeline Server. The CLI itself is linked with the jar file and utilizes a java runtime internally to interact with the Konduit-Serving package. If you look at the konduit serving distribution, you'll see the following folder architecture in the root folder:
The main CLI logic is places under bin/konduit file, which contains the following content:
#!/usr/bin/env bash
SCRIPT_DIR="$(dirname "$0")"
. ${SCRIPT_DIR}/../conf/konduit-serving-env.sh
java -jar -Dvertx.cli.usage.prefix=konduit ${SCRIPT_DIR}/../konduit.jar "$@"
As you can see, it uses the java command which is available through a Java runtime environment. The java command itself uses the konduit.jar file which is the main application package inside a Konduit-Serving distribution.
This JAR file will be used as a Java application dependency while creating custom endpoints logic for a Konduit-Serving pipeline. We'll get to how we can do that later in this notebook.
Throughout this document the term "Model Serving Pipeline" has been used. This refers to how Machine Learning or Deep Learning models get served on an application server. Machine/Deep Learning models work on n-dimensional arrays (also known as ND-Arrays). They don't know how to convert a JPEG or PNG image into numbers directly. Instead, they expect pre-processed data in the form of a multidimensional array. Also, any other form of data, be it text, audio or video, gets converted into numbers ND-Arrays before getting fed into a machine learning model.
The process during which the data is converted from one form to another is called pre-processing and is done just before it's fed as a model input. So, in a sense you can see this as being Lego blocks fitting into each other. One part takes input in a specific form and outputs it into another form, which in turn gets fed into the next part. This chaining of processes creates a series of steps which have specific jobs to perform before the next step and the end result is a machine learning Pipeline. The typical flow of the pipeline looks like the following:
A pipeline can also be in the form of a directed acyclic graph or DAG where data can flow into the graph and can give multiple outputs. In Konduit-Serving a Pipeline graph can also contain optional graph branches and can also concatenate outputs from multiple graph nodes. For the sake of the current goal (BMI Model Serving) we'll stick to a Sequential Pipeline which only has one input and one output.
Inside Konduit-Serving, a pipeline can be broken down into steps, where each step is responsible for performing a specific function. A pipeline step is the smallest component of a whole pipeline and can be used for a whole list of operations. To see the list of available pipeline steps you can use the config command in Konduit-Serving CLI.
$ konduit config --help
---------------------------------------------------------------------------
Usage: konduit config [-m] [-o <output-file>] -p <config> [-pr <value>] [-y]
A helper command for creating boilerplate json/yaml for inference configuration
This command is a utility to create boilerplate json/yaml configurations that can be conveniently modified to start konduit servers.
Example usages:
--------------
-- FOR SEQUENCE PIPELINES--
- Prints 'logging -> tensorflow -> logging' config in pretty format:
$ konduit config -p logging,tensorflow,logging
- Prints 'logging -> tensorflow -> logging' config with gRPC protocol
in pretty format:
$ konduit config -p logging,tensorflow,logging -pr grpc
- Prints 'dl4j -> logging' config in minified format:
$ konduit config -p dl4j,logging -m
- Saves 'dl4j -> logging' config in a 'config.json' file:
$ konduit config -p dl4j,logging -o config.json
- Saves 'dl4j -> logging' config in a 'config.yaml' file:
$ konduit config -p dl4j,logging -y -o config.json
-- FOR GRAPH PIPELINES --
- Generates a config that logs the input(1) then flow them through two
tensorflow models(2,3) and merges the output(4):
$ konduit config -p
1=logging(input),2=tensorflow(1),3=tensorflow(1),4=merge(2,3)
- Generates a config that logs the input(1) then channels(2) them through one
of the two tensorflow models(3,4) and then selects the output(5) based
on the value of the selection integer field 'select'
$ konduit config -p
1=logging(input),[2_1,2_2]=switch(int,select,1),3=tensorflow(2_1),4=tensorflow(2_2),5=any(3,4)
- Generates a config that logs the input(1) then channels(2) them through one
of the two tensorflow models(3,4) and then selects the output(5) based
on the value of the selection string field 'select' in the selection map
(x:0,y:1).
$ konduit config -p 1=logging(input),[2_1,2_2]=switch(string,select,x:0,y:1,1),3=tensorflow(2_1),4=tensorflow(2_2),5=any(3,4)
--------------
Options and Arguments:
-m,--minified If set, the output json will be printed in a
single line, without indentations. (Ignored
for yaml)
-o,--output <output-file> Optional: If set, the generated json/yaml will
be saved here. Otherwise, it's printed on the
console.
-p,--pipeline <config> A comma-separated list of sequence/graph
pipeline
steps to create boilerplate configuration
from. For
sequences, allowed values are: [crop_grid,
crop_fixed_grid, dl4j, keras,
Draw_bounding_box, draw_fixed_grid, draw_grid,
draw_segmentation,extract_bounding_box,
Camera_frame_capture, video_frame_capture,
Image_to_ndarray, logging,
ssd_to_bounding_box, samediff, show_image,
tensorflow, nd4jtensorflow, python, onnx].
For graphs, the list item should be in the
format
'<output>=<type>(<inputs>)' or
'[outputs]=switch(<inputs>)' for switches. The
pre-defined root input is named, 'input'.
Examples
are ==> Pipeline step:
'a=tensorflow(input),b=dl4j(input)' Merge
Step:
'c=merge(a,b)' Switch Step (int):
'[d1,d2,d3]=switch(int,select,input)' Switch
Step
(string):
'[d1,d2,d3]=switch(string,select,x:1,y:2,z:3,input)'
'Any Step: 'e=any(d1,d2,d3)' See the examples
above for more usage information.
-pr,--protocol <value> Protocol to use with the server. Allowed
values are
[http, grpc, mqtt]
-y,--yaml Set if you want the output to be a yaml
configuration.
---------------------------------------------------------------------------
config command can take a pipeline pattern string and creates a pipeline configuration as well as server configuration. The server configuration combined with pipeline step configuration is collectively called Inference Configuration in Konduit-Serving. This is the final output from the config command.
The following pipeline step types can be used to configure a pipeline configuration.
# | Pipeline Step Type Name | Description |
---|---|---|
01 | CROP_GRID | A pipeline step that crops sub images out of a larger image, based on a grid. |
02 | CROP_FIXED_GRID | This step is similar to CROP_GRID with the difference that the x/y location values are hardcoded into the configuration, instead of coming dynamically from the input Data instance. |
03 | DL4J | A model pipelinestep that serves a DL4J model. |
04 | KERAS | A model pipeline step that serves a Keras model. |
05 | DRAW_BOUNDING_BOX | A pipeline step that configures how to draw a bounding box onto an image. The bounding box data, that's to be drawn, is taken from the previous step's data instance. |
06 | DRAW_GRID | Draw a grid on the specified image, based on the x/y coordinates of the corners, and the number of segments within the grid in both directions. |
07 | DRAW_FIXED_GRID | A pipeline step that draws a grid on an image. This is similar to DRAW_GRID but the corner x/y location values are hardcoded into the configuration (via points), instead of coming dynamically from the input Data instance. |
08 | DRAW_SEGMENTATION | A pipeline step that configures how to draw a segmentation mask, optionally on an image. |
09 | EXTRACT_BOUNDING_BOX | A pipeline step that extracts sub-images from an input image, based on the locations of input bounding boxes. |
10 | CAMERA_FRAME_CAPTURE | A pipeline step that specifies an input that's taken from a camera feed. |
11 | VIDEO_FRAME_CAPTURE | A pipeline step that configures how to extract a single frame from a video each time inference is called. The video path is hardcoded, mainly used for testing/demo purposes. |
12 | IMAGE_TO_NDARRAY | A PipelineStep for converting images to n-dimensional arrays. |
13 | LOGGING | A step that logs the key and value pairs coming from the previous steps. |
14 | SSD_TO_BOUNDING_BOX | A pipeline step that configures extraction of bounding boxes from an SSD model output. |
15 | SAMEDIFF | A model pipeline step that serves a SameDiff model. |
16 | SHOW_IMAGE | A pipeline step that configures how to show/render an image from a previous step in an application frame. Usually only used for testing and debugging locally, not when serving from HTTP/GRPC etc endpoints. |
17 | TENSORFLOW | A model pipeline step that serves a TensorFlow model using Tensorflow Java API. This is packaged into Konduit-Serving through JavaCPP. |
18 | ND4JTENSORFLOW | A pipeline step that configures a TensorFlow model that is to be executed based on an ND4J graph runner. This has performance benefits over native TensorFlow Java distribution. |
19 | PYTHON | This pipeline step can take an arbitrary python script and serve that through Konduit-Serving. |
20 | ONNX | A model pipeline step that serves a ONNX model. |
Inference configuration contains all the details about how the pipeline server should be setup, which protocol it’s supposed to use for sending in/out data, whether we have a sequential or graph pipeline and finally how the pipeline is configured. The config command outputs inference configuration for us that can be directly used with a serve command after necessary changes are made. An Example of inference configuration through config command is as follows:
$ konduit config --pipeline logging --yaml
---------------------------------------------------------------------------
---
host: "localhost"
port: 0
use_ssl: false
protocol: "HTTP"
kafka_configuration:
start_http_server_for_kafka: true
http_kafka_host: "localhost"
http_kafka_port: 0
consumer_topic_name: "inference-in"
consumer_key_deserializer_class: "io.vertx.kafka.client.serialization.JsonObjectDeserializer"
consumer_value_deserializer_class: "io.vertx.kafka.client.serialization.JsonObjectDeserializer"
consumer_group_id: "konduit-serving-consumer-group"
consumer_auto_offset_reset: "earliest"
consumer_auto_commit: "true"
producer_topic_name: "inference-out"
producer_key_serializer_class: "io.vertx.kafka.client.serialization.JsonObjectSerializer"
producer_value_serializer_class: "io.vertx.kafka.client.serialization.JsonObjectSerializer"
producer_acks: "1"
mqtt_configuration: {}
custom_endpoints: []
pipeline:
steps:
- '@type': "LOGGING"
logLevel: "INFO"
log: "KEYS_AND_VALUES"
---------------------------------------------------------------------------
The above command creates a yaml configuration for a logging pipeline step. Logging pipeline step just takes in an input from the previous pipeline step and outputs (and logs on console) the same information. This is useful for debugging issues in the running servers.
This configuration can be saved inside a file by executing the following:
$ konduit config --pipeline logging --yaml --output server-conf.yaml
---------------------------------------------------------------------------
Config file created successfully at /root/server-conf.yaml
---------------------------------------------------------------------------
Afterwards, this configuration can be used with the serve command to start a Konduit-Serving server. Example is following:
$ konduit serve --config server-conf.yaml -id server --background --runWithoutManifest
---------------------------------------------------------------------------
Starting konduit server...
Using classpath: /root/konduit/bin/../konduit.jar
INFO: Running command /root/miniconda/jre/bin/java -Dkonduit.logs.file.path=/root/.konduit-serving/command_logs/server.log -Dlogback.configurationFile=/tmp/logback-run_command_4b1acb956d0d436c.xml -jar /root/konduit/bin/../konduit.jar run --instances 1 -s inference -c server-conf.yaml -Dserving.id=server
For server status, execute: 'konduit list'
For logs, execute: 'konduit logs server'
---------------------------------------------------------------------------