• 1.triton镜像使用


    1.tritonserver镜像使用

    1)拉取镜像

    1. # <xx.yy>为Triton的版本
    2. docker pull nvcr.io/nvidia/tritonserver:22.06-py3

    2)启动容器

    指定模型仓库时可以执行server下的./fetch_model.sh,见2.2部分

    GPU版本的启动

    docker run --gpus=1 --rm -p8000:8000 -p8001:8001 -p8002:8002 -v /home/zhouquanwei/workspace/triton/server/docs/examples/model_repository:/models nvcr.io/nvidia/tritonserver:22.06-py3 tritonserver --model-repository=/models

    CPU版本的启动

    docker run --rm -p8000:8000 -p8001:8001 -p8002:8002 -v /home/zhouquanwei/workspace/triton/server/docs/examples/model_repository:/models nvcr.io/nvidia/tritonserver:22.06-py3 tritonserver --model-repository=/models
    

    区别只在于--gpus=1这个参数

    注意:docker19.03之前的版本使用gpu要指定显卡硬件名,docker19.03之后的需要安装

    nvidia-container-toolkit或nvidia-container-runtime

    我的服务器是centos系统,我安装nvidia-container-toolkit,方式如下:

    1. distribution=$(. /etc/os-release;echo $ID$VERSION_ID)
    2. curl -s -L https://nvidia.github.io/nvidia-docker/$distribution/nvidia-docker.repo | sudo tee /etc/yum.repos.d/nvidia-docker.repo
    3. sudo yum install -y nvidia-container-toolkit

    安装之后要重启docker

    systemctl restart docker

    查看gpus参数是否安装成功

    docker run --help | grep -i gpus
          --gpus gpu-request               GPU devices to add to the container ('all' to pass all GPUs)

    重新执行我遇到了如下错误

     先使用非GPU版本的

    nvidia-docker2.0是一个简单的包,它主要通过修改docker的配置文件“/etc/docker/daemon.json”来让docker使用NVIDIA Container runtime。

    执行成功之后

     进入该容器的方式为

    docker exec -it  8f89d733ff41 /opt/nvidia/nvidia_entrypoint.sh

    3)验证是否启动成功

    curl -v localhost:8000/v2/health/ready

     4)继续验证,发送一个请求

    1. ##拉取镜像
    2. docker pull nvcr.io/nvidia/tritonserver:22.06-py3-sdk
    3. ##启动服务
    4. docker run -it --rm --net=host nvcr.io/nvidia/tritonserver:22.06-py3-sdk
    5. ##发送请求
    6. /workspace/install/bin/image_client -m densenet_onnx -c 3 -s INCEPTION /workspace/images/mug.jpg
    7. Request 0, batch size 1
    8. Image '/workspace/images/mug.jpg':
    9. 15.346230 (504) = COFFEE MUG
    10. 13.224326 (968) = CUP
    11. 10.422965 (505) = COFFEEPOT

     注意

    1)对于nvcr.io/nvidia/tritonserver:22.06-py3镜像,其容器内的/opt/tritonserver/bin目录下保存tritonserver的启动程序,使用

    tritonserver --model-repository=/models

     2)/opt/tritonserver目录下各个文件的含义

    /opt/tritonserver/bin:tritonserver可执行文件

    /opt/tritonserver/lib:存放共享库

    /opt/tritonserver/backends:存放backends

    /opt/tritonserver/repoagents:存放repoagents

    2.编译tritonserver

    Triton inference server 支持源码编译和容器编译两种方式

    2.1源码编译

    2.2容器编译

    1)克隆triton inference server

    1. cd /workspace/triton
    2. git clone --recursive git@github.com:triton-inference-server/server.git

    2)创建模型仓库

    1. cd /workspace/triton/server/docs/examples
    2. ./fetch_models.sh

    执行./fetch_models.sh脚本之后发现/workspace/triton/server/docs/examples/model_repository/densenet_onnx目录下多了一个1目录。

    /tmp目录下多了一个inception_v3_2016_08_28_frozen.pb.tar.gz 

    3)编译,容器编译和源码编译

    1. cd server
    2. ./build.py -v --enable-all

  • 相关阅读:
    JVM高频知识点总结【3】
    CentOS7---部署Tomcat和安装Jpress
    计算机网络中的CSMA/CD算法的操作流程(《自顶向下》里的提炼总结)
    未来已来:探索5G技术如何改变我们的生活和工作
    RAID-6技术详解
    用go基于有向图实现一个有限状态机器(FSM)
    (13.2)Latex图片、表格的绘制与排布
    2分钟快速批量部署node_exporter
    提升协作效率:钉钉流程与低代码平台的无缝对接
    WebSocket的入门秘籍?
  • 原文地址:https://blog.csdn.net/qq_38196982/article/details/127231512