Docker 容器简介

阿里 2016 年的双十一,数万台服务器支持,所有的交易系统全部都跑在了 Docker 容
器中,撑起来每秒钟 17.5 万笔的交易峰值。4 小时 26 分 31 秒交易 362 亿,超过 2013 年
双十一全体交易,最终双十一交易额 1207 亿,全球之最。

要支持这么的大的访问量,就需要提升系统的并发量,要提升系统的并发量,最直接的
办法就是提升服务器的数量。阿里为支持双十一,提前准备万台服务器,万兆带宽。直播也
是如此事先要准备大量服务器,百万级粉丝需要准备上千台服务器。
但准备多少够呢?预计多了,成本就白支出了,预计少了,洪峰来了,系统倒了,现场
砸了,饭碗丢了。能否动态感知快速响应呢?这就是云所做的,而云背后就是 docker!

VM 虚拟机的出现可以让服务器资源可以充分利用,一台服务器上可以安装多个 VM,而
每个 VM 又形成资源隔离,使不同的 VM 可以使用同一台服务器,却互相不干扰。Docker 同
理,它也是将硬件资源抽象。
Docker 两个最重要的概念是镜像和容器。镜像类似虚拟机的快照,但更轻量,非常非
常轻量。举例来说,VM 相当于绿皮火车,Docker 就相当于劳斯莱斯小汽车。VM 的快照通
常 2~3G,而 Docker 只有 100~300M。

镜像  image
简单说,镜像就是一个只读模板。
创建 Docker 镜像有几种方式,多数是在一个现有镜像基础上创建新镜像,因为几乎你
需要的任何东西都有了公共镜像,包括所有主流 Linux 发行版,你应该不会找不到你需要
的镜像。不过就算你想从头构建一个镜像也有好几种方式。
实现的方式有两种:在一个文件 Dockerfile 中指定一个基础镜像及需要完成的修改;
或通过“运行”一个镜像,对其进行修改并提交。不同方式各有优点,不过一般会使用文件
Dockerfile 来指定所做的变化。
镜像拥有唯一 ID,以及一个供人阅读的名字和标签对。镜像可以命名为类似
ubuntu:latest、ubuntu:precise、django:1.6、django:1.7 等等。

9.1.5.2 容器  container
每个容器都是相互隔离的、保证安全的平台。可以把容器看做是一个简易版的 Linux
环境(包括 root 用户权限、进程空间、用户空间和网络空间等)和运行在其中的应用程序。
可以从镜像中创建容器,这等同于从快照中创建虚拟机,不过更轻量。应用是由容器运
行的。容器与虚拟机一样,是隔离的。它们也拥有一个唯一 ID 和唯一的供人阅读的名字。
容器有必要对外暴露服务,因此 Docker 允许暴露容器的特定端口。

容器启动时,将被分配一个随机的私有 IP,其它容器可以使用这个 IP 地址与其进行通
讯。这点非常重要,原因有二:一是它提供了容器间相互通信的渠道,二是容器将共享一个
本地网络。
要开启容器间通讯,Docker 允许你在创建一个新容器时引用其它现存容器,在你刚创
建的容器里被引用的容器将获得一个(你指定的)别名。我们就说,这两个容器链接在了一
起。
因此,如果 DB 容器已经在运行,我可以创建 web 服务器容器,并在创建时引用这个 DB
容器,给它一个别名,比如 dbapp。在这个新建的 web 服务器容器里,我可以在任何时候
使用主机名 dbapp 与 DB 容器进行通讯。

1. 虚拟化技术依赖物理 CPU 和内存,是硬件级别的;而 docker 构建在操作系统上,
利用操作系统的 containerization 容器技术,所以 docker 甚至可以在虚拟机
上运行。
2. 启动速度快,比 VM 快太多了,启动、停止、开始、重启都是秒级甚至毫秒级。
3. 轻量级虚拟化,在一台服务器上可以部署 100~1000 个 Container 容器。而 VM 一
台服务器能部署 10 到 20 就很不错了。
4. *Docker 是单线程,Docker 设计者极力推崇“一个容器一个进程的方式”。无法
很好地模拟一个完整的环境(详细参加 LXC)。
5. *当停止一个虚拟机时,可能除了一些临时文件,没有文件会被删除(业务产生的
文件);但当停止一个 Docker 容器,对初始状态(创建容器所用的镜像的状态)
做的所有变化都会丢失。这是使用 Docker 时必须做出的最大思维变化之一:容器
是短暂和一次性的。所以有种说法,例如 mysql 这样的数据库还是不要用 Docker
的好,因为数据库在使用过程中会有很多业务数据。
6. Docker 的安全性目前比 VM 要差。VM 做到资源完全隔离,而 Docker 会共享资源,
这就带来了安全的风险。

转载于:https://my.oschina.net/architectliuyuanyuan/blog/2992608

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值