Skip to content

Latest commit

 

History

History
204 lines (152 loc) · 9.95 KB

README.md

File metadata and controls

204 lines (152 loc) · 9.95 KB

Using Containers with MXNet Model Server

MXNet Model Server (MMS) can be used with any container service. In this guide, you will learn how to run MMS with Docker.

Contents of this Document

Other Relevant Documents

Quickstart

Running MXNet Model Server with Docker in two steps:

Step 1: Run the Docker image.

This will download the MMS Docker image and run its default configuration, serving a SqueezeNet model.

docker run -itd --name mms -p 80:8080 -p 8081:8081 awsdeeplearningteam/mxnet-model-server:1.0.1-mxnet-cpu mxnet-model-server --start --models squeezenet=https://s3.amazonaws.com/model-server/model_archive_1.0/squeezenet_v1.1.mar

With the -p flag, we're setting it up so you can run the Predict API on your host computer's port 80. This maps to the Docker image's port 8080. It will run the Management API on your host computer's port 8081. This maps to the Docker image's port 8081.

Step 2: Test inference.

curl -O https://s3.amazonaws.com/model-server/inputs/kitten.jpg
curl -X POST http://127.0.0.1/predictions/squeezenet -T kitten.jpg

After fetching this image of a kitten and posting it to the predict endpoint, you should see a response similar to the following:

{
  "prediction": [
    [
      {
        "class": "n02124075 Egyptian cat",
        "probability": 0.9408261179924011
...

Cleaning Up

Now that you have tested it out, you may stop the Docker container. The following command will stop the server and delete the container. It will retain the Docker image for trying out other models and configurations later.

docker rm -f mms

Available pre-built continers

We have 5 containers tags available on Docker Hub.

  1. latest: This will be the same as mxnet-model-server:1.0.0-mxnet-cpu. This tag will be available after an official release.
  2. 1.0.1-mxnet-cpu: This will be the official CPU container based on the Dockerfile.cpu. This tag will be available after an official 1.0 release.
  3. 1.0.1-mxnet-gpu: This will be the official GPU container based on the Dockerfile.gpu. This tag will be available after an official 1.0 release.
  4. nightly-mxnet-cpu: This will be the official CPU container which is built based on the nightly release of MMS pip package. This will be built from Dockerfile.nightly-cpu.
  5. nightly-mxnet-gpu: This will be the official GPU container which is built based on the nightly release of MMS pip package. This will be built from Dockerfile.nightly-gpu.

To pull the a particular container, run the following command

Pulling the latest tag:

Docker pull by default pulls the latest tag. This tag isn't available until after an official release.

docker pull awsdeeplearningteam/mxnet-model-server # This gets the latest release which is the same as 1.0.1-mxnet-cpu

Pulling the 1.0.1-mxnet-cpu tag:

To pull a official 1.0 MMS CPU container run the following command. This tag isn't available until after an official release.

docker pull awsdeeplearningteam/mxnet-model-server:1.0.1-mxnet-cpu 

Pulling the 1.0.1-mxnet-gpu tag:

To pull a official 1.0 MMS GPU container run the following command. This tag isn't available until after an official release.

docker pull awsdeeplearningteam/mxnet-model-server:1.0.1-mxnet-gpu 

Pulling the nightly-mxnet-cpu tag:

To pull a official latest 1.0 MMS CPU container run the following command. This track the pre-release version of MMS. We do not recommend running this container in production setup.

docker pull awsdeeplearningteam/mxnet-model-server:nightly-mxnet-cpu

Pulling the nightly-mxnet-gpu tag:

To pull a official latest 1.0 MMS GPU container run the following command. This track the pre-release version of MMS. We do not recommend running this container in production setup.

docker pull awsdeeplearningteam/mxnet-model-server:nightly-mxnet-gpu

Configuring MMS with Docker

In the Quickstart section, you launched a Docker image with MMS serving the SqueezeNet model. Now you will learn how to configure MMS with Docker to run other models. You will also learn how to collect MMS logs, and optimize MMS with Docker images.

Using MMS and Docker with a Shared Volume

You may sometimes want to load different models with a different configuration. Setting up a shared volume with the Docker image is the recommended way to handle this.

Step 1: Create a folder to share with the Docker container.

Create a directory for models. This will also provide a place for log files to be written.

mkdir /tmp/models

Step 2: Download the configuration template.

Download the template config.properties and place it in the models folder you just created:

Step 3: Modify the configuration template.

Edit the file you downloaded, config.properties.

# vmargs=-Xmx1g -XX:MaxDirectMemorySize=512m -Dlog4j.configuration=file:///opt/ml/conf/log4j.properties
model_store=/models
# load_models=ALL
inference_address=http://0.0.0.0:8080
management_address=http://0.0.0.0:8081
# number_of_netty_threads=0
# max_workers=0
# job_queue_size=1000
# number_of_gpu=1
# keystore=src/test/resources/keystore.p12
# keystore_pass=changeit
# keystore_type=PKCS12
# private_key_file=src/test/resources/key.pem
# certificate_file=src/test/resources/certs.pem

Modify the configuration file to suite your configuration needs before running the model server.

Save the file.

Step 4: Run MMS with Docker using a shared volume.

When you run the following command, the -v argument and path values of /tmp/models/:/models will map the Docker image's models folder to your local /tmp/models folder. MMS will then be able to use the local model file.

docker run -itd --name mms -p 80:8080 -p 8081:8081 -v /tmp/models/:/models awsdeeplearningteam/mxnet-model-server:1.0.1-mxnet-cpu mxnet-model-server --start --models squeezenet=https://s3.amazonaws.com/model-server/model_archive_1.0/resnet-18.mar

NOTE: If you modify the inference_address or the management_address in the configuration file, you must modify the ports exposed by Docker as well.

Step 5: Test inference.

You will upload the same kitten image as before, but this time you will request the predictions/resnet API endpoint.

curl -X POST http://127.0.0.1/predictions/resnet -T @kitten.jpg

Given that this is a different model, the same image yields a different inference result which will be something similar to the following:

{
  "prediction": [
    [
      {
        "class": "n02123159 tiger cat",
        "probability": 0.3630334138870239
      },
...

Conclusion

You have tried the default Predictions API settings using a SqueezeNet model. You then configured your Predictions API endpoints to also serve a ResNet-18 model. Now you are ready to try some other more advanced settings such as:

  • GPU inference
  • MMS settings
  • Optimizing inference with gunicorn configurations

Next Step: Advanced Settings