Docker容器使用方法详解

目录
  • 一、新建并启动

一、新建并启动

所需要的命令主要为 dockerrun。例如,下⾯的命令输出⼀个“HelloWorld”,之后终⽌容器。

$ docker run ubuntu:16.04 /bin/echo 'Hello world' Hello world

这跟在本地直接执⾏ /bin/echo 'hello world' ⼏乎感觉不出任何区别。下⾯的命令则启动⼀个 bash 终端,允许⽤户进⾏交互。

$ docker run -t -i ubuntu:16.04 /bin/bash root@af8bae53bdd3:/#

其中, -t 选项让Docker分配⼀个伪终端(pseudo-tty)并绑定到容器的标准输⼊上, -i 则让容器的 标准输⼊保持打开。 在交互模式下,⽤户可以通过所创建的终端来输⼊命令,例如:

root@af8bae53bdd3:/# pwd /root@af8bae53bdd3:/# ls bin boot dev etc home lib lib64 media mnt opt proc root run sbin srv sys tmp usr var

当利⽤ docker run 来创建容器时,Docker 在后台运⾏的标准操作包括:

①检查本地是否存在指定的镜像,不存在就从公有仓库下载

②利⽤镜像创建并启动⼀个容器 ③分配⼀个⽂件系统,并在只读的镜像层外⾯挂载⼀层可读写层 ④从宿主主机配置的⽹桥接⼝中桥接⼀个虚拟接⼝到容器中去 ⑤从地址池配置⼀个 ip 地址给容器 ⑥执⾏⽤户指定的应⽤程序 ⑦执⾏完毕后容器被终⽌ 二、启动已终止容器

可以利⽤ docker container start 命令,直接将⼀个已经终⽌的容器启动运⾏。

容器的核⼼为所执⾏的应⽤程序,所需要的资源都是应⽤程序运⾏所必需的。除此之外,并没有其它 的资源。可以在伪终端中利⽤ ps 或 top 来查看进程信息。

root@ba267838cc1b:/# ps PID TTY TIME CMD 1 ? 00:00:00 bash 11 ? 00:00:00 ps

可⻅,容器中仅运⾏了指定的 bash 应⽤。这种特点使得 Docker 对资源的利⽤率极⾼,是货真价实的轻量级虚拟化。

三、后台运行

更多的时候,需要让 Docker 在后台运⾏⽽不是直接把执⾏命令的结果输出在当前宿主机下。此时,可以通过添加 -d 参数来实现。下⾯举两个例⼦来说明⼀下。

1.如果不使⽤ -d 参数运⾏容器。

$ docker run ubuntu:16.04 /bin/sh -c "while true; do echo hello world; sleep 1; done" hello world hello world hello world hello world

容器会把输出的结果 (STDOUT) 打印到宿主机上⾯。

2.如果使⽤了 -d 参数运⾏容器。

$ docker run -d ubuntu:16.04 /bin/sh -c "while true; do echo hello world; sleep 1; done"77b2dc01fe0f3f1265df143181e7b9af5e05279a884f4776ee75350ea9d8017a

此时容器会在后台运⾏并不会把输出的结果 (STDOUT) 打印到宿主机上⾯(输出结果可以⽤ docker logs 查看)。

注: 容器是否会⻓久运⾏,是和 docker run 指定的命令有关,和 -d 参数⽆关。

使⽤ -d 参数启动后会返回⼀个唯⼀的 id,也可以通过 docker container ls 命令来查看容器信息。

$ docker container ls CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES 77b2dc01fe0f ubuntu:16.04 /bin/sh -c 'while tr 2 minutes ago Up 1 minute agitat ed_wright

要获取容器的输出信息,可以通过 docker container logs 命令。

$ docker container logs [container ID or NAMES] hello world hello world hello world . . .

四、终止容器

可以使⽤ docker container stop 来终⽌⼀个运⾏中的容器。此外,当 Docker 容器中指定的应⽤终结时,容器也⾃动终⽌。

例如对于上⼀章节中只启动了⼀个终端的容器,⽤户通过 exit 命令或 Ctrl+d 来退出终端时,所创建的 容器⽴刻终⽌。终⽌状态的容器可以⽤ docker container ls -a 命令看到。例如

$ docker container ls -a CONTAINER ID IMAGE COMMAND CREATED ST ATUS PORTS NAMES ba267838cc1b ubuntu:16.04 "/bin/bash" 30 minutes ago Ex ited (0) About a minute ago trusting_newton

处于终⽌状态的容器,可以通过 docker container start 命令来重新启动。

此外, docker container restart 命令会将⼀个运⾏态的容器终⽌,然后再重新启动它。

五、进入容器

在使⽤ -d 参数时,容器启动后会进⼊后台。某些时候需要进⼊容器进⾏操作:exec 命令 -i -t 参数。

只⽤ -i 参数时,由于没有分配伪终端,界⾯没有我们熟悉的 Linux 命令提示符,但命令执⾏结果仍 然可以返回。

当 -i -t 参数⼀起使⽤时,则可以看到我们熟悉的 Linux 命令提示符。

$ docker run -dit ubuntu:16.04 69d137adef7a8a689cbcb059e94da5489d3cddd240ff675c640c8d96e84fe1f6 $ docker container ls CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES 69d137adef7a ubuntu:16.04 "/bin/bash" 18 seconds ago Up 17 secon ds zealous_swirles $ docker exec -i 69d1 bash lsbin boot dev ... $ docker exec -it 69d1 bash root@69d137adef7a:/#

如果从这个 stdin 中 exit,不会导致容器的停⽌。这就是为什么推荐⼤家使⽤ docker exec 的原因。

更多参数说明请使⽤ docker exec --help 查看。

六、删除容器

可以使⽤ docker container rm 来删除⼀个处于终⽌状态的容器。例如:

$ docker container rm trusting_newton trusting_newton

也可⽤使⽤ docker rm 容器名来删除,如果要删除⼀个运⾏中的容器,可以添加 -f 参数。Docker 会 发送 SIGKILL 信号给容器。

⽤ docker container ls -a (或者docker ps -a) 命令可以查看所有已经创建的包括终⽌状态的容器, 如果数量太多要⼀个个删除可能会很麻烦,⽤下⾯的命令可以清理掉所有处于终⽌状态的容器。

$ docker container prune

或者

$ docker ps -aq

到此这篇关于Docker容器使用方法详解的文章就介绍到这了,更多相关Docker容器内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • Docker容器间通信与外网通信的操作

    一 容器间通信 1.容器的网络共享 处于这个模式下的docker容器会共享一个网络栈,这样两个容器之间可以使用localhost高效快速通信. 使用于web服务器与应用服务器之间的通信. ##清空实验环境 [root@server1 ~]# docker ps -a CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES ##默认网络创建容器 [root@server1 ~]# docker run -it --name vm1 ubuntu

  • Docker容器数据卷介绍及操作示例

    目录 容器数据卷介绍 什么是数据卷 数据卷能做什么? 特点 Docker 容器数据卷操作 直接命令添加数据卷 dockerfile 添加数据卷 Docker 数据卷容器 数据卷容器简介 案例演示 容器数据卷介绍 什么是数据卷 将运用与运行的环境打包形成容器运行,运行可以伴随着容器,但是我们对数据的要求是持久化的. 容器之间希望有可能共享数据. Docker 容器产生的数据,如果不通过 docker commit 生成新的镜像,使得数据做为镜像的一部分保存下载,那么当容器删除后,数据自然也就没有了

  • docker容器下配置jupyter notebook的操作

    docker容器下配置jupyter notebook,主要是为了编写python代码,更具体点是做深度学习的开发. jupyter web形式最高效的使用方式就是部署在云上,不管是cpu云服务器还是gpu的云服务器,都能快速启动使用. 而docker的出现又方便了很多在部署使用上. - 安装 docker docker分为docker CE和docker EE,一般使用docker CE(社区版本). docker可以在Linux(ubuntu.centos).MacOS.Windows或者树

  • Docker镜像与容器的导入导出操作实践

    目录 一.前言 二.docker镜像的导入和导出 1.docker镜像的导出 2.docker镜像的导入 三.docker容器的导入和导出 1.docker容器的导出 2.docker容器的导入 四.总结 一.前言 随着容器技术的发展,现在很多的应用程序系统都会选择使用docker容器进行部署,但是有时候使用docker容器进行部署的时候会遇到问题,比如说我们的应用程序里面需要依赖其他第三方的镜像,如果这时候服务器是在内网不能连接外网的情况下,那么就无法部署了.基于这种情况,docker官方支持

  • Docker容器从镜像恢复代码的操作步骤

    有时候代码丢失了需要从容器运行的镜像中恢复出所需代码,此时仅需在容器运行的服务器进行简单的几步操作,就能提取出打包镜像时使用的代码 查看所有容器: docker container ls -a 根据容器id进入到指定容器: docker exec -ti id /bin/bash 拷贝容器内目录到服务指定文件夹: docker container cp id:/usr/local/tomcat/webapps/province-admin /home/test/province-admin 经过

  • docker容器的创建及常用操作命令详解

    目录 docker容器简介 1.创建容器 2.查看本机的容器列表 3.停止和启动一个容器 4.删除容器 5.查看容器内容 6.复制命令 7.进入容器 docker容器简介 容器就是对外提供服务的一个实例. 容器启动的必要条件:容器内至少有一个进程运行在前台 1.创建容器 # 格式 docker run [参数] [镜像名称] [运行容器的启动命令] # 参数 -d : 以守护进程的方式运行一个容器 docker run -d [镜像名称] [cmd] --name : 指定容器的名称 docke

  • docker容器访问宿主机的MySQL操作

    背景: 有一个flask项目提供接口,使用docker容器构建并且运行,MySQL在宿主机运行,需要在容器中可以让flask连接上宿主机的mysql 使用ifconfig命令可以看到,有一个docker0和eth0,在docker容器中可以通过eth0的IP地址加上端口号(3306)这样就可以连接上宿主机的MySQL了:另外,nginx可以通过docker0的IP地址加上构建容器时指定的端口号进行访问容器. 补充:docker的mysql容器运行正常,但是宿主机却连不上数据库,解决方法来啦 do

  • docker 查看容器的挂载目录操作

    只显示Docker容器挂载目录信息 docker inspect --format "{{.Config.Volumes}}" 369a1376f78c 显示Docker容器和物理主机挂载目录信息 方法一 docker inspect -f "{{.Mounts}}" 369a1376f78c 方法二 docker inspect 369a1376f78c | grep Mounts -A 50 补充:Docker 显示某个容器所有的挂载目录 docker insp

  • Docker容器使用方法详解

    目录 一.新建并启动 一.新建并启动 所需要的命令主要为 dockerrun.例如,下⾯的命令输出⼀个“HelloWorld”,之后终⽌容器. $ docker run ubuntu:16.04 /bin/echo 'Hello world' Hello world 这跟在本地直接执⾏ /bin/echo 'hello world' ⼏乎感觉不出任何区别.下⾯的命令则启动⼀个 bash 终端,允许⽤户进⾏交互. $ docker run -t -i ubuntu:16.04 /bin/bash

  • Python魔法方法 容器部方法详解

    这篇文章主要介绍了Python魔法方法 容器部方法详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下 为了加深印象,也为了以后能够更好的回忆,还是记录一下. 序列(类似集合,列表,字符串),映射(类似字典)基本上是元素的集合,要实现他们的基本行为(协议),不可变对象需要两个协议,可变对象需要4个协议. __len__(self):返回元素的数量,(为不可变对象需要的协议之一)=====> len __iter__返回一个迭代器,具有了__nex

  • 详解如何进入、退出docker容器的方法

    1 启动docker服务 首先需要知道启动docker服务是: service docker start 或者: systemctl start docker 2 关闭docker服务 关闭docker服务是: service docker stop 或者: systemctl stop docker 3 启动docker某个image(镜像)的container(容器) Docker的镜像称为image,容器称为container. 对于Docker来说,image是静态的,类似于操作系统快照

  • Linux Docker安装wordpress的方法详解教程

    安装mysql服务 下载mysql镜像: docker pull mysql 创建mysql容器并后台运行,指定数据库密码是123456.-e指定环境变量. docker run --name mysql_db -e MYSQL_ROOT_PASSWORD=123456 -d mysql 使用官方的wordpress wordpress镜像daocloud.io: docker pull daocloud.io/daocloud/dao-wordpress:latest 拉取镜像前请先登录: d

  • Docker run 命令的使用方法详解

    注意,本文基于最新的Docker 1.4文档翻译. Docker会在隔离的容器中运行进程.当运行 docker run命令时,Docker会启动一个进程,并为这个进程分配其独占的文件系统.网络资源和以此进程为根进程的进程组.在容器启动时,镜像可能已经定义了要运行的二进制文件.暴露的网络端口等,但是用户可以通过docker run命令重新定义(译者注:docker run可以控制一个容器运行时的行为,它可以覆盖docker build在构建镜像时的一些默认配置),这也是为什么run命令相比于其它命

  • Docker部署安装Redash中文版的方法详解

    1安装说明 相比Linux环境本地安装而言,Docker安装方式更为简便,Docker脚本化安装过程会自动获取Redis.postgres.Python3.7镜像,构造Redash最新的后台server.worker.schedule镜像.前端npm依赖包安装和前端最新代码打包是通过卷映射方式挂载到server容器,因此这些工作需要人工一次执行:另外构建初始数据库表结构也需要人工一次执行.这些动作执行完毕,启动Docker容器就可以访问了.由于安装过程需要访问国外服务器,极难一次安装成功,需要反

  • Spring-IOC容器中的常用注解与使用方法详解

    Spring是什么? Spring是一个轻量级Java开发框架,最早有Rod Johnson创建,目的是为了解决企业级应用开发的业务逻辑层和其他各层的耦合问题.它是一个分层的JavaSE/JavaEE full-stack(一站式)轻量级开源框架,为开发Java应用程序提供全面的基础架构支持.Spring负责基础架构,因此Java开发者可以专注于应用程序的开发. 体系结构 核心容器(Core Container):Spring的核心容器是其他模块建立的基础,有Spring-core.Spring

  • SpringBoot向容器注册bean的方法详解

    目录 简介 法1:@Component 法2:@Configuration+@Bean 法3:@Import等 法4:FactoryBean 简介 本文用示例介绍SpringBoot如何向容器注册bean(即:将对象加入容器). 法1:@Component (@Controller/@Service/@Repository也可以,因为它里边包含@Component) 默认是加载和Application类所在同一个目录下的所有类,包括所有子目录下的类. 当启动类和@Component分开时,如果启

  • Docker中容器数据卷详解

    目录 什么是容器数据卷 数据的覆盖问题 使用数据卷 方式一:直接使用命令挂载 -v 测试挂载卷 方式二:Dockerfile文件 数据卷命令 查看数据卷 方式一:docker inspect 容器ID 方式二:docker volume inspect juming-nginx 挂载三种方式 扩展 什么是容器数据卷 从docker的理念说起,docker将应用和环境打包成一个镜像,运行镜像(生成容器)就可以访问服务了. 如果数据都存在容器中,那么删除容器,数据就会丢失!需求:数据可以持久化 My

  • Docker Swarm入门实例详解

    Swarm 在 Docker 1.12 版本之前属于一个独立的项目,在 Docker 1.12 版本发布之后,该项目合并到了 Docker 中,成为 Docker 的一个子命令.目前,Swarm 是 Docker 社区提供的唯一一个原生支持 Docker 集群管理的工具.它可以把多个 Docker 主机组成的系统转换为单一的虚拟 Docker 主机,使得容器可以组成跨主机的子网网络. 1. Swarm 认识 Swarm 是目前 Docker 官方唯一指定(绑定)的集群管理工具.Docker 1.

随机推荐