您的位置:首页 > 运维架构 > Docker

docker 实现hello world守护进程

2015-08-20 14:01 811 查看
Hello world 守护进程

现在当一个容器运行完一个命令后就会退出,但是这样看起来有时候并不好。让我们创建一个容器以进程的方式运行,就像大多数我们运行在 Docker 中的应用程序一样,这里我们可以使用 docker run 命令:

docker run -d centos:latest /bin/bash -c "while true; do echo hello world; sleep 1; done"

等等,怎么回事?我们的 “hello world” 输出呢?让我们看看它是怎么运行的。这个命令看起来应该很熟悉.我们运行docker run ,但是我们指定了一个 -d 标识。-d 标识告诉 docker 在容器内以后台进程模式运行。

最终,我们指定命令行运行:

/bin/sh -c "while true; do echo hello world; sleep 1; done"
这是一个忠实的 hello world 进程:一个脚本会一直输出 "hello world"

为什么我们看不到的一大堆的 "hello world" ? 而是docker返回的一个很长的字符串:
a569c8882785aa0f6b5ebd332d0bf0406ba495e9cf1b4c22f868447f13a5ea65

这个长的字符串叫做容器ID(container ID)。它对于每一个容器来说都是唯一的,所以我们可以使用它。

注意:容器 ID 是有点长并且非常的笨拙,稍后我们会看到一个短点的 ID,某些方面来说它是容器 ID 的简化版。
我们可以根据容器 ID 查看 "hello world" 进程发生了什么

首先,我们要确保容器正在运行。我们可以使用 docker ps 命令来查看。docker ps 命令可以查询 docker 进程的所有容器。

docker ps
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
a569c8882785 centos:latest "/bin/bash -c 'while 7 seconds ago Up 6 seconds jovial_kowalevski

这里我们看到了以进程模式运行的容器。docker ps 命令会返回一些有用的信息,这里包括一个短的容器 ID:a569c8882785。

我们还可以查看到构建容器时使用的镜像, centos:latest,当命令运行之后,容器的状态随之改变并且被系统自动分配了名称 jovial_kowalevski 。

docker logs jovial_kowalevski

docker logs 命令会查看容器内的标准输出:这个例子里输出的是我们的命令 hello world

太棒了!我们的 docker 进程是工作的,并且我们创建了我们第一个 docker 应用。

现在我们已经可以创建我们自己的容器了,让我们处理正在运行的进程容器并停止它。我们使用 docker stop 命令来停止容器 。

$ sudo docker stop jovial_kowalevski
jovial_kowalevski
docker stop 命令会通知 Docker 停止正在运行的容器。如果它成功了,它将返回刚刚停止的容器名称。

让我们通过 docker ps 命令来检查它是否还工作。

$ docker ps
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
太好了,我们的容器停止了。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  docker