溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Docker如何使用Dockerfile來創(chuàng)建鏡像

發(fā)布時間:2022-05-25 15:07:32 來源:億速云 閱讀:746 作者:iii 欄目:大數(shù)據(jù)

今天小編給大家分享一下Docker如何使用Dockerfile來創(chuàng)建鏡像的相關知識點,內(nèi)容詳細,邏輯清晰,相信大部分人都還太了解這方面的知識,所以分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后有所收獲,下面我們一起來了解一下吧。

1.dockerfile

1.1基本案例

dockerfile可以說是docker的描述符,該文件定義了docker鏡像的所能擁有哪些東西.基本格式如下:

第一行指定該鏡像基于的基礎鏡像(必須)
from java:8

維護者信息
maintainer quding niudear@foxmail.com

鏡像操作指令
run echo $java_home

啟動時操作的命令

cmd ./usr/sbin/nginx

該文件說明從java8這個基礎鏡像創(chuàng)建一個新的鏡像,輸出java路徑,啟動成功則啟動nginx服務,這也是一個dockerfile需要包含的操作步驟.

1.2指令詳解

1.from:格式為 from <image>或from<image>:<tag>第一條指令必須是from指令。并且,如果在同一個dockerfile中創(chuàng)建多個鏡像時,可以使用多個from指令(每個鏡像一次)。

2.maintainer:格式為maintaier,指定維護者信息。

3.run:格式為run <command>或者run [“executable”,“param1”,“param2”]。前者將在shell終端中運行的命令,即/bin/sh–c;后者則使用exec執(zhí)行。指定使用其他終端可以通過第二種方式實現(xiàn),例如run[“/bin/bash”,“-c”,“echohello”]。每條run指令將在當前鏡像基礎上執(zhí)行指定命令,并提交為新的鏡像。當命令較長時可以使用\來換行。這實際上就是在容器構(gòu)建時需要執(zhí)行哪些指令,例如容器構(gòu)建時需要下拉代碼,但是默認啟動的容器中是沒有git指令的,就需要下載,可以執(zhí)行:run apt-get install -y git,然后run git clonexxxx

4.cmd:指定容器啟動后執(zhí)行的命令

命令格式為:

sh格式: cmd <命令>

exec格式:cmd [“可執(zhí)行文件”,”參數(shù)1”,”參數(shù)2”]

一般都是早就寫好的腳本或者啟動一個服務,例如:cmd[“/run.sh”]。注意:如果dockerfile中指定了多條命令,只有最后一條會被執(zhí)行。如果用戶啟動時候加了運行的命令,則會覆蓋掉cmd指定的指令。

這里有一個問題,很多時候我們想要docker一直在后臺運行,但是往往docker啟動后就停止.原因就在于此.

比如執(zhí)行cmd serice mysql start,那么翻譯過來的話是cmd ["sh","-c","serice mysql start"],那么對于docker來說cmd主進程為sh,那么sh執(zhí)行完該命令就結(jié)束,所以導致docker停止.所以要改成直接啟動文件形式cmd ["mysql","-g",""daemon off;],指定前臺運行.

5.expose:告訴docker服務端容器需要暴露的端口號,供互聯(lián)系統(tǒng)使用。在啟動容器時需要通過-p(注意是大寫),docker主機會自動分配一個端口轉(zhuǎn)發(fā)到指定的端口;使用-p,則可以具體指定哪個本地端口映射過來。
例如:我在elasticsearch鏡像的dockerfile中指定了暴露出9200和9300端口,我可以在dockerfile中寫:expose 9200 9300

6.env:創(chuàng)建的時候給容器中加上個需要的環(huán)境變量。指定一個值,為后續(xù)的run指令服務

7.copy:復制本地的文件或目錄到容器中。目標路徑不存在時,會自動創(chuàng)建。

8.entrypoint:配置容器啟動后執(zhí)行的命令,并且不可被docker run 提供的參數(shù)覆蓋。
每個dockerfile中只能有一個entrypoint,當指定多個entrypoint時,只有最后一個生效

9.volume:創(chuàng)建一個掛在點,可以從本機或其他容器掛載的掛載點。意思就是從容器中暴露出一部分,和外界共享這塊東西,一般放數(shù)據(jù)庫的數(shù)據(jù)或者是代碼。在容器啟動運行的時候,如果需要將volume暴露的東西和本地的一個文件夾進行映射,想要通過本地文件直接訪問容器中暴露的部分,可以在運行的時候進行映射:

10.user:指定運行容器時的用戶名或者uid,后續(xù)的run也會使用指定的用戶。當服務不需要管理員權限時,可以通過該命令指定運行用戶。并且可以在之前創(chuàng)建所需要的用戶。
要臨時獲取管理員權限的時候要使用gosu,不推薦使用sudo。如果不指定,容器默認是root運行。

11.workdir:定義工作目錄,如果容器中沒有此目錄,會自動創(chuàng)建

創(chuàng)建指令docker build 路徑,該命令會讀取路徑下的dockerfile文件和其他文件,然后發(fā)送給服務端,由服務端創(chuàng)建鏡像.

2.創(chuàng)建ssh服務鏡像

2.1準備java8環(huán)境

后續(xù)教程需要利用到java8環(huán)境,因此先下載一個官方的java8鏡像作為基礎鏡像.直接執(zhí)行如下命令.可以利用之前的教程,啟動容器查看下java路徑.

docker pull java:8

Docker如何使用Dockerfile來創(chuàng)建鏡像

2.2編寫dockerfile

ssh服務主要是openssh-server來提供,因此需要在容器中安裝該服務.

dockerfile:

#顯示該鏡像是基于java8鏡像
from java:8

#維護人信息
maintainer quding niudear@foxmail.com
#更新源
run apt-get update
#安裝軟件
run apt-get install -y openssh-server

run mkdir -p /var/run/sshd
run mkdir -p /root/.ssh

#取消pam限制
run sed -ri 's/session required  pam_loginuid.so/#session  required pam_loginuid.so/g' /etc/pam.d/sshd

#復制配置文件到相應位置
copy authorized_keys /root/.ssh/authorized_keys
copy run.sh /run.sh

#賦予腳本權限
run chmod 755 /run.sh

#開放端口
expose 22

#設置啟動命令

cmd ["/run.sh"]

run.sh

#!/bin/bash
/usr/sbin/sshd -d

拷貝本機的id_ras

cat ~/.ssh/id_rsa.pub >authorized_keys
//用來免密的

執(zhí)行構(gòu)建

docker build -t sshd:java .

構(gòu)建成功后使用docker images即可查看,然后像上篇一樣啟動容器,暴露出端口,再使用ssh連接,和一般linux系統(tǒng)就沒什么差別了.

以上就是“Docker如何使用Dockerfile來創(chuàng)建鏡像”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家閱讀完這篇文章都有很大的收獲,小編每天都會為大家更新不同的知識,如果還想學習更多的知識,請關注億速云行業(yè)資訊頻道。

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權內(nèi)容。

AI