Docker基礎(chǔ)資料
安裝docker
$ sudo apt-get install docker.io
查看本地已有鏡像
$ sudo docker images
安裝 docker-compose
$ sudo apt-get install -u docker-compose
查看 docker-compose 信息
$ docker-compose -h
將用戶加入docker組
$ sudo groupadd docker
$ sudo gpasswd -a {USER} docker
$ sudo service docker restart
-- 添加完成重啟機器
登錄
$ docker login local-dtr.patsnap.com
Username (local): local
Password: patsnaplocal
利用 Dockerfile 創(chuàng)建鏡像
-- Dockerfile中每條指令都創(chuàng)建鏡像的一層,一般Dockerfile分為四部分:基礎(chǔ)鏡像信息/維護(hù)者信息/鏡像操作指令/容器啟動時執(zhí)行的指令。如:
#patsnap-course-project
FROM local-dtr.patsnap.com/patsnap/base:php5.5.30nginxnode-v1.4
ADD deployment/nginx/conf/conf.d/* /usr/local/nginx/conf/conf.d/
ADD deployment/changeenv.sh /config/init/
RUN mkdir -p /data/patsnap
VOLUME [/data/patsnap]
EXPOSE 10050 80
Dockerfile基本語法:
-- #? ? ? ? ×用來注釋
-- FROM? ? 指令告訴Docker使用那個鏡像作為基礎(chǔ),第一條指令必須為FROM指令。
并且,如果在同一個dockerfile中創(chuàng)建多個鏡像時,可以使用多個FROM指令(每個鏡像一次)
-- RUN? ? ? 每條RUN指令將在當(dāng)前鏡像基礎(chǔ)上執(zhí)行指定命令,并提交為新的鏡像。
格式RUN 或RUN ["executable", "param1", "param2"],
前者將在shell終端運行命令,即/bin/sh -C;后者則使用exec執(zhí)行。
指定使用其他終端可以通過第二種方式實現(xiàn),例如:RUN ["/bin/bash", "-c", "echo hello"]。
-- CMD? ? ? 指定啟動容器時執(zhí)行的命令,每個Dockerfile只能有一條CMD命令。如指定多條命令,只有最后一條會被執(zhí)行。
-- ENV? ? ? 指定一個環(huán)境變量,會被后續(xù)RUN指令使用,并在容器運行時保存。格式:ENV
-- ADD? ? ? 該命令將復(fù)制指定的到容器中的。其中可以是Dockerfile所在目錄的一個相對路徑;
也可以是一個URL;還可以是一個tar文件(自動解壓為目錄)。
格式:ADD
-- EXPOSE? 告訴Docker服務(wù)段容器暴露的端口號,供互聯(lián)系統(tǒng)使用。
在啟動容器時需要通過-P,Docker主機會自動分配一個短褲轉(zhuǎn)發(fā)到指定的端口。
格式:EXPOSE [...]
-- VOLUME? 創(chuàng)建一個可以從本地主機或其他容器掛載的掛載點,一般用來存放數(shù)據(jù)庫和需要保存的數(shù)據(jù)等。
格式:VOLUME ["/data"]。
創(chuàng)建鏡像
編寫完成Dockerfile之后,可以通過docker build 命令來創(chuàng)建鏡像。格式:docker build [選項] 路徑; 該命令將讀取指定路徑下(包括子目錄)的Dockerfile,并將該路徑下所以內(nèi)容發(fā)送給Docker服務(wù)器,由服務(wù)器端來創(chuàng)建鏡像。 因此一般建議放置Dockerfile的目錄為空目錄。也可以通過.dockerignore文件(每一行添加一條匹配模式)來讓Docker忽略路徑下的目錄和文件。 要指定鏡像的標(biāo)簽信息,可以通過-t選項,如:
如果在docker run 后面追加-d=true或者-d,則containter將會運行在后臺模式(Detached mode)。此時所有I/O數(shù)據(jù)只能通過網(wǎng)絡(luò)資源或者共享卷組來進(jìn)行交互。因為container不再監(jiān)聽你執(zhí)行docker run的這個終端命令行窗口。但你可以通過執(zhí)行docker attach 來重新掛載這個container里面。需要注意的時,如果你選擇執(zhí)行-d使container進(jìn)入后臺模式,那么將無法配合"--rm"參數(shù)。
$ docker build -t basedocker .
$ docker run -d -p [PORT]:[PORT] --name [DockerName] [IMAGE][:TAG]
部署應(yīng)用
Docker Compose是Docker官方編排項目之一,負(fù)責(zé)快速在集群中部署分布式應(yīng)用。 Dockerfile可以讓用戶管理一個單獨的應(yīng)用容器;而Compose則允許用戶在一個模板(YAML格式)中定義一組相關(guān)聯(lián)的應(yīng)用容器(被稱為一個project,即項目)。docker-compose.yml是Compose使用的主模板文件 默認(rèn)的模板文件是 docker-compose.yml,其中定義的每個服務(wù)都必須通過 image 指令指定鏡像或 build 指令(需要 Dockerfile)來自動構(gòu)建。 其它大部分指令都跟 docker run 中的類似。 如果使用 build 指令,在 Dockerfile 中設(shè)置的選項(例如:CMD, EXPOSE, VOLUME, ENV 等) 將會自動被獲取,無需在 docker-compose.yml 中再次設(shè)置。
docker-compose.yml語法說明:
image? ? ? 指定為鏡像名稱或鏡像 ID。如果鏡像在本地不存在,Compose 將會嘗試?yán)ミ@個鏡像。
build? ? ? 指定 Dockerfile 所在文件夾的路徑。 Compose 將會利用它自動構(gòu)建這個鏡像,然后使用這個鏡像。
command? ? 覆蓋容器啟動后默認(rèn)執(zhí)行的命令。
links? ? ? 鏈接到其它服務(wù)中的容器。使用服務(wù)名稱或服務(wù)名稱:服務(wù)別名 (SERVICE:ALIAS) 格式都可以。
ports? ? ? 暴露端口信息。使用宿主:容器 (HOST:CONTAINER)格式或者僅僅指定容器的端口都可以。
expose? ? ? 暴露端口,但不映射到宿主機,只被連接的服務(wù)訪問。僅可以指定內(nèi)部端口為參數(shù)。
volumes? ? 卷掛載路徑設(shè)置。可以設(shè)置宿主機路徑 (HOST:CONTAINER) 或加上訪問模式 (HOST:CONTAINER:ro)。
environment 設(shè)置環(huán)境變量。你可以使用數(shù)組或字典兩種格式。只給定名稱的變量會自動獲取它在 Compose 主機上的值,
可以用來防止泄露不必要的數(shù)據(jù)。
env_file? ? 從文件中獲取環(huán)境變量,可以為單獨的文件路徑或列表。
如果通過 docker-compose -f FILE 指定了模板文件,則 env_file 中路徑會基于模板文件路徑。
如果有變量名稱與 environment 指令沖突,則以后者為準(zhǔn)。
Compose 命令說明:
基本格式:docker-compose [options] [COMMAND] [ARGS...]
選項:
--verbose 輸出更多調(diào)試信息。
--version 打印版本并退出。
-f, --file FILE 使用特定的 compose 模板文件,默認(rèn)為 docker-compose.yml。
-p, --project-name NAME 指定項目名稱,默認(rèn)使用目錄名稱。
docker-compose命令:
build? 構(gòu)建或重新構(gòu)建服務(wù)。服務(wù)一旦構(gòu)建后,將會帶上一個標(biāo)記名,例如 web_db。
可以隨時在項目目錄下運行 docker-compose build 來重新構(gòu)建服務(wù)。
kill? ? 通過發(fā)送 SIGKILL 信號來強制停止服務(wù)容器。支持通過參數(shù)來指定發(fā)送的信號,
例如:$ docker-compose kill -s SIGINT
logs? ? 查看服務(wù)的輸出。
port? ? 打印綁定的公共端口。
ps? ? ? 列出所有容器。
pull? ? 拉取服務(wù)鏡像。
rm? ? ? 刪除停止的服務(wù)容器。
run? ? 在一個服務(wù)上執(zhí)行一個命令。
start? 啟動一個已經(jīng)存在的服務(wù)容器。
stop? ? 停止一個已經(jīng)運行的容器,但不刪除它。
up? ? ? 構(gòu)建,(重新)創(chuàng)建,啟動,鏈接一個服務(wù)相關(guān)的容器。鏈接的服務(wù)都將會啟動,除非他們已經(jīng)運行。
默認(rèn)情況, docker-compose up 將會整合所有容器的輸出,并且退出時,所有容器將會停止。
如果使用 docker-compose up -d ,將會在后臺啟動并運行所有的容器。
默認(rèn)情況,如果該服務(wù)的容器已經(jīng)存在, docker-compose up 將會停止并嘗試重新創(chuàng)建他們,
以保證 docker-compose.yml 的修改生效。
如果你不想容器被停止并重新創(chuàng)建,可以使用 docker-compose up --no-recreate。
如果需要的話,這樣將會啟動已經(jīng)停止的容器。
docker 命令幫助
$ sudo docker
attach? ? # 當(dāng)前 shell 下 attach 連接指定運行鏡像
build? ? # 通過 Dockerfile 定制鏡像
commit? ? # 提交當(dāng)前容器為新的鏡像
cp? ? ? ? # 從容器中拷貝指定文件或者目錄到宿主機中
create? ? # 創(chuàng)建一個新的容器,同 run,但不啟動容器
diff? ? ? # 查看 docker 容器變化
events? ? # 從 docker 服務(wù)獲取容器實時事件
exec? ? ? # 在已存在的容器上運行命令
export? ? # 導(dǎo)出容器的內(nèi)容流作為一個 tar 歸檔文件[對應(yīng) import ]
history? # 展示一個鏡像形成歷史
images? ? # 列出系統(tǒng)當(dāng)前鏡像
import? ? # 從tar包中的內(nèi)容創(chuàng)建一個新的文件系統(tǒng)映像[對應(yīng) export]
info? ? ? # 顯示系統(tǒng)相關(guān)信息
inspect? # 查看容器詳細(xì)信息
kill? ? ? # kill 指定 docker 容器
load? ? ? # 從一個 tar 包中加載一個鏡像[對應(yīng) save]
login? ? # 注冊或者登陸一個 docker 源服務(wù)器
logout? ? # 從當(dāng)前 Docker registry 退出
logs? ? ? # 輸出當(dāng)前容器日志信息
port? ? ? # 查看映射端口對應(yīng)的容器內(nèi)部源端口
pause? ? # 暫停容器
ps? ? ? ? # 列出容器列表
pull? ? ? # 從docker鏡像源服務(wù)器拉取指定鏡像或者庫鏡像
push? ? ? # 推送指定鏡像或者庫鏡像至docker源服務(wù)器
restart? # 重啟運行的容器
rm? ? ? ? # 移除一個或者多個容器
rmi? ? ? # 移除一個或多個鏡像[無容器使用該鏡像才可刪除,否則需刪除相關(guān)容器才可繼續(xù)或 -f 強制刪除]
run? ? ? # 創(chuàng)建一個新的容器并運行一個命令
save? ? ? # 保存一個鏡像為一個 tar 包[對應(yīng) load]
search? ? # 在 docker hub 中搜索鏡像
start? ? # 啟動容器
stop? ? ? # 停止容器
tag? ? ? # 給源中鏡像打標(biāo)簽
top? ? ? # 查看容器中運行的進(jìn)程信息
unpause? # 取消暫停容器
version? # 查看 docker 版本號
wait? ? ? # 截取容器停止時的退出狀態(tài)值
運行'docker COMMAND --help'查看更多幫助
進(jìn)入Docker容器
$ docker ps
$ docker exec -it 775c7c9ee1e1 /bin/bash
查看nignx配置
$ cd /usr/local/nginx/conf/conf.d/
$ vi course.conf
停止進(jìn)程,配置環(huán)境
$ docker exec -it 9d bash
$ supervisorctl stop webpack
$ npm start