【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 镜 ...
随机推荐
- Linux - 常用归档、压缩命令
1. ncompress compress命令是一个相当古老的 unix 档案压缩指令,压缩后的文件会加上一个 .Z 的后缀名,默认不会保留源文件.compress只能对文件进行压缩,若要压缩目录,先 ...
- Python学习之路 (一)开发环境搭建
前言 python3应该是Python的趋势所在,当然目前争议也比较大,这篇随笔的主要目的是记录在centos6.7下搭建python3环境的过程 以及碰到的问题和解决过程. 另外,如果本机安装了py ...
- saltstack之sls文件配置
state模块 state模块会调用它的sls函数处理一个以.sls结尾的配置文件. sls文件是YAML语言来进行描述的 缩进 不要使用`tab`因为tab是四个空格,而YAML是使用两个空格 冒号 ...
- iptables传输数据包的过程
IPTABLES传输数据包的过程 大概过程如图所示: 1. 数据包进入网卡时,首先进入PREROUTING链,linux内核会判断数据包的目的IP是否为本地主机 2. 如果数据包的目的IP是本地主机, ...
- ZOJ3211-Dream City(贪心思想+变形的01背包)
Dream City Time Limit:1000MS Memory Limit:32768KB 64bit IO Format:%lld & %llu Submit Sta ...
- openshift 持续集成与部署 -- 构建部署流水线
Jenkins持续构建说得更直白点,就是各种项目的"自动化"编译.打包.分发部署.j跟svn.git能无缝集成,也支持直接与知名源代码托管网站,比如github.bitbucket ...
- 【vue】vue依赖安装如vue-router、vue-resource、vuex等
方式一: 最直接的方式为在 package.json中添加如图依赖配置,然后项目 cnpm install即可 方式二: 根据vue项目的搭建教程,接下来记录下如何在Vue-cli创建的项目中安装vu ...
- DBlink的创建与删除
创建方式一: create [public] database link link名称 connect to 对方数据库用户identified by 对方数据库用户密码 using '对方数据库i ...
- CentOS 7 配置阿里云本地yum源
删除原有的yum源: rm -f /etc/yum.repos.d/* 重新下载阿里云的yum源: wget -O /etc/yum.repos.d/CentOS-Base.repo http://m ...
- Android TV 全屏无标题
想要全部窗口全屏无标题,修改 res\values\styles.xml 可设置主题和样式 <resources> <!-- Base application theme, depe ...