# Copyright (c) 2022 PaddlePaddle Authors. All Rights Reserved. # # Licensed under the Apache License, Version 2.0 (the "License"); # you may not use this file except in compliance with the License. # You may obtain a copy of the License at # # http://www.apache.org/licenses/LICENSE-2.0 # # Unless required by applicable law or agreed to in writing, software # distributed under the License is distributed on an "AS IS" BASIS, # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. # See the License for the specific language governing permissions and # limitations under the License. FROM graphcore/poplar:3.0.0 #Install the build dependencies RUN apt-get update && apt-get install -y --no-install-recommends curl wget vim git patchelf python3-dev python3-pip \ python3-setuptools build-essential libgl1-mesa-glx libglib2.0-dev ca-certificates \ libssl-dev zlib1g-dev rapidjson-dev libboost-dev libre2-dev librdmacm-dev libnuma-dev libarchive-dev unzip && \ apt-get clean && rm -rf /var/lib/apt/lists/* RUN ln -s /usr/bin/python3 /usr/bin/python; RUN pip3 install --upgrade pip # install cmake WORKDIR /home RUN wget -q https://github.com/Kitware/CMake/releases/download/v3.18.6/cmake-3.18.6-Linux-x86_64.tar.gz && tar -zxvf cmake-3.18.6-Linux-x86_64.tar.gz ENV PATH=/home/cmake-3.18.6-Linux-x86_64/bin:$PATH #install triton ENV TAG=r21.10 RUN git clone https://github.com/triton-inference-server/server.git -b $TAG && \ cd server && \ mkdir -p build/tritonserver/install && \ python3 build.py \ --build-dir `pwd`/build \ --no-container-build \ --endpoint=grpc \ --enable-logging \ --enable-stats \ --cmake-dir `pwd`/build \ --repo-tag=common:$TAG \ --repo-tag=core:$TAG \ --repo-tag=backend:$TAG \ --repo-tag=thirdparty:$TAG \ --backend=python:$TAG COPY python/dist/*.whl /opt/fastdeploy/ RUN python3 -m pip install /opt/fastdeploy/*.whl \ && rm -rf /opt/fastdeploy/*.whl # triton server RUN mkdir -p /opt/tritonserver && cp -r /home/server/build/tritonserver/install/* /opt/tritonserver # python backend RUN mkdir -p /opt/tritonserver/backends/python && cp -r /home/server/build/python/install/backends/python /opt/tritonserver/backends/ # fd_backend COPY serving/build/libtriton_fastdeploy.so /opt/tritonserver/backends/fastdeploy/ COPY build/fastdeploy-0.0.3 /opt/fastdeploy/ RUN mv /opt/tritonserver/bin/tritonserver /opt/tritonserver/bin/fastdeployserver ENV LD_LIBRARY_PATH="/opt/fastdeploy/lib:/opt/fastdeploy/third_libs/install/onnxruntime/lib:/opt/fastdeploy/third_libs/install/paddle2onnx/lib:/opt/fastdeploy/third_libs/install/paddle_inference/paddle/lib:$LD_LIBRARY_PATH" ENV PATH="/opt/tritonserver/bin:$PATH"