深入理解pytorch庫的dockerfile
0. dockerfile命令
FROM # 基礎鏡像,一切從這裡開始構建 MAINTAINER # 鏡像是誰寫的,姓名+郵箱 RUN # 鏡像構建的時候需要運行的命令 ADD # 步驟:tomcat鏡像,這個tomcat壓縮包!添加內容 WORKDIR # 鏡像的工作目錄 VOLUME # 掛載的目錄 EXPOSE # 保留端口配置 CMD # 指定這個容器啟動的時候要運行的命令,隻有最後一個會生效,可被替代 ENTRYPOINT # 指定這個容器啟動的時候要運行的命令,可以追加命令 ONBUILD # 當構建一個被繼承DockerFile這個時候就會運行ONBUILD指令,觸發指令。 COPY # 類似ADD,將我們文件拷貝到鏡像中 ENV # 構建的時候設置環境變量
1. 使用指令的註意點
1.FROM:
如果制作base image
,則使用FROM scratch
。
如果在某鏡像基礎上制作,例如使用FROM centos:7
指定具體的base image
的版本,不指定版本則默認為最新的。
2.LABEL:
需要對鏡像做基礎的介紹:
LABEL maintainer="Prin<[email protected]>" LABEL version = "1.0" LABEL description="prin First DcokerFile"
3.RUN:
容器內執行的命令,有兩種格式。shell:RUN <命令行命令>,等同於在終端執行shell命令
。exec:RUN ["可執行文件","參數1","參數2"]
。
註意:Dockerfile的指令每執行一次都會在docker上新建一層。所以過多無意義的層,會造成鏡像膨脹過大,建議使用&&符號鏈接命令,例如:RUN yum -y update && yum -y install yum net-tools。
4.ADD and COPY:
概述:
ADD和COPY都是將宿主機上的文件拷入鏡像中。大部分情況,,COPY優於ADD(方便明瞭)。 ADD除瞭COPY還有額外功能(解壓)。添加遠程文件/目錄請使用curl或者wget。
ADD For_add /prin ——- 將本地文件夾For_add(與dockerfile在同一個目錄)內的文件全部拷入鏡像的/prin目錄。
COPY For_cp /prin —— 同上。
ADD for_add.tar.gz /prin/unzip/ —— 將 for_add.tar.gz壓縮文件拷貝進入鏡像的/prin/unzip/目錄,並解壓。
5.WORKDIR(工作目錄):
在容器生成時,默認切換到具體的目錄中。
6.VOLUME(掛載):
概述:
設置數據卷的位置,並且容器在運行時自動掛載為匿名卷,當然也可以覆蓋與具名掛載。
2. dockerfile
# 繼承Pytorch官方的cuda鏡像 FROM pytorch/pytorch:1.11.0-cuda11.3-cudnn8-devel LABEL maintainer = "[email protected]" LABEL version = "0.2" LABEL description = "prepare deep learning environment" # 指定docker鏡像中,默認的工作路徑是/home/BE WORKDIR /home/BE RUN rm /etc/apt/sources.list.d/cuda.list \ && rm /etc/apt/sources.list.d/nvidia-ml.list \ && apt-get update \ && apt-get install -y libgl1 \ && conda install gdal==3.4.1 \ && pip config set global.index-url https://pypi.douban.com/simple/ \ && pip install opencv-python-headless==4.6.0.66 \ && pip install opencv-python==4.6.0.66 \ && pip install segmentation-models-pytorch
3. 參考
https://docs.microsoft.com/zh-cn/virtualization/windowscontainers/manage-docker/manage-windows-dockerfile
4. 存在的問題
Q1:每一次運行docker容器時,是否要掛載本地路徑
docker run的時候,進行掛載
Q2:dockerfile中涉及apt-get 操作失敗
官方的解釋:為瞭最好地確保我們的 RPM 和 Debian 軟件包存儲庫的安全性和可靠性,NVIDIA 將從 2022 年 4 月 27 日開始更新和輪換 apt、dnf/yum 和 zypper 軟件包管理器使用的簽名密鑰。未能更新存儲庫簽名密鑰將導致嘗試從 CUDA 存儲庫訪問或安裝包時出現包管理錯誤。為確保繼續訪問最新的 NVIDIA 軟件,請完成以下步驟: 刪除過時的簽名密鑰 Deb…
RUN rm /etc/apt/sources.list.d/cuda.list RUN rm /etc/apt/sources.list.d/nvidia-ml.list
到此這篇關於pytorch庫的dockerfile的文章就介紹到這瞭,更多相關pytorch庫的dockerfile內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!
推薦閱讀:
- docker容器使用GPU方法實現
- 詳解win10下pytorch-gpu安裝以及CUDA詳細安裝過程
- Linux安裝Pytorch1.8GPU(CUDA11.1)的實現
- Dockerfile中的保留字指令的過程解析
- Docker 鏡像分層及dockerfile 編寫技巧