MXNet Model Server (MMS) can be used with any container service. In this guide, you will learn how to run MMS with Docker.
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
...
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
We have 5 containers tags available on Docker Hub.
- latest: This will be the same as
mxnet-model-server:1.0.0-mxnet-cpu
. This tag will be available after an official release. - 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.
- 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.
- 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.
- 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
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
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
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
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
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
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.
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
},
...
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