2018-10-22

什么时候应该将应用程序切分为多个容器?

围绕着应该将应用程序的哪些部分切分为多个容器以及为什么要这样做,存在着很多困惑。我最近对Docker用户邮箱列表的回应促成了今天的文章。在这篇文章中我打算评估一个镜像化的Java应用程序,它历史上曾经运行在一个单一的Tomcat服务器里,并解释为什么我会把它切分为独立的容器。为了让事情有趣——我也旨在证明这个动作(比如将应用程序分割为独立的容器)和数据及(工程)逻辑,而不是简单地说“有一个原则”,即必须在所有时间都遵守。

让我们看一个Java应用程序示例,由以下两部分组成: 基于Struts Web框架构建的一个前端应用 基于Java

EE构建的一个后端REST API

如前所述,这个应用程序历史上曾经跑在一个Tomcat服务器里,两个组件是通过一个基于REST的API进行通信的,所以问题变成了:

我应该要将这个应用程序切分成多个容器吗?

答案是肯定的,我相信这个应用程序应该切分为两个不同的Docker容器,但这应该经过慎重考虑之后。

而不是“仅仅因为”将应用程序切分成多个容器或试图坚持一些新奇的原则(比如“每个容器只运行一个进程”)——我建议我们应该通盘考虑项目需求然后做出明智和聪明的决定。是否所有的应用程序都应该切分为多个容器?容器化通过提供一个更简单的部署策略至少会使你的软件生涯更便捷。

让我们在示例应用程序的分析上做些短暂的停留,做一些设计思考:

JVM是多线程的,所以没有必要运行多个Unix/Linux进程。事实上,我认为这是Java工程师理所当然的困惑。从历史上看,Java开发人员实际上喜欢在同一个JVM里边运行多个应用程序,在实践中,这样做可以节省相当多的内存。此外,Web应用服务器比如Tomcat是打从一开始就支持在单个JVM上运行多个应用程序。这实际上是运行一个简单的Java程序相对于Java

EE应用程序(这可能是由多个线程和多个不同的程序组成)的主要区别。 在现实中,许多应用在每个容器中使用多个进程,Apache

Web服务器的Prefork和MPM和模块都在同一个容器中使用多个进程。现代的Web应用具有事件驱动编程或反应器模式的特性(例如Nginx),实际衍生了许多子进程。我认为,FastCGI、AIO以及反应器模式的整个理念是将工作分担给其他进程(或线程),而让内核专注处理I/O。Linux内核是相当擅长子进程调度的,Kubernetes、Swarm和单个的Docker容器不太擅长干这活。进程(及线程)都是有关内核资源分配的,而容器涉及到了集群资源分配。

运行单容器单进程的“最佳实践”被广泛认为是“原则“,但听起来更多像哲学。作为一名工程师,我想要理解技术组件,并做出合乎逻辑的决定。我认为,这种”最佳实践“甚至不是普遍的共识,其控制应用程序根源于广泛缺乏了解的Unix是如何工作的。

Linux容器在历史上有许多种形式,许多实际推荐运行的是在单个容器里运行多个进程。什么使得Docker容器与众不同的呢?Linux容器本质上就是对于系统调用的克隆、SElinux和Cgroups,它们是否是LXC或者Docker(通过libcontainer)类型是无关紧要的,因为Linux内核自身就可以处理进程隔离。

在有效的时间之内通过Socket、文件或者网络等处理通信,每一个方法都有它各自的优点和缺点。给定应用程序的通信方式肯定会影响你是否想将您的应用程序切分成多个容器。

代码、配置和数据的分离也会影响您的应用程序切分为多个容器的能力。如果你的应用程序具有良好的代码、配置和数据的分离能力,将会非常容易切分为多个容器,如果你的应用代码非常古老,并且不太好理解,将会对于文件系统带来不必要的改变,并且非常难以作切分,注意,下面的方法是非常棒的!你不必重写你的应用来容器化,而可以通过将你的应用放入一个容器就可以享受Docker容器格式的好处。你可以轻松地移动(使用注册中心服务)和部署(执行docker

run命令)。 好的,有一些Unix应用遇到101错误了,让我们回到示例Java应用的分析:

如上所述的两个Java组件看起来做的都是不同的事情,一个组件是Web前端,另外一个是API服务器。既然这些组件做的是不同的事情(比如他们确实是不同的服务),几乎没有机会比在相同的JVM里有性能优势(当然了,没有实际的测试性能,我不能100%确定)。

这两个应用程序使用REST API来进行通信(而不是使用Socket、共享内存或文件等方式)。

一般来说,如果一个应用程序包含一个API层和一个前端层,对于独立地扩展这些应用就非常有用。比如说如果一个API也被一个移动应用所消费,根据用户负载进行动态伸缩就很有用,而基于Web的前端就不需要伸缩。相反,如果我扩展web前端,我可能还需要扩展API服务器的部分,但每五个Web前端我可能只需要再多一个API服务器。长话短说,伸缩逻辑复杂,借助于类似Kubernetes这样的工具进行独立的伸缩是非常有用的。

基于这三个单独的观察,我推荐将这两个组件切分为单独的容器,我还推荐使用容器编排工具比如Kubernets或者OpenShift来将这些服务连接在一起。我不会将这一决定基于所谓的“原则”或“最佳实践”,而是会基于它的应用架构和某种形式的信息推理。

这儿的事情变得疯狂,我提交(给你)一个新的“最佳实践”,请击鼓:

是的,如果您的应用程序/服务具有很好的代码、配置和数据的隔离,安装非常清晰(因为安装脚本会使整个过程变得困难),提供了一个非常清晰的通信模式,就非常有意义来切分/分配为单容器运行单个服务。

从根本上说,我建议我们所有人都应该开始更加理性地考虑如何把应用放入容器里,意识到容器化不仅仅是一个哲学理论,更是可以解决技术痛点问题的。我喜欢容器,并且在所有的时间都愿意使用它们,但是也是以一个睿智的方式。我确信人们对于容器化应用的意见和想法,我鼓励您在下面的评论栏中分享你的想法。

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 217,509评论 6 504
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,806评论 3 394
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 163,875评论 0 354
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,441评论 1 293
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,488评论 6 392
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,365评论 1 302
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,190评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,062评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,500评论 1 314
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,706评论 3 335
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,834评论 1 347
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,559评论 5 345
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,167评论 3 328
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,779评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,912评论 1 269
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,958评论 2 370
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,779评论 2 354

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,654评论 18 139
  • Docker — 云时代的程序分发方式 要说最近一年云计算业界有什么大事件?Google Compute Engi...
    ahohoho阅读 15,532评论 15 147
  • 文/静仁 风,呼啸而至 雪,不期而遇 都是一刹那,即停即走 冰,像是和情人一直窝在壁炉旁 忘了归期 抽刀断水,恨也...
    赵静仁阅读 344评论 0 2
  • 1. 去体检,抽血的地方人很多。没看到抽号或是排队的迹象,刚好有一个窗口空着,我连忙过去坐了下来。 一个年轻的女孩...
    Q小喵阅读 619评论 9 9
  • 孤山春来早 杏花拥怀抱 层层花叠峦 无风影自摇 百花未露头 杏枝早盈笑 游人爬山坳 仙境乐陶陶 花开二月间 暗香溢...
    林智宏阅读 91评论 0 1