当前位置: 首页 > news >正文

Docker容器(三)

一、创建容器

  容器是Docker另一个核心的概念,简单来说,容器是镜像的一个运行实例,所不同的是,镜像是静态的只读文件,而容器带有运行时需要的可写文件层

1.1. 新建容器

  使用docker create命令来新建容器

[root@rsync131 ~]# docker images
REPOSITORY          TAG                 IMAGE ID            CREATED             SIZE
docker.io/centos    latest              5182e96772bf        6 weeks ago         200 MB
[root@rsync131 ~]# docker create centos
b9dd06b5dcba561b178b1892631cd318f0babd4a9a3f067761963a6ab61fe078
[root@rsync131 ~]# docker ps -a
CONTAINER ID        IMAGE               COMMAND             CREATED             STATUS              PORTS               NAMES
b9dd06b5dcba        centos              "/bin/bash"         9 seconds ago       Created                                 sleepy_sammet

1.2. 启动容器

  使用docker start命令来启动容器

[root@rsync131 ~]# docker start b9dd06b5dcba
b9dd06b5dcba
[root@rsync131 ~]# docker ps -a
CONTAINER ID        IMAGE               COMMAND             CREATED              STATUS                     PORTS               NAMES
b9dd06b5dcba        centos              "/bin/bash"         About a minute ago   Exited (0) 4 seconds ago                       sleepy_sammet

  PS:不知道为什么我使用这样的方式是启动不了容器的,待解释

1.3. 新建并启动容器

  一般在创建容器的是我们不会使用上面的两步的方式来进行创建,有个更简单的方式就是在创建的时候直接启动

  使用docker run 命令,创建并启动容器

[root@rsync131 ~]# docker run -it -d --name test_centos centos
159a08c11fece853626516ab94b401464efd85d69c1f88706ec17a29178fee54
[root@rsync131 ~]# docker ps
CONTAINER ID        IMAGE               COMMAND             CREATED             STATUS              PORTS               NAMES
159a08c11fec        centos              "/bin/bash"         3 seconds ago       Up 3 seconds                            test_centos


docker run:死命令
-i:让容器的标准输入保持打开
-t:分配个伪终端
-d:守护状态运行
--name:指定容器名字参数
test_centos:容器名字
centos:镜像名或者镜像ID

  这里我们说一下docker run执行的时候都干了什么

    检查本地镜像是否存在,不存在则会自动去公有仓库去下载

    利用镜像创建容器,并启动容器

    分配一个文件系统给容器,并在只读的镜像层外面挂载一层可读写层

    从宿主主机配置的网桥接口中桥接一个虚拟接口到容器中

    从网桥的地址池配置一个IP给容器

    执行用户指定的应用程序

1.4. 查看容器运行日志

  使用命令docker logs 来查看日志

[root@rsync131 ~]# docker ps
CONTAINER ID        IMAGE               COMMAND             CREATED             STATUS              PORTS               NAMES
159a08c11fec        centos              "/bin/bash"         21 minutes ago      Up 21 minutes                           test_centos
[root@rsync131 ~]# docker logs 159a08c11fec

 

二、终止容器

2.1. 终止容器

  使用docker stop 来终止正在运行的容器

语法格式:
docker stop 容器名

常用选项:
-t,--time[=10] : 10秒后发送终止信号

  使用docker kill 命令可以直接终止容器

  docker kill 命令会直接发送SIGKILL信号来强行终止容器

[root@rsync131 ~]# docker ps
CONTAINER ID        IMAGE               COMMAND             CREATED             STATUS              PORTS               NAMES
159a08c11fec        centos              "/bin/bash"         29 minutes ago      Up 29 minutes                           test_centos
[root@rsync131 ~]# docker stop 159a08c11fec
[root@rsync131 ~]# docker kill 159a08c11fec

2.2. 查看终止的容器

  使用docker ps 只是可以查看正在运行的容器

  使用docker ps -a 则可以看到所有的容器包括正在运行的和已经终止的容器

[root@rsync131 ~]# docker ps
CONTAINER ID        IMAGE               COMMAND             CREATED             STATUS              PORTS               NAMES
159a08c11fec        centos              "/bin/bash"         30 minutes ago      Up 30 minutes                           test_centos
[root@rsync131 ~]# docker ps -a
CONTAINER ID        IMAGE               COMMAND             CREATED             STATUS                     PORTS               NAMES
159a08c11fec        centos              "/bin/bash"         30 minutes ago      Up 30 minutes                                  test_centos
b9dd06b5dcba        centos              "/bin/bash"         36 minutes ago      Exited (0) 9 minutes ago                       sleepy_sammet

  

2.3. 启动和重启已经终止的容器

  已经终止的容器我们可以使用docker start 命令来启动

  也可以使用docker restart 命令将一个正在运行的容器先stop后start

[root@rsync131 ~]# docker ps -a
CONTAINER ID        IMAGE               COMMAND             CREATED             STATUS                     PORTS               NAMES
159a08c11fec        centos              "/bin/bash"         30 minutes ago      Up 30 minutes                                  test_centos
b9dd06b5dcba        centos              "/bin/bash"         36 minutes ago      Exited (0) 9 minutes ago                       sleepy_sammet
[root@rsync131 ~]# docker start b9dd06b5dcba
b9dd06b5dcba
[root@rsync131 ~]# docker restart 159a08c11fec
159a08c11fec

  

三、进入容器

  在使用 -d 选项来运行容器的时候,容器会在后台运行,用户是无法看到容器的信息的,也无法进入操作

  这个时候如果我们要进入容器进行操作,应该怎么办呢?在docker 中进入docker中的方法有很多种,比如官方的attach和exec命令,以及第三方的nsenter工具(这个没有用过 最常用的还是exec)等

3.1. attach 命令

attach命令是docker自带的命令
语法格式:
docker attach [--detach-keys[=[]]] [--no-stdin] [--sig-proxy[=true]] CONTAINER

支持的常用主要选项:
--detach-keys[=[]]:指定退出attach模式的快捷键序列,默认是CTRL+p CTRL-q
--no-stdin=true|false :是否关闭标准输入,默认true
--sig-proxy=true|false : 是否代理收到的系统信号给应用程序,默认是true
[root@rsync131 ~]# docker ps
CONTAINER ID        IMAGE               COMMAND             CREATED             STATUS              PORTS               NAMES
159a08c11fec        centos              "/bin/bash"         41 minutes ago      Up 10 minutes                           test_centos
[root@rsync131 ~]# docker attach 159a08c11fec
[root@159a08c11fec /]# 

PS:使用attach命令进入容器是很不方便的,就是这个命令只允许一个人使用容器,在开多个窗口同时用attach进入容器的时候,窗口执行的命令会同步,当一个窗口阻塞了,其他窗口就不能玩了,所有不用这个命令,太坑了

3.2. exec 命令

  为了解决上面的坑,docker在1.3.0版本提供了exec这个命令解决了attach命令的坑

语法格式:
docker exec  [-d|--detach] [--detach-keys[=[]]] [-i|--interactive] [--privileged] [-t|--tty] [-u|--user[=USER]] CONTAINER COMMAND [ARG....]

主要选项参数:
-i, --interactive=true|false: 打开标准输入接收用户输入的命令,默认false
--privileged=true|false :是否给执行命令以高权限,默认false
-t,--tty=true|false:分配伪终端 默认false
-u,--user="" : 执行命令的用户或者ID
[root@rsync131 ~]# docker exec -it 159a08c11fec bash
[root@159a08c11fec /]# ls
anaconda-post.log  bin  dev  etc  home  lib  lib64  media  mnt  opt  proc  root  run  sbin  srv  sys  tmp  usr  var
[root@159a08c11fec /]#

  可以看到,一个bash终端打开了,在不影响容器内其他应用的前提下,用户可以很容易的与容器进行交互

PS:通过制定 -it 参数保持标准输入,并且分配个伪终端,是很推荐的方式哦

四、删除容器

   使用docker rm 命令来删除处于终止或者退出状态的容器

语法格式:
docker rm [-f|--force] [-l|--link] [-v|--volumes] CONTAINER [CONTAINER.....]

主要选项参数:
-f,--force=false:是否强行终止并删除运行中的容器
-l,--link=false:删除容器的链接,但是保留容器
-v,--volumes=false:删除容器挂载的数据卷
[root@rsync131 ~]# docker ps -a
CONTAINER ID        IMAGE               COMMAND             CREATED             STATUS                         PORTS               NAMES
159a08c11fec        centos              "/bin/bash"         2 hours ago         Up About an hour                                   test_centos
b9dd06b5dcba        centos              "/bin/bash"         2 hours ago         Exited (0) About an hour ago                       sleepy_sammet
[root@rsync131 ~]# docker rm b9dd06b5dcba
b9dd06b5dcba
[root@rsync131 ~]# docker ps -a
CONTAINER ID        IMAGE               COMMAND             CREATED             STATUS              PORTS               NAMES
159a08c11fec        centos              "/bin/bash"         2 hours ago         Up About an hour                        test_centos

  默认情况下,docker rm命令只能删除已经终止的容器,不能删除运行中的容器,想要删除运行中的容器可以使用 -f 参数,来强制的删除

五、容器的导入与导出

  在做容器迁移的时候我们就要先把容器导出,然后在导入到其他的地方

5.1. 导出容器

  使用命令docker export 命令来导出容器

语法格式:
docker export [-o|--output[=""]] CONTAINER

主要选项参数:
-o,--output:指定导出的tar文件名
[root@rsync131 ~]# docker ps -a
CONTAINER ID        IMAGE               COMMAND             CREATED             STATUS              PORTS               NAMES
159a08c11fec        centos              "/bin/bash"         2 hours ago         Up About an hour                        test_centos
[root@rsync131 ~]# docker export -o centos_test.tar.gz 159a08c11fec
或者
[root@rsync131 ~]# docker export 159a08c11fec > centos_test.tar.gz
[root@rsync131 ~]# ll
总用量 273536
-rw-------. 1 root root      1513 8月  20 20:25 anaconda-ks.cfg
-rw-------  1 root root 280093696 9月  23 11:51 centos_test.tar.gz

5.2. 导入容器

  使用命令docker import 导入变成镜像

语法格式:
docker import [-c|--change[=[]]] [-m|--messge[=MESSAGE]] file|URL|- [REPOSITORY[:TAG]]

用户可以通过-c 选项在导入的同时执行对容器进行修改的Dockerfile指令
[root@rsync131 ~]# docker ps -a
CONTAINER ID        IMAGE               COMMAND             CREATED             STATUS              PORTS               NAMES
[root@rsync131 ~]# ll
总用量 273536
-rw-------. 1 root root      1513 8月  20 20:25 anaconda-ks.cfg
-rw-r--r--  1 root root 280093696 9月  23 11:52 centos_test.tar.gz
[root@rsync131 ~]# docker import centos_test.tar.gz centos:1.0
sha256:f54ee7febeda5d3d8af11cc4756c1e6661feb84b2af6280654ef07ddf8bdead2
[root@rsync131 ~]# docker images
REPOSITORY          TAG                 IMAGE ID            CREATED             SIZE
centos              1.0                 f54ee7febeda        5 seconds ago       271 MB
docker.io/centos    latest              5182e96772bf        6 weeks ago         200 MB

  

转载于:https://www.cnblogs.com/zhujingzhi/p/9656350.html

相关文章:

  • RANSAC - 随机采样一致性算法
  • [译]JavaScript Symbols, Iterators, Generators, Async/Await, and Async Iterators
  • 利用哈希表实现数组的去重以及利用delete批量删除数组元素
  • eclipse +VISUALSVN SERVER 创建版本控制器,防止误操作(可视化操作,简单方便,不需要修改配置文件)...
  • 3.GoolgeProtoBuffer序列化反序列化
  • C语言-删除注释
  • c#调用java
  • java 动态代理
  • 字符缓冲流BufferedWriter和BufferedWriter
  • 修改BASH的配色
  • OpenStack快照分析:(三)从磁盘启动云主机离线(在线)快照分析
  • php substr说明
  • alterdialog
  • MobIM-API说明
  • mysql5.5.15配置主从数据库
  • 2017-08-04 前端日报
  • 345-反转字符串中的元音字母
  • 4月23日世界读书日 网络营销论坛推荐《正在爆发的营销革命》
  • Angular4 模板式表单用法以及验证
  • el-input获取焦点 input输入框为空时高亮 el-input值非法时
  • Java Agent 学习笔记
  • JavaScript的使用你知道几种?(上)
  • MySQL-事务管理(基础)
  • nginx 配置多 域名 + 多 https
  • python 装饰器(一)
  • RxJS 实现摩斯密码(Morse) 【内附脑图】
  • Solarized Scheme
  • Vue UI框架库开发介绍
  • vue总结
  • 阿里研究院入选中国企业智库系统影响力榜
  • 基于遗传算法的优化问题求解
  • 判断客户端类型,Android,iOS,PC
  • 前端攻城师
  • 前端面试之CSS3新特性
  • 使用iElevator.js模拟segmentfault的文章标题导航
  • 双管齐下,VMware的容器新战略
  • 一道闭包题引发的思考
  • 职业生涯 一个六年开发经验的女程序员的心声。
  • 字符串匹配基础上
  • ​猴子吃桃问题:每天都吃了前一天剩下的一半多一个。
  • # Swust 12th acm 邀请赛# [ E ] 01 String [题解]
  • #1015 : KMP算法
  • #多叉树深度遍历_结合深度学习的视频编码方法--帧内预测
  • #我与Java虚拟机的故事#连载18:JAVA成长之路
  • (04)odoo视图操作
  • (07)Hive——窗口函数详解
  • (二)换源+apt-get基础配置+搜狗拼音
  • (二开)Flink 修改源码拓展 SQL 语法
  • (官网安装) 基于CentOS 7安装MangoDB和MangoDB Shell
  • (一)VirtualBox安装增强功能
  • (转) ns2/nam与nam实现相关的文件
  • (转)EOS中账户、钱包和密钥的关系
  • (转)nsfocus-绿盟科技笔试题目
  • (转)大型网站的系统架构
  • (转)关于pipe()的详细解析