A containerized service for neural machine translation
Project description
sockeye-serving
sockeye-serving
is a containerized service for neural machine translation that uses Amazon's sockeye
framework as the translation engine.
The web server makes use of mxnet-model-server
, which provides a management API for loading models and a prediction API for requesting translations.
Any Sockeye model can be loaded via the management API. Text preprocessing is built into the request pipeline and supports a wide variety of languages. Specialized processing for specific languages can be implemented using custom handlers.
Getting Started With Docker
This example shows how to serve an existing model for Chinese to English translation. First, pull the latest Docker image:
docker pull jwoo11/sockeye-serving
Download the example model archive (MAR). This is a ZIP archive containing the parameter files and scripts needed to run translation:
Extract the MAR file to /tmp/models
.
This directory will be the source for a bind mount for Docker:
unzip -d /tmp/models/zh zh.mar
Start the server:
docker run -itd --name sockeye_serving -p 8080:8080 -p 8081:8081 -v /tmp/models:/opt/ml/model jwoo11/sockeye-serving
Now, load the model using the management API. Note that the URL of the model is relative to the bind mount:
curl -X POST "http://localhost:8081/models?synchronous=true&initial_workers=1&url=zh"
Get the status of the model with the following:
curl -X GET "http://localhost:8081/models/zh"
The response should look like this:
{
"modelName": "zh",
"modelUrl": "zh",
"runtime": "python3",
"minWorkers": 1,
"maxWorkers": 1,
"batchSize": 1,
"maxBatchDelay": 100,
"workers": [
{
"id": "9000",
"startTime": "2019-01-26T00:49:10.431Z",
"status": "READY",
"gpu": false,
"memoryUsage": 601395200
}
]
}
To translate text use the inference API. Notice that the port is different from above.
curl -X POST "http://localhost:8080/predictions/zh" -H "Content-Type: application/json" \
-d '{ "text": "我的世界是一款開放世界遊戲,玩家沒有具體要完成的目標,即玩家有超高的自由度選擇如何玩遊戲" }'
The translation quality depends on the model. The provided model returns this translation:
{
"translation": "in my life was a life of a life of a public public, and a public, a time, a video, a play, which, it was a time of a time of a time."
}
A better model trained on more data returns this response:
{
"translation": "My world is an open world game, and players have no specific goal to accomplish, that is, players have a high degree of freedom to choose how to play."
}
Command Line Interface
You can use scripts/sockeye_serving
to easily start and stop Docker and to make REST calls to both the management and prediction APIs.
Configurable properties are located in scripts/sockeye_serving.properties
.
To show the help message for the script, run:
scripts/sockeye_serving help
Switching between CPUs and GPUs
You can use the command line interface to specify that a model should use either CPUs or GPUs.
If the flag --use-cpu
is in config/sockeye-args.txt
, then CPUs will be used for translation.
Otherwise, GPUs will be used.
After changing the configuration, update the model and deploy it:
scripts/sockeye_serving update zh
scripts/sockeye_serving deploy zh
Enabling TLS
The provided configuration instructs the server to use plain HTTP. To enable TLS, you can either supply a Java keystore or a private key and certificate in PEM format.
Using config/config.properties
as a starting point, create a new config.properties
file and save it under /tmp/models
:
model_store=/opt/ml/model
inference_address=https://0.0.0.0:8443
management_address=https://0.0.0.0:8444
Suppose you have a key pair residing on the host at /path/to/certs
.
Set the properties for the keystore:
keystore=/path/to/certs/keystore.p12
keystore_pass=changeit
keystore_type=PKCS12
Or provide the path to the server's private key and certificate:
private_key_file=/path/to/certs/private.key
certificate_file=/path/to/certs/cert.pem
Then start the container:
docker run -itd --name sockeye_serving -p 8443:8443 -p 8444:8444 \
-v /path/to/certs:/path/to/certs \
-v /tmp/models:/opt/ml/model jwoo11/sockeye-serving \
mxnet-model-server --start --mms-config /opt/ml/model/config.properties
To make requests using curl
you should ensure that you set --cert
, --key
, and --cacert
as needed.
Additional Documentation
For more information on mxnet-model-server
, see:
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Hashes for sockeye_serving-1.0.0-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 614e0632a06d470b6be133f8f753eea1003a2f4fac97467b6d70b32230c466f6 |
|
MD5 | f3006b356d4728d6a69a84d41cc40618 |
|
BLAKE2b-256 | 487dcfc09928d707f662be30bb02a2221b552d14afa11de72e80b50fecb8a873 |