Docker鏡像與倉庫
☆ 查看和刪除鏡像:
Docker鏡像的存儲位置:/var/lib/docker
[root@docker0 ~]# docker info
Containers: 0
Running: 0
Paused: 0
Stopped: 0
Images: 3
Server Version: 1.12.6
Storage Driver: devicemapper
PoolName: docker-8:2-33777500-pool
PoolBlocksize: 65.54 kB
BaseDevice Size: 10.74 GB
Backing Filesystem: xfs
Datafile: /dev/loop0
Metadata file: /dev/loop1
DataSpace Used: 302.6 MB
DataSpace Total: 107.4 GB
DataSpace Available: 18.24 GB
Metadata Space Used: 901.1 kB
Metadata Space Total: 2.147 GB
Metadata Space Available: 2.147 GB
ThinPool Minimum Free Space: 10.74 GB
UdevSync Supported: true
Deferred Removal Enabled: true
Deferred Deletion Enabled: true
Deferred Deleted Device Count: 0
Dataloop file: /var/lib/docker/devicemapper/devicemapper/data
WARNING: Usage of loopback devices is stronglydiscouraged for production use. Use `--storage-opt dm.thinpooldev` to specify acustom block storage device.
Metadata loop file: /var/lib/docker/devicemapper/devicemapper/metadata
Library Version: 1.02.140-RHEL7 (2017-05-03)
Logging Driver: journald
Cgroup Driver: systemd
Plugins:
Volume: local
Network: null bridge overlay host
Swarm: inactive
Runtimes: docker-runc runc
Default Runtime: docker-runc
Security Options: seccomp selinux
Kernel Version: 3.10.0-693.5.2.el7.x86_64
Operating System: CentOS Linux 7 (Core)
OSType: linux
Architecture: x86_64
Number of Docker Hooks: 3
CPUs: 1
Total Memory: 976.3 MiB
Name: docker0
ID: PFGR:DFK7:WIOG:MSWF:632I:BPDO:NUNA:WDGS:AQJ3:6PEU:2BCE:UOMI
Docker Root Dir: /var/lib/docker
Debug Mode (client): false
Debug Mode (server): false
Registry: https://index.docker.io/v1/
WARNING: bridge-nf-call-iptables isdisabled
WARNING: bridge-nf-call-ip6tables isdisabled
Insecure Registries:
127.0.0.0/8
Registries: docker.io (secure)
[root@docker0 ~]#
列出鏡像:
dockerimages 選項 倉庫
-a:--all,列出所有鏡像
-f:--filter,顯示時的過濾條件
--no-trunc:指定不使用截斷的數據進行顯示
-q:--quiet,只顯示鏡像的唯一ID
查看鏡像的詳細信息:
dockerinspect 選項 container或images 容器或鏡像
-f:--format,格式
刪除鏡像:
dockerrmi 選項 image鏡像
-f:--force,強制刪除鏡像
--no-prune:不刪除未打標簽的父鏡像
☆ 獲取和推送鏡像:
通過DockerHub的官方網站進行查找。
dockersearch 選項term
--automated:只顯示自動化構建的鏡像
--no-trunc:不以截斷的方式顯示輸出
-s:--stars,限定顯示結果的最低星級
最多返回25個結果。
拉取鏡像:
dockerpull 選項 name或name:標記
-a:--all-tags,下載所喲匹配標記的鏡像
--registry-mirror:修改/etc/default/docker,添加DOCKER_OPTS=” --registry-mirror=鏡像地址”
註冊DaoCloud獲取倉庫加速器:
[root@docker0 ~]# curl -sSLhttps://get.daocloud.io/daotools/set_mirror.sh | sh -s http://a836cbf0.m.daocloud.io
在自動修改的docker的配置文件/etc/docker/daemon.json的時候,啟動docker會格式出錯,要手動更改為如下格式:
CentOS或RHEL在/etc/sysconfig/docker文件中OPTIONS=添加--registry-mirror=http://a836cbf0.m.daocloud.io
☆ 構建鏡像:
1.使用commit通過容器創建鏡像:
dockercommit 選項 container倉庫或倉庫:標記
-a:--author=“”,作者信息
-m:message=“”,提交信息
-p:--pause,創建鏡像的時候會將容器暫停
創建一個容器:
更新APT源:
安裝軟件:
退出容器:
提交鏡像:
查看結果:
2.使用Dockerfile構建鏡像:
創建Dockerfile文件:
編寫Dockerfile文件:
編譯Dockerfile文件:
查看鏡像:
☆ Dockerfile指令:
Dockerfile中的註釋使用#開頭
1.指定基礎鏡像:
FROM 鏡像
FROM 鏡像:標簽
鏡像必須存在。
2.指定鏡像作者信息:
MAINTAINER姓名
通常包含作者姓名和聯系方式。
3.指定鏡像中運行的命令:
包好兩種模式:
RUN Shell命令
使用/bin/sh -c shell形式執行指令。
RUN [“Shell環境”,”param”,” param”]
指定運行鏡像容器的端口:
EXPOSE端口…
5.指定容器運行的默認模式:
CMD[“param”,“param”]作為ENTRPOINT指令的默認參數
CMD命令 param param
CMD[“Shell環境”,“param”,“param”]
ENTRYPOINT[“Shell環境”,“param”,“param”]
ENTRYPOINT命令 paramparam
ENTRYPOINT指令不會被docker run命令覆蓋,如果要覆蓋run命令需要使用docker run –entrypoint選項。
6.將文件或者是目錄復制到Dockerfile構建的鏡像:
ADDsrc dest
ADD [“src”…“dest”]適用於文件路徑存在空格的情況
COPYsrc dest
COPY[“src”…“dest”] 適用於文件路徑存在空格的情況
ADD指令包含tar的解壓功能,如果只是單純復制文件,最好使用COPY命令。
7.添加卷:
VOLUME[“/data”]
這個卷可以繞過聯合文件系統來提供數據持久化功能。
8.設置工作目錄:
WORKDIR/tmp
9.設置環境變量
ENVkey value
ENVkey=value
10.指定運行身份
USER 用戶名
11.為鏡像添加觸發器:
ONBUILDDockerfile指令
當鏡像被使用的時候觸發。
☆ Dockerfile構建過程:
從基礎鏡像運行一個容器,執行一條Dockerfile指令,對容器進行修改,在提交一個新的鏡像層,基於剛才構建的鏡像,再運行一個容器,對容器進行更改,再次提交鏡像,知道Dockerfile指令還行完成。
Docker緩存:Docker在構建鏡像的時候還會產生緩存。編譯Dockerfile文件的時候可以不使用緩存,docker build–no-cache可以取消使用緩存,這在使用更新apt源的時候尤為有用。
本文出自 “許俊傑” 博客,請務必保留此出處http://xvjunjie.blog.51cto.com/12360960/1982415
Docker鏡像與倉庫