我正在关注Docker的文档,以了解Docker的工作原理。
但我遇到了Doc,
中的问题说这个命令运行时:
$ docker run -d ubuntu:14.04 /bin/sh -c "while true; do echo hello world; sleep 1; done"
由于-d
标志而启动了守护程序。
但是当使用docker ps
命令检查正在运行的容器时,它是空的,只有标题:
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
使用docker ps -a
命令观察我看到的所有容器:
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
e7f1bebd5a49 ubuntu:14.04 "/bin/sh -c while tru" 6 minutes ago Exited (2) 4 minutes ago cranky_mcclintock
它以error code 2
退出。看日志:
docker logs e7f1bebd5a49
true;: 1: true;: Syntax error: end of file unexpected
为什么会这样?我在Windows 10中运行Docker(使用Docker Quickstart Terminal)。
这是我的docker info
:
Containers: 3
Images: 52
Server Version: 1.9.1
Storage Driver: aufs
Root Dir: /mnt/sda1/var/lib/docker/aufs
Backing Filesystem: extfs
Dirs: 58
Dirperm1 Supported: true
Execution Driver: native-0.2
Logging Driver: json-file
Kernel Version: 4.1.13-boot2docker
Operating System: Boot2Docker 1.9.1 (TCL 6.4.1);
CPUs: 1
Total Memory: 996.2 MiB
Name: default
Debug mode (server): true
File Descriptors: 12
Goroutines: 20
EventsListeners: 0
Init SHA1:
Init Path: /usr/local/bin/docker
Docker Root Dir: /mnt/sda1/var/lib/docker
Registry: https://index.docker.io/v1/
Labels:
provider=virtualbox
以下是docker events
docker run
$ docker run -d ubuntu:14.04 /bin/sh -c "while true; do echo hello world; sleep 1; done"
e7f1bebd5a490e35ce8451c5f12a4a4f4e089bd70fc6ad1726e927a0610f3e49
2016-01-14T13:20:55.350098419+08:00 e7f1bebd5a490e35ce8451c5f12a4a4f4e089bd70fc6ad1726e927a0610f3e49: (from ubuntu:14.04) create
2016-01-14T13:20:55.363562836+08:00 e7f1bebd5a490e35ce8451c5f12a4a4f4e089bd70fc6ad1726e927a0610f3e49: (from ubuntu:14.04) start
2016-01-14T13:20:55.436727252+08:00 e7f1bebd5a490e35ce8451c5f12a4a4f4e089bd70fc6ad1726e927a0610f3e49: (from ubuntu:14.04) die
答案 0 :(得分:1)
使用VirtualBox的控制台时一切正常。它只在Windows的控制台中失败(使用Docker Quickstart终端)。
我认为根本问题在于行尾代码字符(\n
,\r
或\r\n
)。