博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Docker 容器简介
阅读量:6428 次
发布时间:2019-06-23

本文共 2005 字,大约阅读时间需要 6 分钟。

hot3.png

阿里 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

你可能感兴趣的文章
第十一章 MySQL运算符
查看>>
JAVA常见算法题(十七)
查看>>
GUI鼠标相关设置
查看>>
使用 <Iframe>实现跨域通信
查看>>
闭包--循序学习
查看>>
项目实战之集成邮件开发
查看>>
解决C3P0在Linux下Failed to get local InetAddress for VMID问题
查看>>
1531 山峰 【栈的应用】
查看>>
巧用美女照做微信吸粉,你会做吗?
查看>>
wcf学习总结《上》
查看>>
ERROR (ClientException)
查看>>
Load Balance 产品横向比较
查看>>
Java代理程序实现web方式管理邮件组成员
查看>>
【编译打包】tengine 1.5.1 SRPM
查看>>
看图说话:手动清除病毒文件流程
查看>>
一句话下拖库
查看>>
Deploy Office Communications Server 2007R2 Group Chat Server(二)
查看>>
在Cacti上实现MSN报警机制
查看>>
如何对C++虚基类构造函数
查看>>
XFire WebService开发快速起步
查看>>