Docker 常用命令、容器数据卷的介绍

本篇将进一步介绍Docker,主要介绍Docker常用命令,Docker容器数据卷,Docker镜像等内容。

Docker常用命令

1.帮助命令
docker version
docker info
docker --help
2.镜像命令
  • 列出本地主机上的镜像
docker images [OPTIONS]

OPTIONS参数说明:
    -a :列出本地所有的镜像(含中间映像层)
    -q :只显示镜像ID。
    --digests :显示镜像的摘要信息
    --no-trunc :显示完整的镜像信息

运行效果:
[图片上传失败...(image-951668-1634286574472)]
说明:
REPOSITORY:表示镜像的仓库源
TAG:镜像的标签,相当于版本号
IMAGE ID:镜像ID
CREATED:镜像创建时间
SIZE:镜像大小

  • 搜索镜像
docker search [OPTIONS] 镜像名字

OPTIONS参数说明:
    --no-trunc : 显示完整的镜像描述
    -s : 列出收藏数不小于指定值的镜像。
    --automated : 只列出 automated build类型的镜像;
  • 拉取下载镜像
docker pull 镜像名字[:TAG]

:TAG : 标签,相当于版本号
  • 删除镜像
docker rmi 镜像名字/镜像ID

docker rmi  -f 镜像ID  #删除单个

docker rmi -f 镜像名1:TAG 镜像名2:TAG #删除多个

docker rmi -f $(docker images -qa) #删除全部,$(docker images -qa)表示查询出所有的镜像ID
  • commit镜像
    可以通过docker commit 容器副本使之成为新的镜像
docker commit -m “提交的描述信息” -a “作者” 容器ID 要创建的目标镜像名:[标签名]
3.容器命令
  • 新建并启动容器
docker run [OPTIONS] IMAGE [COMMAND] [ARG...]

OPTIONS说明(常用):
    --name="容器新名字": 为容器指定一个名称;
    -d: 后台运行容器,并返回容器ID,也即启动守护式容器;
    -i:以交互模式运行容器,通常与 -t 同时使用;
    -t:为容器重新分配一个伪输入终端,通常与 -i 同时使用;
    -P: 随机端口映射;
    -p: 指定端口映射,有四种
        hostPort:containerPort
        ip:hostPort:containerPort
        ip::containerPort
        containerPort
COMMAND说明:启动容器后,并在容器执行某个指令
ARG说明:传递的参数

示例:启动交互式容器,指定端口映射,并在容器内执行/bin/bash命令
docker run -it -p 8080:8080 jenkins123 /bin/bash
[图片上传失败...(image-180547-1634286574472)]
示例:启动守护式容器
docker run -d -p 8080:8080 jenkins123
[图片上传失败...(image-63cabf-1634286574472)]
需要注意:
Docker容器后台运行,就必须有一个前台进程。
容器运行的命令如果不是那些一直挂起的命令(比如运行top,tail),就是会自动退出的。

  • 列出当前所有正在运行的容器
docker ps [OPTIONS]

OPTIONS说明(常用):
    -a :列出当前所有正在运行的容器+历史上运行过的
    -l :显示最近创建的容器。
    -n:显示最近n个创建的容器。
    -q :静默模式,只显示容器编号。
    --no-trunc :不截断输出。
    组合使用 docker ps -qa 查询所有容器id
  • 退出容器
exit #容器停止退出
ctrl+P+Q #容器不停止退出
  • 启动容器
docker start 容器ID或者容器名
  • 停止容器
docker stop 容器ID或者容器名
  • 强制停止容器
docker kill 容器ID或者容器名
  • 重启容器
docker restart 容器ID或者容器名
  • 删除已停止的容器
docker rm 容器ID 
docker rm -f $(docker ps -qa) #删除多个
  • 查看容器日志
docker logs -f -t --tail 容器ID

参数说明:
    -t 是加入时间戳
    -f 跟随最新的日志打印
    --tail 数字 显示最后多少条
  • 查看容器内运行的进程
docker top 容器ID
  • 查看容器内部细节
docker inspect 容器ID
  • 进入正在运行的容器
#方式一
docker exec -it 容器ID /bin/bash #在容器中打开新的终端,会启动新的进程
#方式二
docker attach 容器ID #直接进入容器启动命令的终端,不会启动新的进程
  • 从容器内拷贝文件到主机上
docker cp  容器ID:容器内路径 目的主机路径
4.总结一下
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容器数据卷

作用
  • 容器的持久化,类似我们Redis里面的rdb和aof文件
  • 容器间继承+共享数据
给容器添加数据卷
  • 命令添加
 docker run -d -v /宿主机绝对路径目录:/容器内目录 镜像名/ID
 #注意:如果出现cannot open directory,需要多加一个参数 --privileged=true
 
 #查看是否挂载成功
 docker inspect 容器ID

如果成功会显示:
[图片上传失败...(image-b23a5d-1634286574472)]
数据同步效果
在主机中写入一个hello文件
[图片上传失败...(image-658629-1634286574472)]
在容器中能同步到主机写入的hello文件
[图片上传失败...(image-b4a86e-1634286574472)]

  • 通过DockerFile添加,等后面介绍DockerFIle时,一同介绍。

Docker镜像

为了更好了解docker镜像是什么,我们先来了解一下UnionFS(联合文件系统)。

UnionFS

Union文件系统(UnionFS)是一种分层、轻量级并且高性能的文件系统,它支持对文件系统的修改作为一次提交来一层层的叠加,同时可以将不同目录挂载到同一个虚拟文件系统下。

Docker镜像组成

docker的镜像实际上由一层一层的文件系统组成,Union 文件系统是 Docker 镜像的基础,镜像可以通过分层来进行继承,基于基础镜像,可以制作各种具体的应用镜像。
所以,当去拉取一个镜像时,在下载的过程中可以看到dockers是一层一层下载的。
[图片上传失败...(image-2c2975-1634286574472)]
采用这种分层结构的好处:共享资源,节约空间。
举个例子:假如有多个镜像都从相同的 base 镜像构建而来,那么宿主机只需在磁盘上保存一份base镜像,同时内存中也只需加载一份 base 镜像,就可以为所有容器服务了。而且镜像的每一层都可以被共享

通过容器副本构建一个新的镜像

Docker镜像有个特点,都是只读的。
所以,可以通过docker commit 容器副本使之成为新的镜像。

docker commit -m=“提交的描述信息” -a=“作者” 容器ID 要创建的目标镜像名:[标签名]
操作过程
  • 通过docker pull 拉取一个镜像,并运行起来。
  • 期间可以进入容器,进行相应定制修改操作。
  • 通过docker commit该容器副本使之成为新的镜像。
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,684评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,143评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,214评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,788评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,796评论 5 368
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,665评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,027评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,679评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 41,346评论 1 299
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,664评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,766评论 1 331
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,412评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,015评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,974评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,203评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,073评论 2 350
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,501评论 2 343

推荐阅读更多精彩内容