Docker教程:使用容器(简单示例)

如果你是Docker的新手,看一下你应该学习的一些基础命令,以便开始管理容器。

Docker对软件开发生命周期产生了巨大影响,使得大规模软件部署变得简单而且安全。这个教程将介绍运行、启动、停止和删除Docker容器的基础知识。

Docker使得在不同的操作系统上使用不同的编程语言很容易,而所有这些都在同一主机上实现。

在Docker之后部署你的软件变得更加容易,你不必担心错过系统配置或先决条件。

Docker与虚拟机

如果你正使用虚拟运行你的软件,为什么还需要Docker来取代呢?

它们之间的主要区别在于Docker是一个在你的本机操作系统中运行的独立进程,而虚拟机是一个完整的隔离操作系统,它在主机操作系统之上运行,需要更多时间来加载。所以Docker比虚拟机有更多优势,例如:

  • 加载速度与虚拟机不同,所需的硬件资源很少。
  • 在同一操作系统上同时运行多个Docker容器。
  • 你可以修改容器并对其进行部署,或将Docker文件定义提供给朋友,以便在同一环境中工作。

实际上,Docker不是虚拟机的替代品,而是解决特定问题。

假设你的应用程序需要3个或更多在不同操作系统上运行的服务,那么你可以在同一主机上平稳运行3个容器,而不是在同一主机上运行3个虚拟机。听起来很棒!

运行你的容器

在开始之前,请确保已正确安装Docker并准备好接受命令。在新的终端窗口中键入以下命令:

$ docker -v

以上命令输出PC上安装的Docker版本:

Docker version 17.12.0-ce-rc2, build f9cde63

是时候开始运行容器了:

$ docker container run alpine echo "Hello World"

当您第一次运行上述命令时,你应该在终端窗口中看到与此类似的输出:

这很容易,不是吗?尝试再次运行相同的命令:

$ docker container run alpine echo "Hello World"

运行上述命令的第二,第三或第n次,你应该只在终端中看到此输出:

Hello World

现在你已成功运行容器,现在是时候分析究竟发生了什么。查看以下命令:

$ docker container run alpine echo "Hello World"

该命令包含多个部分。首先,你有“docker”这个词。这是Docker命令行界面(CLI)的名称,用于与负责运行容器的Docker引擎进行交互。

接下来,您有单词“container”,它表示你正在使用的上下文。

再下一步是 实际要执行的命令run。

现在,还需要告诉Docker运行哪个容器。在这里,运行的是 alpine 容器。

最后,需要定义在容器运行时,应在容器内执行的进程或任务类型。这是命令的最后一部分,echo "Hello World"。

在容器内运行进程

既然已经了解了运行容器的命令的各个部分,请尝试在另一个容器中运行不同的进程:
$ docker container run centos ping -c 5 127.0.0.1

输出如下:

在前面的示例中,使用的容器镜像是CentOS,并且在CentOS容器内执行的进程是ping -c 5 127.0.0.1,它将环回地址ping五次直到它停止。

第一行如下:

Unable to find image 'centos:latest' locally

这告诉你Docker没有在系统的本地缓存中找到名为centos:latest的镜像。因此,Docker知道它必须从存储容器的某个镜像源中提。

默认情况下,Docker环境配置为从hub.docker.com的Docker Hub中提取镜像。这由第二行表示如下:

latest: Pulling from library/centos

接下来的三行输出如下:

85432449fd0f: Pull completeDigest: sha256:3b1a65e9a05...Status:

这告诉您Docker已成功从Docker Hub中提取了镜像centos:latest。

后续的输出都是由容器内运行的进程生成的,这里运行的是ping工具。

你可能还注意到latest这个关键字出现了几次。每个映像都有一个版本(也称为标记),如果没有明确指定版本,则Docker会自动其视为最新版本。

如果在系统上再次运行这个容器,将不会输出之前的五行,因为Docker将在本地缓存容器映像,因此不必先下载它。试试是不是这样。

运行一个随机引用容器

为了运行随机语句容器,需要一个生成随机语句的算法。可以在此处[1]找到生成这些随机语句的API。
现在的目标是要在容器内运行一个进程,每5秒生成一条随机语句,并且输出到STDOUT:

按Ctrl + C停止脚本。这是输出:

每个响应都是一个JSON格式的字符串,包含引号,作者及其类别。
现在,让这个容器后台运行。为此,需要将前面的脚本缩成一行,并使用 /bin/sh -c “…” 来执行。Docker 的表达式如下:

$ docker container run -d --name quotes alpine \  /bin/sh -c "while :; do wget -qO- https://talaikis.com/api/quotes/random; printf '\n'; sleep 5; done"

上面的表达式,你使用了两个命令行参数,-d 和--name。-d告诉Docker以一个Linux守护进程的方式运行容器。-name参数用于为容器指定显式名称。

如果您未指定显式容器名称,Docker将自动为容器分配一个随机但唯一的名称。这个名字将由一位着名科学家的名字和一个形容词组成。

诸如,“boring_borg”或“angry_goldberg”。相当幽默,不是吗?

一个重要的方面是容器名称必须是唯一的。确保引号容器已启动并正在运行:

$ docker container ls -l

前面输出的重要部分是STATUS列,此例中,它显示UP 16 seconds。这意味着容器已经启动并运行了16秒。

列表容器

随着时间的推移继续运行容器,你的系统也许会产生很多容器。要查找主机上当前正在运行的容器,可以使用container ls命令,如下所示:

$ docker container ls

这将列出所有当前运行的容器。
默认情况下,Docker输出七列,含义如下:

如果要列出系统上定义的所有容器,可以使用命令行参数 -a 或 -all,如下所示:

$ docker container ls -a

这将列出任何状态的容器,无论是创建,运行还是退出。

有时,可能只想列出所有容器的ID。为此,你有 -q 参数:

$ docker container ls -q

你可能想知道这有什么用。这里有个例子:

$ docker container rm -f $(docker container ls -a -q)

上面的命令删除当前在系统上定义的所有容器,包括已停止的容器。rm命令代表删除,将在本教程中进一步解释。
在上一节中,您在list命令中使用了-l参数。尝试使用Docker帮助找出-l参数代表什么。您可以为list命令调用help,如下所示:
$ docker container ls -h

停止和启动容器

有时,你可能需要暂时停止正在运行的容器。试试以下这个容器:

$ docker container run -d --name quotes alpine \  /bin/sh -c "while :; do wget -qO- https://talaikis.com/api/quotes/random; printf '\n'; sleep 5; done"

现在,你可以使用以下命令停止此容器:

$ docker container stop quotes

当你尝试暂停容器时,可能会注意到它需要一段时间(大约10秒)才能执行完成。为什么会这样? Docker将 Linux SIGTERM信号发送到容器内运行的主进程。

在上面的命令中,容器的名称用于指定要停止的容器。也可以使用容器ID。

你如何获得容器ID?

有几种方法可以做到这一点。手动方法是列出所有正在运行的容器,并在列表中找到您要查找的容器。只需从那里复制其ID。
更自动化的方法是使用shell脚本和环境变量。例如,如果要获取引号容器的ID,这是一个示例:

$ export CONTAINER_ID = $(docker container ls | grep quotes | awk '{print $1}')

这里我们使用AWK获取第一个字段,即容器ID。现在,您可以在表达式中使用$CONTAINER_ID变量,而不是使用容器名称:

$ docker container stop $CONTAINER_ID

一旦停止容器后,其状态将更改为“已退出”。

你可以使用docker container start命令重新启动已停止的容器。

移除容器

运行docker container ls -a命令时,您可以看到很多处于“已退出”状态的容器。

如果您不再需要这些容器,最好将它们从内存中删除;否则,他们会占用宝贵的资源。删除容器的命令如下:

$ docker container rm <container ID>

或者,也可以使用此命令:

$ docker container rm <container name>

有时,无法删除正在运行的容器;如果要强制删除,可以使用命令行参数 -f 或 -force。
容器化改变了行业运行方式,将维护成本降低了50%以上,并将产品上市时间缩短了约90%。此外,相对于容器外运行,容器使应用程序更安全。

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对我们的支持。如果你想了解更多相关内容请查看下面相关链接

(0)

相关推荐

  • Docker容器中Mysql数据的导入/导出详解

    前言 Mysql数据的导入导出我们都知道一个mysqldump命令就能够解决,但如果是运行在docker环境下的mysql呢? 解决办法其实还是用mysqldump命令,但是我们需要进入docker的mysql容器内去执行它,并且通过配置volumes让导出的数据文件可以拷贝到宿主机的磁盘上 所以操作步骤就可以分为: 配置docker的volumes 进入docker的mysql容器,导出数据文件 至于数据导入,太过简单,就不说了 先来看看mysqldump命令常见选项: --all-datab

  • 如何隔离docker容器中的用户的方法

    笔者在前文<理解 docker 容器中的 uid 和 gid>介绍了 docker 容器中的用户与宿主机上用户的关系,得出的结论是:docker 默认没有隔离宿主机用户和容器中的用户.如果你已经了解了 Linux 的 user namespace 技术(参考<Linux Namespace : User>),那么自然会问:docker 为什么不利用 Linux user namespace 实现用户的隔离呢?事实上,docker 已经实现了相关的功能,只是默认没有启用而已.笔者将在

  • Docker容器自启动的实现方法

    容器自启动 Docker提供了restart policy机制,可以在容器退出或者Docker重启时控制容器能够自启动.这种Restart policy可以保证相关容器按照正确顺序启动.虽然也可以通过进程监控的方式(如systemd)来完成这种动作,但Docker还是建议尽量避免使用进程监控的方式来 "自启动" 容器. Docker的 Restart policy与dockerd命令的--live-restore启动标志还有区别:--live-restore标志可以在Docker升级的

  • Centos7下安装与卸载docker应用容器引擎的方法

    Docker 是一个开源的应用容器引擎,基于Go 语言并遵从Apache2.0协议开源. Docker 可以让开发者打包他们的应用以及依赖包到一个轻量级.可移植的容器中,然后发布到任何流行的 Linux 机器上,也可以实现虚拟化. 容器是完全使用沙箱机制,相互之间不会有任何接口(类似 iPhone 的 app),更重要的是容器性能开销极低. Docker的应用场景 Web 应用的自动化打包和发布. 自动化测试和持续集成.发布. 在服务型环境中部署和调整数据库或其他的后台应用. 从头编译或者扩展现

  • 详解将本地docker容器迁移到服务端

    从docker容器生成镜像 docker commit -a "zhaoolee" -m "完成uwsgi的配置" qs zhaoolee-qs:1.0 参数说明: -a为作者署名, -m为本次提交的内容说明, qs为容器的名称, zhaoolee-qs:1.0表示新生成的镜像名为zhaoolee-qs,镜像zhaoolee-qs版本号为1.0 从容器生成镜像的时间可以会比较长, 需要耐心等待 将docker镜像导出为静态文件 docker save zhaoole

  • Docker下Tomcat容器中使用Mysql的方法

    在这里我们使用Tomcat容器来运行war包,不过作为一个网站一个程序,如果需要用到数据库的,那么Tomcat容器中如何连接Mysql呢? 已经pull了tomcat和mysql镜像,可以使用docker的连接系统(–link)连接多个容器方式解决tomcat容器中使用mysql [root@izbp1b5k5bjps0dw8owk7tz ~]# docker images REPOSITORY TAG IMAGE ID CREATED SIZE tomcat latest 2d084b1116

  • Docker容器之内网独立IP访问的方法

    实验介绍 今天在学习Docker容器的时候,在虚拟机中创建并开启了一个nginx的container,然后通过端口映射的方法,即将container的80端口映射到虚拟机的80端口,然后在宿主机上通过访问虚拟机的IP从而访问到Docker容器的Nginx服务. 然后开始思考,能否通过分配给container一个独立的IP,然后在宿主机上访问这个独立IP从而访问Nginx服务.通过各种探索,百度,最终实现,下面开始实验,这里用的是虚拟机的NAT模式. 实验图解 实验实施 安装docker服务 [r

  • 详解Docker 端口映射与容器互联

    1.端口映射实现访问容器 1.从外部访问容器应用 在启动容器的时候,如果不指定对应的参数,在容器外部是无法通过网络来访问容器内部的网络应用和服务的. 当容器中运行一些网络应用,要让外部访问这些应用时,可以通过-p或-P参数来指定端口映射.当使用-P(大写P)标记时,Docker会随机映射一个端口到内部容器开放的网络端口(端口范围在Linux系统使用的端口之外,一般都过万): [root@docker ~]# docker run -d --name nginx_1 -P nginx:latest

  • Docker容器使用jenkins部署web项目(总结)

    (1)需要安装Docker容器,在Docker容器内安装jenkins,gogs,tomcat.   新建maven项目,添加findbugs plugin. 使用docker启动jenkins,gogs,Tomcat的命令gogs : 复制代码 代码如下: docker run -itd -p 10022:22 -p 10080:3000 --restart=always --privileged=true --name=gogs -v /var/gogs:/data gogs/gogs je

  • Docker创建运行多个mysql容器的方法示例

    1.使用mysql/mysql-server:latest镜像快速启动一个Mysql实例 docker run --name ilink_user_01 -e MYSQL_ROOT_PASSWORD=123456 0d 0p 3307:3306 mysql/mysql-server:latest ilink_user_01是容器名称,通过--name指令指定 123456为数据库root的密码,通过-e指定环境MYSQL_ROOT_PASSWORD为123456,-e (指定容器内的环境变量)

  • Docker容器内不能联网的6种解决方案

    Docker容器内不能联网的6种解决方案 注:下面的方法是在容器内能ping通公网IP的解决方案,如果连公网IP都ping不通,那主机可能也上不了网(尝试ping 8.8.8.8) 1.使用–net:host选项 sudo docker run --net:host --name ubuntu_bash -i -t ubuntu:latest /bin/bash 2.使用–dns选项 sudo docker run --dns 8.8.8.8 --dns 8.8.4.4 --name ubunt

  • docker容器启动后添加端口映射

    概要 网上有许多人在查找关于容器启动后能否进行端口映射的问题.我曾经也问过度娘,很遗憾我没找到.本文就这个问题给出一个解决方法,旨在抛砖引玉.本文的思路是使用iptables的端口转发,这也是docker端口映射内部的实现机制,只不过我是显示地写出来罢了,为的就是让查找这个问题的人对docker的端口映射有一个直观的了解. 结论:容器启动后是可以添加端口映射的,但不建议手工添加,最好使用docker提供的功能. 步骤 创建两个容器并进行了端口映射,结果如图所示: 假如,我start一个容器,其内

随机推荐