Skip to content

Latest commit

 

History

History
142 lines (134 loc) · 9.19 KB

README.md

File metadata and controls

142 lines (134 loc) · 9.19 KB

Introduction

This repository contains the source code of the AWS Neuron TensorFlow integration project. It primarily serves the purpose of demonstrating how to integrate AWS Neuron into an existing, self-maintained fork of TensorFlow. For detailed usage and examples on integrating your TensorFlow based deep learning applications with AWS Neuron, please refer to the AWS Neuron SDK main documentation site.

Build AWS Neuron TensorFlow integration

Here are the steps for building AWS Neuron TensorFlow integration. It is available in the following two forms.

  1. tensorflow-neuron pip whl, a Python package that adds on top of tensorflow.
  2. tensorflow_model_server_neuron binary executable, a special build of TensorFlow Serving (tf-serving).

The AWS Neuron runtime is integrated into TensorFlow as a TensorFlow custom operator, namely NeuronOp, without any modification to the core TensorFlow code. As a result, AWS customers may bring in their own fork of TensorFlow, potentially with their own modifications, and expect it to work with AWS Neuron seemlessly together.

The open source distribution of tensorflow-neuron requires deb/rpm package aws-neuronx-runtime-lib at run-time. For more information, please refer to Introducing Packaging and installation changes and AWS Neuron Runtime 2.x (libnrt.so).

Install build tool

We recommend Bazelisk which is "a user-friendly launcher for Bazel".

  1. Install Bazelisk (from [https://github.com/bazelbuild/bazelisk#installation]) and name it as bazel
    1. mkdir -p $HOME/bin
    2. curl -L https://github.com/bazelbuild/bazelisk/releases/download/v1.14.0/bazelisk-linux-amd64 --output $HOME/bin/bazel
    3. chmod +x $HOME/bin/bazel
    4. export PATH=$PATH:$HOME/bin
    5. Verify by running bazel version

Build procedures

tensorflow-neuron 2.x pip whl

  1. Install Python3 developer package
    • On Debian-based OS (e. g., Ubuntu): sudo apt install python3-dev python3-pip python3-venv
    • On AmazonLinux2 or other CentOS-based OS: sudo yum install python3-devel python3-pip
  2. Setup build venv and install dependencies
    1. python3 -m venv env_tfn
    2. source ./env_tfn/bin/activate
    3. pip install pip -U
    4. pip install numpy==1.20.0 wheel six
    5. pip install keras_preprocessing --no-deps
  3. Clone tensorflow source code and setup tensorflow-neuron directory
    1. git clone https://github.com/tensorflow/tensorflow.git -b v2.8.3 tensorflow
    2. git clone https://github.com/aws/aws-neuron-tensorflow ./tensorflow/tensorflow/neuron
  4. Build tensorflow-neuron pip whl
    1. cd tensorflow
    2. ./configure
    3. bazel build --cxxopt="-D_GLIBCXX_USE_CXX11_ABI=0" //tensorflow/neuron:build_pip_package
    4. ./bazel-bin/tensorflow/neuron/build_pip_package ./
    5. pip whl can be found by ls tensorflow_neuron-*.whl
  5. (Optional) Validate the tensorflow-neuron pip whl on an inf1 instance with pre-installed aws-neuronx-dkms and aws-neuronx-runtime-lib
    1. Copy tensorflow_neuron-*.whl to the inf1 instance's $HOME directory, e. g. scp tensorflow_neuron-*.whl my_inf1:~/
    2. On the inf1 instance:
      1. mkdir ~/rundir
      2. cd ~/rundir
      3. python3 -m venv env_tfn
      4. source ./env_tfn/bin/activate
      5. pip install pip -U
      6. pip install pytest
      7. pip install neuron-cc ~/tensorflow_neuron-*.whl --extra-index-url=https://pip.repos.neuron.amazonaws.com
      8. pytest --pyargs tensorflow_neuron -k 'custom or dot or batchnorm', all tests should pass.

tensorflow_model_server_neuron 2.x binary executable

We recommend building and running tensorflow_model_server_neuron on docker image tensorflow/serving:2.8.3-devel which includes the source code of tf-serving 2.8.3 and its entire build dependency environment. To install docker, please refer to https://docs.docker.com/engine/install/.

  1. docker run -it --rm -v $(pwd):/host_workspace tensorflow/serving:2.8.3-devel bash
  2. git clone https://github.com/aws/aws-neuron-tensorflow ./tensorflow_serving/neuron
  3. sed -i 's/SUPPORTED_TENSORFLOW_OPS = /SUPPORTED_TENSORFLOW_OPS = ["\/\/tensorflow_serving\/neuron\/runtime:all_ops"] + /g' ./tensorflow_serving/model_servers/BUILD
    • If the sed command fails to execute, you may choose to manually edit tensorflow_serving/model_servers/BUILD to let SUPPORTED_TENSORFLOW_OPS include Bazel target "//tensorflow_serving/neuron/runtime:all_ops".
  4. bazel build //tensorflow_serving/model_servers:tensorflow_model_server
  5. install bazel-bin/tensorflow_serving/model_servers/tensorflow_model_server ./tensorflow_model_server_neuron
  6. Verify by installing aws-neuronx-runtime-lib and running tensorflow_model_server_neuron
    1. echo "deb [trusted=yes] https://apt.repos.neuron.amazonaws.com bionic main" > /etc/apt/sources.list.d/neuron.list
    2. apt-get update && apt-get install -y aws-neuronx-runtime-lib
    3. ./tensorflow_model_server_neuron --help

tensorflow-neuron 1.x pip whl

  1. Install Python3 developer package
    • On Debian-based OS (e. g., Ubuntu): sudo apt install python3-dev python3-pip python3-venv
    • On AmazonLinux2 or other CentOS-based OS: sudo yum install python3-devel python3-pip
  2. Setup build venv and install dependencies
    1. python3 -m venv env_tfn
    2. source ./env_tfn/bin/activate
    3. pip install pip -U
    4. pip install numpy==1.18.5 wheel six
    5. pip install keras_preprocessing --no-deps
  3. Clone tensorflow source code and setup tensorflow-neuron directory
    1. git clone https://github.com/tensorflow/tensorflow.git -b v1.15.5 tensorflow
    2. git clone https://github.com/aws/aws-neuron-tensorflow ./tensorflow/tensorflow/neuron
  4. Build tensorflow-neuron pip whl
    1. cd tensorflow
    2. git checkout refs/tags/v1.15.5
    3. USE_BAZEL_VERSION=0.26.1 ./configure
    4. USE_BAZEL_VERSION=0.26.1 bazel build --incompatible_remap_main_repo --cxxopt="-D_GLIBCXX_USE_CXX11_ABI=0" //tensorflow/neuron:build_pip_package
    5. ./bazel-bin/tensorflow/neuron/build_pip_package ./
    6. pip whl can be found by ls tensorflow_neuron-*.whl
  5. (Optional) Validate the tensorflow-neuron pip whl
    1. mkdir ../rundir
    2. cd ../rundir
    3. pip install pytest
    4. pip install neuron-cc ../tensorflow/tensorflow_neuron-*.whl --extra-index-url=https://pip.repos.neuron.amazonaws.com
    5. env NEURON_TF_COMPILE_ONLY=1 pytest --pyargs tensorflow_neuron, all tests should pass.
      • If tests are running on inf1 instances with pre-installed aws-neuronx-dkms and aws-neuronx-runtime-lib, then you may simply run pytest --pyargs tensorflow_neuron and expect all tests passing.
      • Known issue: if you have h5py>=3 installed, some Keras related tests may fail due to tensorflow/tensorflow#44467

tensorflow_model_server_neuron 1.x binary executable

We recommend building and running tensorflow_model_server_neuron on docker image tensorflow/serving:1.15.0-devel which includes the source code of tf-serving 1.15.0 and its entire build dependency environment. To install docker, please refer to https://docs.docker.com/engine/install/.

  1. docker run -it --rm -v $(pwd):/host_workspace tensorflow/serving:1.15.0-devel bash
  2. git clone https://github.com/aws/aws-neuron-tensorflow ./tensorflow_serving/neuron
  3. git apply ./tensorflow_serving/neuron/runtime/serving_neuron_op.diff
    • All this patch does is to register NeuronOp into tf-serving by adding the following line of code into Bazel BUILD file tensorflow_serving/model_servers/BUILD.
    SUPPORTED_TENSORFLOW_OPS.append("//tensorflow_serving/neuron/runtime:all_ops")
    
    • If the patch fails to apply due to file content conflicts, you may choose to manually edit tensorflow_serving/model_servers/BUILD to let SUPPORTED_TENSORFLOW_OPS include Bazel target "//tensorflow_serving/neuron/runtime:all_ops".
  4. bazel build //tensorflow_serving/model_servers:tensorflow_model_server
  5. install bazel-bin/tensorflow_serving/model_servers/tensorflow_model_server ./tensorflow_model_server_neuron
  6. Verify by installing aws-neuronx-runtime-lib and running tensorflow_model_server_neuron
    1. echo "deb [trusted=yes] https://apt.repos.neuron.amazonaws.com bionic main" > /etc/apt/sources.list.d/neuron.list
    2. apt-get update && apt-get install -y aws-neuronx-runtime-lib
    3. ./tensorflow_model_server_neuron --help