【Docker】——安装镜像和创建容器,详解镜像和Dockerfile

2024-06-26 1473阅读

前言

在此记录一下docker的镜像和容器的相关注意事项

前提条件:已安装Docker、显卡驱动等基础配置

1. 安装镜像

网上有太多的教程,但是都没说如何下载官方的镜像,在这里记录一下,使用docker安装官方的镜像

Docker Hub的官方链接:https://www.docker.com/products/docker-hub/

【Docker】——安装镜像和创建容器,详解镜像和Dockerfile

点击Explore Docker Hub,在搜索框中输入:nvidia/cuda,转到tags,找到合适的镜像,复制链接即可

【Docker】——安装镜像和创建容器,详解镜像和Dockerfile

Docker镜像源

docker.chenby.cn/

为了更加快速的下载,一般会添加docker镜像源,提高下载速度,如果不适用docker镜像源,也可能下载失败,因此,完整的镜像下载命令如下:

docker pull docker.chenby.cn/nvidia/cuda:11.1.1-cudnn8-devel-ubuntu20.04

【Docker】——安装镜像和创建容器,详解镜像和Dockerfile

等待下载完毕即可,这个命令使用的cuda版本不高,应该可以在大部分机器上直接使用

  • 镜像重命名

    docker tag 旧镜像名 新镜像名

    docker rmi 旧镜像名

    使用docker tag 其实会生成一个新镜像,我们可以使用docker rmi 删除旧的镜像

    2. NVIDIA Container Toolkit (Docker使用GPU)

    • 设置NVIDIA Container Toolkit的stable版本存储库的GPG key:

      distribution=$(. /etc/os-release;echo $ID$VERSION_ID) && curl -s -L https://nvidia.github.io/nvidia-docker/gpgkey | sudo apt-key add - && curl -s -L https://nvidia.github.io/nvidia-docker/$distribution/nvidia-docker.list | sudo tee /etc/apt/sources.list.d/nvidia-docker.list

      • 安装toolkit:

        sudo apt-get update && sudo apt-get install -y nvidia-container-toolkit

        sudo systemctl restart docker

        3. 创建容器

        • 生成dockerfile

          现在需要进入一个空的项目,并进入到Dockerfile的文件目录中,在本例中,则需要命令行切换到docker_test目录下,并根据自己的需求,编辑dockerfile

          【Docker】——安装镜像和创建容器,详解镜像和Dockerfile

          其中,重点关注FROM的镜像源是否一致,详细的dockerfile自行了解(正常情况下,github的项目都是配置好的,只需注意FROM的镜像源),dockerfile示例如下(YOLOv10):

          # Ultralytics YOLO 🚀, AGPL-3.0 license
          # Builds ultralytics/ultralytics:latest image on DockerHub https://hub.docker.com/r/ultralytics/ultralytics
          # Image is CUDA-optimized for YOLOv8 single/multi-GPU training and inference
          # Start FROM PyTorch image https://hub.docker.com/r/pytorch/pytorch or nvcr.io/nvidia/pytorch:23.03-py3
          FROM pytorch/pytorch:2.2.0-cuda12.1-cudnn8-runtime
          RUN pip install --no-cache nvidia-tensorrt --index-url https://pypi.ngc.nvidia.com
          # Downloads to user config dir
          ADD https://github.com/ultralytics/assets/releases/download/v0.0.0/Arial.ttf \
              https://github.com/ultralytics/assets/releases/download/v0.0.0/Arial.Unicode.ttf \
              /root/.config/Ultralytics/
          # Install linux packages
          # g++ required to build 'tflite_support' and 'lap' packages, libusb-1.0-0 required for 'tflite_support' package
          RUN apt update \
              && apt install --no-install-recommends -y gcc git zip curl htop libgl1 libglib2.0-0 libpython3-dev gnupg g++ libusb-1.0-0
          # Security updates
          # https://security.snyk.io/vuln/SNYK-UBUNTU1804-OPENSSL-3314796
          RUN apt upgrade --no-install-recommends -y openssl tar
          # Create working directory
          WORKDIR /usr/src/ultralytics
          # Copy contents
          # COPY . /usr/src/ultralytics  # git permission issues inside container
          RUN git clone https://github.com/ultralytics/ultralytics -b main /usr/src/ultralytics
          ADD https://github.com/ultralytics/assets/releases/download/v8.1.0/yolov8n.pt /usr/src/ultralytics/
          # Install pip packages
          RUN python3 -m pip install --upgrade pip wheel
          RUN pip install --no-cache -e ".[export]" albumentations comet pycocotools
          # Run exports to AutoInstall packages
          # Edge TPU export fails the first time so is run twice here
          RUN yolo export model=tmp/yolov8n.pt format=edgetpu imgsz=32 || yolo export model=tmp/yolov8n.pt format=edgetpu imgsz=32
          RUN yolo export model=tmp/yolov8n.pt format=ncnn imgsz=32
          # Requires =2.6.0 x2paddle
          # Fix error: `np.bool` was a deprecated alias for the builtin `bool` segmentation error in Tests
          RUN pip install --no-cache numpy==1.23.5
          # Remove exported models
          RUN rm -rf tmp
          # Set environment variables
          ENV OMP_NUM_THREADS=1
          # Avoid DDP error "MKL_THREADING_LAYER=INTEL is incompatible with libgomp.so.1 library" https://github.com/pytorch/pytorch/issues/37377
          ENV MKL_THREADING_LAYER=GNU
          # Usage Examples -------------------------------------------------------------------------------------------------------
          # Build and Push
          # t=ultralytics/ultralytics:latest && sudo docker build -f docker/Dockerfile -t $t . && sudo docker push $t
          # Pull and Run with access to all GPUs
          # t=ultralytics/ultralytics:latest && sudo docker pull $t && sudo docker run -it --ipc=host --gpus all $t
          # Pull and Run with access to GPUs 2 and 3 (inside container CUDA devices will appear as 0 and 1)
          # t=ultralytics/ultralytics:latest && sudo docker pull $t && sudo docker run -it --ipc=host --gpus '"device=2,3"' $t
          # Pull and Run with local directory access
          # t=ultralytics/ultralytics:latest && sudo docker pull $t && sudo docker run -it --ipc=host --gpus all -v "$(pwd)"/datasets:/usr/src/datasets $t
          # Kill all
          # sudo docker kill $(sudo docker ps -q)
          # Kill all image-based
          # sudo docker kill $(sudo docker ps -qa --filter ancestor=ultralytics/ultralytics:latest)
          # DockerHub tag update
          # t=ultralytics/ultralytics:latest tnew=ultralytics/ultralytics:v6.2 && sudo docker pull $t && sudo docker tag $t $tnew && sudo docker push $tnew
          # Clean up
          # sudo docker system prune -a --volumes
          # Update Ubuntu drivers
          # https://www.maketecheasier.com/install-nvidia-drivers-ubuntu/
          # DDP test
          # python -m torch.distributed.run --nproc_per_node 2 --master_port 1 train.py --epochs 3
          # GCP VM from Image
          # docker.io/ultralytics/ultralytics:latest
          
          • 根据dockerfile构建项目镜像

            docker build -t docker_image .

            其中,docker_image为自定义的镜像名称,根据 FROM的镜像源 和 dockerfile 进行构建

            【Docker】——安装镜像和创建容器,详解镜像和Dockerfile

            【Docker】——安装镜像和创建容器,详解镜像和Dockerfile

            至此,项目镜像构建完成

            • 运行容器

              将docker的ssh端口22映射到物理机的2222

              将docekr的 /usr/src/ultralytics 目录映射到物理机的 /local/path 目录

              -name : 容器的名字,可以自定义

              docker_image:自定义镜像的id,根据自己生成的镜像来改

              sudo docker run --gpus all -it -p 2222:22 --name container_name -v /local/path:/usr/src/ultralytics docker_image:latest

              这样,我们就建立好了docker images,同时创建了一个docker container,并将本地与docker建立了联系,我们就可以进入docker container内部,进行开发了

              【Docker】——安装镜像和创建容器,详解镜像和Dockerfile

              备注

              如果在执行过程中,出现问题,可以使用以下命令清楚缓存,重新执行

              sudo docker builder prune -f

              参考

              vscode+docker搭建迷你开发环境。制作docker镜像,并通过vscode连接后进行开发

              通过安装NVIDIA Container Toolkit在Docker中使用GPU

VPS购买请点击我

免责声明:我们致力于保护作者版权,注重分享,被刊用文章因无法核实真实出处,未能及时与作者取得联系,或有版权异议的,请联系管理员,我们会立即处理! 部分文章是来自自研大数据AI进行生成,内容摘自(百度百科,百度知道,头条百科,中国民法典,刑法,牛津词典,新华词典,汉语词典,国家院校,科普平台)等数据,内容仅供学习参考,不准确地方联系删除处理! 图片声明:本站部分配图来自人工智能系统AI生成,觅知网授权图片,PxHere摄影无版权图库和百度,360,搜狗等多加搜索引擎自动关键词搜索配图,如有侵权的图片,请第一时间联系我们,邮箱:ciyunidc@ciyunshuju.com。本站只作为美观性配图使用,无任何非法侵犯第三方意图,一切解释权归图片著作权方,本站不承担任何责任。如有恶意碰瓷者,必当奉陪到底严惩不贷!

目录[+]