這篇“pytorch庫的dockerfile怎么使用”文章的知識點大部分人都不太理解,所以小編給大家總結了以下內容,內容詳細,步驟清晰,具有一定的借鑒價值,希望大家閱讀完這篇文章能有所收獲,下面我們一起來看看這篇“pytorch庫的dockerfile怎么使用”文章吧。
FROM # 基礎鏡像,一切從這里開始構建 MAINTAINER # 鏡像是誰寫的,姓名+郵箱 RUN # 鏡像構建的時候需要運行的命令 ADD # 步驟:tomcat鏡像,這個tomcat壓縮包!添加內容 WORKDIR # 鏡像的工作目錄 VOLUME # 掛載的目錄 EXPOSE # 保留端口配置 CMD # 指定這個容器啟動的時候要運行的命令,只有最后一個會生效,可被替代 ENTRYPOINT # 指定這個容器啟動的時候要運行的命令,可以追加命令 ONBUILD # 當構建一個被繼承DockerFile這個時候就會運行ONBUILD指令,觸發指令。 COPY # 類似ADD,將我們文件拷貝到鏡像中 ENV # 構建的時候設置環境變量
1.FROM:
如果制作base image
,則使用FROM scratch
。
如果在某鏡像基礎上制作,例如使用FROM centos:7
指定具體的base image
的版本,不指定版本則默認為最新的。
2.LABEL:
需要對鏡像做基礎的介紹:
LABEL maintainer="Prin<xxx@qq.com>" 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 = "xxxxxxx@qq.com" 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
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怎么使用”這篇文章的內容,相信大家都有了一定的了解,希望小編分享的內容對大家有幫助,若想了解更多相關的知識內容,請關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。