使用Docker容器
(对Docker感兴趣的朋友可以加我的微信ghostcloud2016,然后我把你加到我们的一个Docker爱好者群组里面。)
这一节我们将从运行一个简单的Hello world入手,来讲解如何使用容器。
1 运行Hello World
root@shev:~# docker run ubuntu:14.04 echo hello-world
hello-world
root@shev:~# docker ps -a
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
0cef7fa7468d ubuntu:14.04 "echo hello-world" 3 seconds ago Exited (0) 2 seconds ago condescending_visvesvaraya
AI 代码解读
剖析:
- 本条命令启动ubuntu:14.04版本的镜像,并在其中运行打印hello world的命令;
- 由于我们的命令是一个简单的语句,并不会持续很长时间,当命令执行完毕时,容器就退出了
- 因此,我们通过docker ps –a可以看到容器的状态是停止状态
2 运行一个可交互的容器
之前的例子里面,容器在运行完指令后就自动退出了,那么我们可不可以运行一个可交互的容器呢?
root@shev:~# docker run -it ubuntu /bin/bash
Unable to find image 'ubuntu:latest' locally
latest: Pulling from library/ubuntu
Digest: sha256:f91f9bab1fe6d0db0bfecc751d127a29d36e85483b1c68e69a246cf1df9b4251
Status: Downloaded newer image for ubuntu:latest
AI 代码解读
root@558531c2b215:/# ll
total 72
drwxr-xr-x 32 root root 4096 Dec 2 09:16 ./
drwxr-xr-x 32 root root 4096 Dec 2 09:16 ../
-rwxr-xr-x 1 root root 0 Dec 2 09:16 .dockerenv*
-rwxr-xr-x 1 root root 0 Dec 2 09:16 .dockerinit*
drwxr-xr-x 2 root root 4096 Oct 28 04:34 bin/
drwxr-xr-x 2 root root 4096 Apr 10 2014 boot/
drwxr-xr-x 5 root root 380 Dec 2 09:16 dev/
drwxr-xr-x 64 root root 4096 Dec 2 09:16 etc/
drwxr-xr-x 2 root root 4096 Apr 10 2014 home/
drwxr-xr-x 12 root root 4096 Oct 28 04:34 lib/
drwxr-xr-x 2 root root 4096 Oct 28 04:33 lib64/
drwxr-xr-x 2 root root 4096 Oct 28 04:33 media/
drwxr-xr-x 2 root root 4096 Apr 10 2014 mnt/
drwxr-xr-x 2 root root 4096 Oct 28 04:33 opt/
dr-xr-xr-x 160 root root 0 Dec 2 09:16 proc/
drwx------ 2 root root 4096 Oct 28 04:34 root/
drwxr-xr-x 7 root root 4096 Oct 28 04:34 run/
drwxr-xr-x 2 root root 4096 Nov 10 00:35 sbin/
drwxr-xr-x 2 root root 4096 Oct 28 04:33 srv/
dr-xr-xr-x 13 root root 0 Dec 2 09:16 sys/
drwxrwxrwt 2 root root 4096 Oct 28 04:34 tmp/
drwxr-xr-x 11 root root 4096 Nov 10 00:35 usr/
drwxr-xr-x 12 root root 4096 Nov 10 00:35 var/
AI 代码解读
root@558531c2b215:/# ifconfig
eth0 Link encap:Ethernet HWaddr 02:42:ac:11:00:02
inet addr:172.17.0.2 Bcast:0.0.0.0 Mask:255.255.0.0
inet6 addr: fe80::42:acff:fe11:2/64 Scope:Link
UP BROADCAST RUNNING MULTICAST MTU:1500 Metric:1
RX packets:8 errors:0 dropped:0 overruns:0 frame:0
TX packets:8 errors:0 dropped:0 overruns:0 carrier:0
collisions:0 txqueuelen:0
RX bytes:648 (648.0 B) TX bytes:648 (648.0 B)
lo Link encap:Local Loopback
inet addr:127.0.0.1 Mask:255.0.0.0
inet6 addr: ::1/128 Scope:Host
UP LOOPBACK RUNNING MTU:65536 Metric:1
RX packets:0 errors:0 dropped:0 overruns:0 frame:0
TX packets:0 errors:0 dropped:0 overruns:0 carrier:0
collisions:0 txqueuelen:0
RX bytes:0 (0.0 B) TX bytes:0 (0.0 B)
AI 代码解读
剖析:
- 本例中,我们在ubuntu:latest镜像中,执行/bin/bash,由于bash本身是一个包含了交互的终端,因此我们可以长时间的运行容器;
- 但是,我们必须指定-it,同shell的stdiin和stdout绑定起来
- 进入容器后,我们实际进入了一个shell终端,里面不仅可以访问文件将,还有一个虚拟网卡和IP。这是不是跟一个linux主机是一样的呢?
3 在容器中运行一个后台守护进程
所谓后台守护进程,就是运行在后台,并不会阻塞当前的进程。
在后台运行一个脚本,每隔1秒打印一句hello world:
root@shev:~# docker run -d ubuntu:14.04 /bin/sh -c "while true; do echo hello world; sleep 1; done"
ba50b5023bb15b50608d855671d40c09690f5b1a956a40e3544acde791e04aa3
AI 代码解读
查看后台的运行日志:
root@shev:~# docker logs ba50
hello world
hello world
hello world
hello world
hello world
hello world
hello world
AI 代码解读
查看当前正在运行的容器列表:
root@shev:~# docker ps
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
ba50b5023bb1 ubuntu:14.04 "/bin/sh -c 'while tr" 2 minutes ago Up 2 minutes ecstatic_bell
e221abf45a0b ghostcloud.cn:5000/gcali:1.2 "/usr/local/ghostclou" 49 minutes ago Up 49 minutes gcsagent
AI 代码解读
停止指定的容器:
root@shev:~# docker stop ba50
ba50
AI 代码解读
再次查看正在运行的容器:
root@shev:~# docker ps
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
e221abf45a0b ghostcloud.cn:5000/gcali:1.2 "/usr/local/ghostclou" 50 minutes ago Up 50 minutes gcsagent
AI 代码解读
剖析:
- 本例中,我们通过-d属性,让容器运行在后台,我们并不进入容器内部
- 执行完毕后,返回了一个id,该id是容器的id。上面显示的是容器的完整id,但是我们实际操作的时候,一般可以只输入前面几位即可,docker会自动进行匹配
- 我们通过docker logs 来查看容器运行的情况,也就是我们循环打印的日志
- 由于该容器是长时间运行的,所以我们可以通过docker ps,查看该容器
- docker stop则是停止该容器,停止后,我们就看不到该容器了