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