您可能需要构建一个单独的、整体部署的web应用程序或服务,并将其部署为一个容器。应用程序本身可能不是内部单一的,而是由几个库、组件甚至层(应用程序层、域层、数据访问层等)构成。但是,在外部,它是一个容器—单个进程、单个web应用程序或单个服务。

要管理此模型,可以部署一个容器来表示应用程序。为了增加容量,您可以向外扩展,也就是说,只需在前面添加更多带有负载平衡器的副本。简单性来自于在单个容器或VM中管理单个部署。

图1 容器化单体应用程序的体系结构示例

可以在每个容器中包含多个组件、库或内部层,如图1所示。单体容器化应用程序的大部分功能都在一个容器中,带有内部层或库,并通过在多个服务器/vm上克隆容器来扩展。然而,这种整体模式可能与容器原则“容器做一件事,在一个过程中做”相冲突,但在某些情况下可能是可以的。

如果应用程序不断增长,需要对其进行扩展,那么这种方法的缺点就显而易见了。如果整个应用程序都可以扩展,这其实不是问题。然而,在大多数情况下,应用程序中只有少数部分是需要扩展的瓶颈,而其他组件使用较少。

例如,在典型的电子商务应用程序中,您可能需要扩展产品信息子系统,因为浏览产品的客户比购买产品的客户多。更多的客户使用他们的购物篮,而不是使用支付管道。添加评论或查看购买历史记录的客户较少。你可能只有少数员工需要管理内容和营销活动。如果缩放整体设计,则这些不同任务的所有代码都会多次部署并在同一级别缩放。

有多种方法可以扩展应用程序的水平复制,分割应用程序的不同区域,并对类似的业务概念或数据进行分区。但是,除了扩展所有组件的问题之外,对单个组件的更改还需要对整个应用程序进行完全的重新测试,并完全重新部署所有实例。

但是,单块方法很常见,因为应用程序的开发最初比微服务方法容易。因此,许多组织使用这种体系结构方法进行开发。虽然一些组织已经取得了足够好的结果,但其他组织正在达到极限。许多组织使用这个模型设计他们的应用程序,因为多年前工具和基础设施使得构建面向服务的体系结构(service-oriented architectures,SOA)变得太困难,直到应用程序增长,他们才看到这一需要。

从基础设施的角度来看,每台服务器可以在同一台主机上运行多个应用程序,并且在资源使用效率方面具有可接受的比率,如图2所示。

图2 整体方法:主机运行多个应用程序,每个应用程序作为容器运行

Microsoft Azure中的单体应用程序可以使用每个实例的专用vm进行部署。此外,使用Azure虚拟机缩放集,您可以轻松缩放vm。Azure应用服务还可以运行单体应用程序并轻松扩展实例,而无需管理VM。自2016年以来,Azure应用服务还可以运行Docker容器的单个实例,从而简化部署。

作为QA环境或有限的生产环境,您可以部署多个Docker主机VM,并使用Azure平衡器平衡它们,如图3所示。这使您可以使用粗粒度方法管理缩放,因为整个应用程序都位于单个容器中。

图3多个主机扩展单个容器应用程序的示例

可以使用传统的部署技术管理到不同主机的部署。Docker主机可以通过Docker run或Docker compose等命令进行管理,这些命令可以手动执行,也可以通过诸如continuous delivery(CD)pipelines之类的自动化进行管理。

将单体应用程序部署为容器

使用容器管理单体应用程序部署有很多好处。扩展容器实

例比部署其他vm快得多,也容易得多。即使使用虚拟机规模集,VM也需要时间来启动。当部署为传统的应用程序实例而不是容器时,应用程序的配置作为VM的一部分进行管理,这并不理想。

将更新部署为Docker映像要快得多,网络效率也高得多。Docker镜像通常在几秒钟内启动,这加快了卷展栏的速度。拆卸Docker映像实例和发出Docker stop命令一样简单,通常不到一秒钟就完成。

因为容器在设计上是不可变的,所以您不必担心损坏的vm。相反,VM的更新脚本可能会忘记解释磁盘上的某些特定配置或文件。

虽然单块应用程序可以从Docker中受益,但我们只谈到了好处。管理容器的其他好处来自与容器编排器一起部署,后者管理每个容器实例的各种实例和生命周期。将单体应用程序分解成可以单独扩展、开发和部署的子系统是您进入微服务领域的切入点。

将单个基于容器的应用程序发布到Azure应用程序服务

无论您想要获得部署到Azure的容器的验证,还是当应用程序只是单个容器应用程序时,Azure应用程序服务都提供了一种提供可伸缩的基于单个容器的服务的好方法。使用Azure应用服务很简单。它提供了与Git的强大集成,使您可以轻松地获取代码、在Visual Studio中构建代码并将其直接部署到Azure。

图4 从Visual Studio 2019将单个容器应用程序发布到Azure应用程序服务

如果没有Docker,如果你需要Azure应用服务中不支持的其他功能、框架或依赖项,你必须等到Azure团队更新了应用服务中的这些依赖项。或者你必须切换到其他服务,比如Azure云服务或VMs,在那里你有进一步的控制权,你可以为你的应用程序安装所需的组件或框架。

Visual Studio 2017及更高版本中的容器支持使您能够在应用程序环境中包含您想要的任何内容,如图4-4所示。由于是在容器中运行,因此如果向应用程序添加依赖项,则可以在Dockerfile或Docker映像中包含依赖项。

如图4所示,发布流通过容器注册表推送镜像。这可以是Azure容器注册表(一个靠近你在Azure中的部署并受Azure活动目录组和帐户保护的注册表),也可以是任何其他Docker注册表,如Docker Hub或本地注册表。

讨论:请加入知识星球【首席架构师圈】或者加微信小号【jiagoushi_pro】或者加QQ群【11107777】
公众号 【jiagoushipro】
【超级架构师】
精彩图文详解架构方法论,架构实践,技术原理,技术趋势。
我们在等你,赶快扫描关注吧。
微信小号 【cea_csa_cto】
50000人社区,讨论:企业架构,云计算,大数据,数据科学,物联网,人工智能,安全,全栈开发,DevOps,数字化.

QQ群 【11107767】深度交流企业架构,业务架构,应用架构,数据架构,技术架构,集成架构,安全架构。以及大数据,云计算,物联网,人工智能等各种新兴技术。
加QQ群,有珍贵的报告和干货资料分享。

视频号 【超级架构师】
1分钟快速了解架构相关的基本概念,模型,方法,经验。
每天1分钟,架构心中熟。

知识星球 向大咖提问,近距离接触,或者获得私密资料分享。 知识星球【首席架构师圈】
微信圈子 志趣相投的同好交流。 微信圈子【首席架构师圈】
喜马拉雅 路上或者车上了解最新黑科技资讯,架构心得。 【智能时刻,架构君和你聊黑科技】
知识星球 认识更多朋友,职场和技术闲聊。 知识星球【职场和技术】
微博 【智能时刻】 智能时刻
哔哩哔哩 【超级架构师】
抖音 【cea_csa_cto】超级架构师
快手 【cea_csa_cto】超级架构师
小红书 【cea_csa_cto】超级架构师 首席架构师智库

谢谢大家关注,转发,点赞和点在看。

「第二部:容器和微服务架构」(2) 容器化单体应用相关推荐

  1. 架构演进之「微服务架构」

    "为什么要搞「微服务架构」"?这也是我们当初讨论的聚焦点.现在天天把"微服务"挂在嘴边的人很多,但是有多少人真正深入思考过"为什么",我认为 ...

  2. 开源 | 蚂蚁金服分布式中间件开源第二弹:丰富微服务架构体系

    小蚂蚁说: 数据.消息.微服务是蚂蚁金服自主研发的金融级分布式中间件 SOFA (Scalable Open Financial Architecture)的三大方向. 一个多月前,蚂蚁金服开源了 S ...

  3. 微服务架构与Docker容器之间关系

    微服务j架构与Docker容器之间关系 因公司业务市场的发展与技术架构等结合因素,希望接下来的产品架构能支撑轻量级.高并发.大数据.智能化.易维护.动态扩展等方向发展,因项目性能问题需要处理,公司架构 ...

  4. 漫谈单体架构与微服务架构(上):单体架构

    最近微服务架构特别火爆,就跟人工智能.区块链一样,软件架构设计如果不提微服务,感觉就像是与世界先进的架构风格和开发技术脱了节似的,各方各面都无法彰显高大上的气质. 本来再打算使用一套系列文章来讨论微服 ...

  5. 「微服务架构」基于NGINX的三种微服务参考架构

    作者注:本博文是系列文章的第一篇: Introducing the NGINX Microservices Reference Architecture (this post) MRA, Part 2 ...

  6. 同事操作两个数据源保持事务一致_「微服务架构」微服务架构中的数据一致性...

    在微服务中,一个逻辑上原子操作可以经常跨越多个微服务.即使是单片系统也可能使用多个数据库或消息传递解决方案.使用多个独立的数据存储解决方案,如果其中一个分布式流程参与者出现故障,我们就会面临数据不一致 ...

  7. 「微服务架构」亚马逊引领其自有微服务架构的原因

    "新堆栈"的真实故事,一次又一次,是关于具有巨大服务器需求的公司如何受到现有架构无法满足这些需求的限制,如何为自己解决问题,然后转而将其解决方案转售给 剩下的世界. 我们多么快地忘 ...

  8. 「微服务架构」Google和eBay在构建微服务生态系统方面的深刻教训

    当你看到来自谷歌,Twitter,eBay和亚马逊的大规模系统时,他们的架构已演变成类似的东西:一组多语言微服务. 当您处于多语言微服务结束状态时,它看起来像什么?Randy Shoup曾在谷歌和eB ...

  9. 「微服务架构」使用Canary版本来简化API版本控制

    API提供者可能面临的最大困难之一是如何管理版本和从实例到实例的构建.迭代的持续需求与组织的持续需求相匹配,使得版本控制成为现代API开发中一个有争议且经常被讨论的方面.但是,对于传统的版本控制,有一 ...

最新文章

  1. Nature:拟南芥根系微生物组的结构
  2. linux nfs 配置_NFS服务器
  3. Python3 Flask+nginx+Gunicorn部署(上)
  4. cef js返回c++的代码_CEF3开发者系列之外篇——IE中JS与C++交互
  5. 微服务精华问答 | 为什么需要微服务?
  6. python 手机编程termux_如何优雅的在手机上进行Python编程?
  7. base,override,virtual
  8. [转载] python中import问题
  9. unity3d meshBaker 基本的使用
  10. 射频识别技术漫谈(4)——数据编码
  11. 独立站SaaS建站模式是什么
  12. tp5 获取当前的url方法
  13. 技术人最基本投资建议
  14. AutoCAD .Net 创建直线Line
  15. 常见电路结构分析四:plc控制系统与其他控制系统的比较
  16. .rs是什么计算机语言,这几句计算机语言是什么意思Dim cnn As ADODB.ConnectionDim rs As ADODB.Reco...
  17. 关于 RESTful API HTTP状态码
  18. 【Python】输入输出(11)
  19. 算法的“有毒泡泡”,当真可以戒掉吗?
  20. 通信值勤维护管理条例_通信运行部值勤维护管理制度.doc

热门文章

  1. 如何缓解自己紧张焦虑的情绪?
  2. pyecharts qq聊天记录数据可视化
  3. 谷歌与Facebook的关系数据库之战
  4. 2022新版域名防红系统源码
  5. jzojWZK打雪仗【高精】【DP】【卡特兰数】
  6. 新概念2-课文名称和知识点
  7. 一个人不孤单 想一个人才孤单
  8. 梯度下降与随机梯度下降
  9. 什么是同城双活、异地双活、异地多活
  10. elaticsear学习常见错误