【Docker】第三篇 Docker容器管理
一、Docker容器概述:
- 简单理解容器是镜像的一个实例。
- 镜像是静态的只读文件,而容器的运行需要可写文件层。
二、创建容器
[root@web130 ~]# docker create -it ubuntu:latest #-i打开标准输入,-t是打开一个伪终端
17c54a92a4e83503e329c3c80e4d10bf298516edffa56b2cea8fa2aa73d4c00c
#我们要了解一下容器标识符:如上显示的CONTAINER ID作为容器的唯一标识。
#CONTAINER ID 默认是128位,但是一般16位就足以保证其在本机的唯一性。所以默认我们使用简约形式即可(id的前16位)。
#当然我们也可以根据自己情况选择适当的位数,来代表容器启停
[root@web130 ~]# docker ps -a #显示所有容器,#docker ps 显示正在运行的容器。#docker ps --no-trunc输出信息不截断显示,可以看到完整id CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
17c54a92a4e8 ubuntu:latest "/bin/bash" seconds ago Created quizzical_bhabha
1、查看docker运行的进程:
[root@web130 ~]# docker container ls #新命令等价与下边ps
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
[root@web130 ~]# docker ps #可以看到已经启动的容器、每个容器的ID、所使用的镜像、创建时间、当前状态、监听的端口和容器的名字
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
[root@web130 ~]#
2、启动容器:
#我们可以通过容器ID不同的前几位id号来代表指定在容器,也可以用全部ID号
[root@web130 ~]# docker ps -a
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
17c54a92a4e8 ubuntu:latest "/bin/bash" minutes ago Created quizzical_bhabha
[root@web130 ~]# docker start [root@web130 ~]# docker ps #可以看到已经启动的容器、每个容器的ID、所使用的镜像、创建时间、当前状态、监听的端口和容器的名字
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
17c54a92a4e8 ubuntu:latest "/bin/bash" minutes ago Up About a minute quizzical_bhabha
[root@web130 ~]#
3、新建并启动一个容器
**docker run在创建容器的时候,在后台运行的标准操作如下:
- 检查本地是否有指定镜像,如果没有直接从公有仓库下载;
- 利用镜像创建一个容器,并启动该容器;
- 分配一个文件系统,并在只读的镜像层外边挂载一层可读写层;
- 从宿主主机配置的网桥接口中桥接一个虚拟接口到容器中;
- 执行用户指定的应用程序;
- 执行完毕后容器制动终止。
[root@web130 ~]# docker run ubuntu /bin/echo 'hello world'
hello world
[root@web130 ~]# docker ps
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
17c54a92a4e8 ubuntu:latest "/bin/bash" minutes ago Up minutes quizzical_bhabha
[root@web130 ~]#
#**启动一个bash终端,允许用户交互
[root@web130 ~]# docker run -it ubuntu:14.04 /bin/bash
root@041941f24d3d:/# ls
bin boot dev etc home lib lib64 media mnt opt proc root run sbin srv sys tmp usr var
root@041941f24d3d:/# pwd
/
root@041941f24d3d:/# ps #可以看到容器只运行了一个bash应用,并没有运行其他无关进程
PID TTY TIME CMD
pts/ :: bash
pts/ :: ps
root@041941f24d3d:/# exit #退出容器,或者Ctrl+d
exit
[root@web130 ~]#
#我们可以加上--rm选项,--name选项,容器退出时,自动删除容器
[root@web130 ~]# docker run -it --rm ubuntu:14.04 /bin/bash
[root@web130 ~]# docker run --name t1 -it --rm ubuntu:14.04 /bin/bash #指定容器名 某些情况下,docker run 容器执行错误,默认情况下常见错误码:
#:Docker daemon执行错误,例如指定不支持的Docker命令参数;
#:所指定命令无法执行,例如权限出错;
#:容器内命令无法找到。
命令执行错误会返回错误码
4、容器守护态(Daemonized)运行
#一些时候让容器在后台运行,用参数-d 来实现
[root@web130 ~]# docker run -d ubuntu /bin/sh -c "while true;do echo hello world;sleep 1;done"
da81dbb0e2dadde799ca4d40189c3d14911ea269f76ce7843f9d585d7efbcd6a
[root@web130 ~]# [root@web130 ~]# docker ps #可以看到运行的容器,当然我们也可以上条命令中--name 指定容器名字,便于识别
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
da81dbb0e2da ubuntu "/bin/sh -c 'while t…" seconds ago Up seconds festive_mirzakhani
17c54a92a4e8 ubuntu:latest "/bin/bash" minutes ago Up minutes quizzical_bhabha
[root@web130 ~]# docker logs da8
hello world
hello world
hello world
....省略....
三、终止容器
stop和kill命令的区别:
*stop是首先发送SIGTERM信号,等一段时间(默认10秒),在发送SIGKILL信号终止容器
*kill直接发送SIGKILL终止容器,强制终止容器
[root@web130 ~]# docker stop da8 #可以-t 指定等待时间,
da8
[root@web130 ~]# docker ps #查看启动的容器
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
17c54a92a4e8 ubuntu:latest "/bin/bash" minutes ago Up minutes quizzical_bhabha
[root@web130 ~]# docker ps -a #查看所有容器
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
da81dbb0e2da ubuntu "/bin/sh -c 'while t…" minutes ago Exited () seconds ago festive_mirzakhani
041941f24d3d ubuntu:14.04 "/bin/bash" minutes ago Exited () minutes ago nervous_jepsen
439157f8ea55 ubuntu "/bin/echo 'hello wo…" minutes ago Exited () minutes ago vigorous_boyd
[root@web130 ~]# docker ps -qa #查看所有容器ID
da81dbb0e2da
041941f24d3d
439157f8ea55
[root@web130 ~]# docker start da8 #启动指定容器
[root@web130 ~]# docker restart da8 #将一个运行的容器先终止,然后在重启启动它
四、进入容器
#前文-d我们将容器放在后台运行,无法操作也无法看到容器中的信息,如何进入一个后台运行的容器,方法如下:
、attach命令
[root@web130 ~]# docker run --name ylt -itd ubuntu #创建一个名字为ylt的容器
7058cf192514f4a6de3340d86d61d6f2dbea0503f85ae35634fb2511cc026f6d
[root@web130 ~]# docker ps
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NMES
7058cf192514 ubuntu "/bin/bash" seconds ago Up seconds ylt
[root@web130 ~]# docker attach ylt #进入后台运行的容器
root@7058cf192514:/# ls
bin boot dev etc home lib lib64 media mnt opt proc root run sbin srv sys tmp usr var
root@7058cf192514:/# 注:当多窗同时通过attach命令连到容器的时候,所有窗口会同步显示。当某个窗口阻塞的时候,其他窗口无法执行命令
当一个窗口exit容器的时候另个也会退出。
、exec命令,最推荐的一种方式
#docker从1..0版本起提供了更加方便的exec命令,可以在容器内直接执行任意命令,同时如果多窗口执行,不会出现attach的问题:
[root@web130 ~]# docker start ylt #启动容器
ylt
[root@web130 ~]# docker exec -it 7058cf192514 /bin/bash #进入容器,可以多窗口执行
root@7058cf192514:/# ls
bin dev home lib64 mnt proc run srv tmp var
boot etc lib media opt root sbin sys usr
root@7058cf192514:/# exit
[root@web130 ~]#
、nsenter工具需要安装,此处不详细介绍
五、删除容器
#docker rm 删除一个终止的容器
#docker rm -f 可以强制删除一个正在运行容器
[root@web130 ~]# docker ps -a
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
7058cf192514 ubuntu "/bin/bash" minutes ago Up minutes ylt
da81dbb0e2da ubuntu "/bin/sh -c 'while t…" minutes ago Exited () minutes ago festive_mirzakhani
041941f24d3d ubuntu:14.04 "/bin/bash" About an hour ago Exited () About an hour ago nervous_jepsen
[root@web130 ~]# docker rm 041941f24d3d
[root@web130 ~]# docker ps #我们可以看到刚才启动的容器
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
7058cf192514 ubuntu "/bin/bash" minutes ago Up minutes ylt
17c54a92a4e8 ubuntu:latest "/bin/bash" About an hour ago Up About an hour quizzical_bhabha
[root@web130 ~]# docker rm ylt #运行中的容器无法删除
Error response from daemon: You cannot remove a running container 7058cf192514f4a6de3340d86d61d6f2dbea0503f85ae35634fb2511cc026f6d. Stop the container before attempting removal or force remove
[root@web130 ~]# docker rm -f ylt #可以强制删除运行中的容器,直接发送的是SIGKILL信号
ylt
[root@web130 ~]#
[root@web130 ~]# docker ps
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
17c54a92a4e8 ubuntu:latest "/bin/bash" About an hour ago Up About an hour quizzical_bhabha
[root@web130 ~]#
六、导入和导出容器
#其实就是一个容器迁移的过程,不用考虑容器是否为运行状态
、导出容器可以使用-o,或者输出重定向“>”
[root@web130 ~]# docker ps -a
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
da81dbb0e2da ubuntu "/bin/sh -c 'while t…" About an hour ago Exited () minutes ago festive_mirzakhani
041941f24d3d ubuntu:14.04 "/bin/bash" About an hour ago Exited () About an hour ago nervous_jepsen
[root@web130 ~]# docker export -o test_docker_run.tar da8 #-o
[root@web130 ~]# ls |grep test_docker*
test_docker_run.tar
[root@web130 ~]# docker export >test_docker_stop.tar #输出重定向
[root@web130 ~]# ls |grep test_docker
test_docker_run.tar
test_docker_stop.tar
[root@web130 ~]#
、导入容器
#导出的文件可以使用docker import 命令导入变成镜像,该命令格式为:
[root@web130 ~]# cat test_docker_run.tar |docker import - test/ubuntu:v1.
sha256:7528eea6db23ec008244e9f65205421fcaa164748054b25dbae1a00f84582b66
[root@web130 ~]# docker images
REPOSITORY TAG IMAGE ID CREATED SIZE
test/ubuntu v1. 7528eea6db23 seconds ago .8MB
#通过指定 URL 或者某个目录来导入
[root@web130 ~]#docker import http://example.com/exampleimage.tgz test/ubuntu:v1.0
【Docker】第三篇 Docker容器管理的更多相关文章
- Devops 开发运维高级篇之容器管理
Devops 开发运维高级篇之容器管理 安装docker Dockerfile镜像脚本入门制作 Harbor镜像仓库安装及使用 不过多解释docker直接秀基操 安装docker:(jenkins服务 ...
- Scala语言笔记 - 第三篇(容器方法篇)
Scala语言笔记 - 第三篇(容器方法篇) 目录 Scala语言笔记 - 第三篇(容器方法篇) map和flapMap方法: 最近研究了下scala语言,这个语言最强大的就是它强大的函数式编程( ...
- Docker系列三:Docker容器管理
Docker容器管理 1. 单一容器管理 1) 容器的启动 $ docker run --name gitlab-redis -d --volume /srv/docker/gitlab/redis: ...
- docker第三篇 镜像管理基础
docker 工作原理: 常用的命令docker run .create .start... 都是客户端命令 Docker Daemon 接收到客户端传过来的命令以后 docker daemon会根据 ...
- docker简单介绍----镜像和容器管理
docker可以分为三部分:docker镜像 docker仓库 docker容器 docker镜像:一个image可以包含一个镜像,也可以理解为一个系统模板,里面安装了相关应用,也可以是纯净版的 ...
- Docker&K8S&持续集成与容器管理--系列教程
前言 网络虚拟化 一 Docker简介 Docker介绍 → B站视频链接 Docker架构 → B站视频链接 二 Docker安装 Ubuntu Docker 安装 CentOS Docker ...
- Docker之单多/机容器管理
Compose是用于定义和运行多容器Docker应用程序的工具.通过Compose,您可以使用YAML文件来配置应用程序的服务.然后,使用一个命令,就可以从配置中创建并启动所有服务. Docker-C ...
- Docker 第三篇--构建Image
什么是 docker Image 和container? 我们先来看看官网是怎么说的. Docker Engine provides the core Docker technology that e ...
- docker 实践三:操作容器
在学习了 docker 镜像的内容后,我们在来看 docker 的另一个核心点:容器. 注:环境为 CentOS7,docker 19.03 docker 的容器是镜像的一个运行实例.docker 镜 ...
随机推荐
- BZOJ1022:[SHOI2008]小约翰的游戏John(博弈论)
Description 小约翰经常和他的哥哥玩一个非常有趣的游戏:桌子上有n堆石子,小约翰和他的哥哥轮流取石子,每个人取的时候,可以随意选择一堆石子,在这堆石子中取走任意多的石子,但不能一粒石子也不取 ...
- 20165302 敏捷开发与XP实践作业
20165302 敏捷开发与XP实践实验报告 一.提交点一 1.实验要求 参考 http://www.cnblogs.com/rocedu/p/6371315.html#SECCODESTANDARD ...
- boost的初步了解
本章介绍了 Boost C++ 库 Asio,它是异步输入输出的核心. 名字本身就说明了一切:Asio 意即异步输入/输出. 该库可以让 C++ 异步地处理数据,且平台独立. 异步数据处理就是指,任务 ...
- 看完了红米5 Plus发布会,我觉得魅蓝Note6降价降多了
没有意外,红米5 Plus在今天下午已经发布.这款以全面屏为卖点的手机机,将红米最低端的一个系列加价到了999元起步——这一切只是因为一个全面屏而已. 知道了红米5 Plus的售价之后,李楠大呼“降多 ...
- 【转】numpy-array自带的迭代器-----np.nditer
转自:https://www.jianshu.com/p/f2bd63766204 it = np.nditer(x, flags=['multi_index'], op_flags=['readwr ...
- Spring源码分析(二十)准备环境
摘要: 本文结合<Spring源码深度解析>来分析Spring 5.0.6版本的源代码.若有描述错误之处,欢迎指正. prepareRefresh函数主要是做些准备工作,例如对系统属性及环 ...
- 使用Ceph集群作为Kubernetes的动态分配持久化存储(转)
使用Docker快速部署Ceph集群 , 然后使用这个Ceph集群作为Kubernetes的动态分配持久化存储. Kubernetes集群要使用Ceph集群需要在每个Kubernetes节点上安装ce ...
- psql: 致命错误: 对用户"user1"的对等认证失败
操作系统:Debian8 登录pg时可能会有提示错误: $ psql -U user1 -d exampledb psql: 致命错误: 对用户"user1"的对等认证失败 打开以 ...
- “error : unknown filesystem”的解决的方法
解决方法例如以下: 1:首先使用ls命令显示出ubuntu分区的安装信息: 1 grub rescue>ls 通常会罗列出全部磁盘的分区信息,比方(hd0,msdos1)(hd0,msdos2) ...
- 【html】文字排版
Web开发过程中文字排版,默认的情况下,行末的长单词会撑开容器. 我们想要的是(像word一样.能够自动换行.既不撑大容器.也不强制拆开行末单词.并且不会隐藏行末单词的多余字母) ①不能撑开容器 ②完 ...