Docker基础之五: 使用Docker容器

本文涉及的产品
容器服务 Serverless 版 ACK Serverless,952元额度 多规格
容器服务 Serverless 版 ACK Serverless,317元额度 多规格
容器镜像服务 ACR,镜像仓库100个 不限时长
简介: 使用Docker容器 这一节我们将从运行一个简单的Hello world入手,来讲解如何使用容器。 1 运行Hello World root@shev:~# docker run ubuntu:14.04 echo hello-world hello-world root@shev:~#

使用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

剖析:

  • 本条命令启动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
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/
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)

剖析:

  • 本例中,我们在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

查看后台的运行日志:

root@shev:~# docker logs ba50
hello world
hello world
hello world
hello world
hello world
hello world
hello world

查看当前正在运行的容器列表:

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

停止指定的容器:

root@shev:~# docker stop ba50
ba50

再次查看正在运行的容器:

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

剖析:

  • 本例中,我们通过-d属性,让容器运行在后台,我们并不进入容器内部
  • 执行完毕后,返回了一个id,该id是容器的id。上面显示的是容器的完整id,但是我们实际操作的时候,一般可以只输入前面几位即可,docker会自动进行匹配
  • 我们通过docker logs 来查看容器运行的情况,也就是我们循环打印的日志
  • 由于该容器是长时间运行的,所以我们可以通过docker ps,查看该容器
  • docker stop则是停止该容器,停止后,我们就看不到该容器了
目录
相关文章
|
14天前
|
Linux iOS开发 Docker
Docker:容器化技术的领航者 —— 从基础到实践的全面解析
在云计算与微服务架构日益盛行的今天,Docker作为容器化技术的佼佼者,正引领着一场软件开发与部署的革命。它不仅极大地提升了应用部署的灵活性与效率,还为持续集成/持续部署(CI/CD)提供了强有力的支撑。
192 69
|
2天前
|
Kubernetes Cloud Native 持续交付
云原生之旅:Docker容器化与Kubernetes集群管理
【9月更文挑战第33天】在数字化转型的浪潮中,云原生技术如同一艘航船,带领企业乘风破浪。本篇文章将作为你的航海指南,从Docker容器化的基础讲起,直至Kubernetes集群的高级管理,我们将一起探索云原生的奥秘。你将学习到如何封装应用、实现环境隔离,以及如何在Kubernetes集群中部署、监控和扩展你的服务。让我们启航,驶向灵活、可伸缩的云原生未来。
|
4天前
|
Kubernetes Cloud Native Docker
云原生时代的容器化实践:Docker与Kubernetes入门
【9月更文挑战第30天】在云计算的浪潮中,云原生技术正以前所未有的速度重塑着软件开发和运维领域。本文将通过深入浅出的方式,带你了解云原生的核心组件——Docker容器和Kubernetes集群,并探索它们如何助力现代应用的构建、部署和管理。从Docker的基本命令到Kubernetes的资源调度,我们将一起开启云原生技术的奇妙之旅。
|
14天前
|
运维 Cloud Native Docker
云原生技术入门:Docker容器化实战
【9月更文挑战第20天】本文将引导你走进云原生技术的世界,通过Docker容器化技术的实战演练,深入理解其背后的原理和应用。我们将一起探索如何在云平台上利用Docker简化部署、扩展和管理应用程序的过程,并揭示这一技术如何改变现代软件的开发和运维模式。
|
9天前
|
Cloud Native 持续交付 Docker
云原生技术入门与实践:Docker容器化部署示例
【9月更文挑战第25天】在数字化转型的浪潮下,云原生技术成为推动企业创新的重要力量。本文旨在通过浅显易懂的语言,为初学者揭示云原生技术的核心概念及其应用价值。我们将以Docker容器为例,逐步引导读者了解如何将应用程序容器化,并在云端高效运行。这不仅是对技术趋势的跟随,更是对资源利用和开发效率提升的探索。
29 4
|
7天前
|
Kubernetes Linux 开发者
深入探索Docker容器化技术的奥秘
深入探索Docker容器化技术的奥秘
16 1
|
10天前
|
存储 Docker 容器
Docker中容器间的通信方式有哪些13
Docker中容器间的通信方式有哪些13
14 4
|
5天前
|
网络协议 安全 开发者
掌握 Docker 网络:构建复杂的容器通信
在 Docker 容器化环境中,容器间的通信至关重要。本文详细介绍了 Docker 网络的基础知识,包括网络驱动、端口映射和命名等核心概念,并深入探讨了 Bridge、Host、Overlay 和 Macvlan 四种网络类型的特点及应用场景。此外,还提供了创建、连接、查看和删除自定义网络的命令示例,以及高级网络配置方法,如网络命名空间、DNS 解析和安全通信配置,帮助开发者构建更健壮的容器化应用。
|
6天前
|
Cloud Native 持续交付 Docker
深入解析Docker容器化技术及其在生产环境中的应用
深入解析Docker容器化技术及其在生产环境中的应用
10 0
|
7天前
|
存储 Kubernetes Docker
深入探索容器化技术:Docker 实战与 Kubernetes 管理
深入探索容器化技术:Docker 实战与 Kubernetes 管理
21 0
下一篇
无影云桌面