2025上半年,最新 AI实践都在这!20+ 应用案例,任听一场议题就值回票价 了解详情
写点什么

微服务与单片应用之间的较量

  • 2014-08-22
  • 本文字数:800 字

    阅读完需:约 3 分钟

采用微服务是分解单片应用(monolithic application)的一种方式。这样做可以获得更高的解耦程度、关注点分离,以及快速部署等优势。但是,这并不是唯一也不是最好的方式。 Todd Hoff 对这两种架构方式进行了描述与比较

Todd 提到了今年早些时候在 twitter 上发生的一场辩论,这场辩论的参与者包括了 Adrian Cockcroft Sam Newman John Allspaw ( Etsy ),他们对微服务和单片应用之间的优缺点进行了比较。该辩论首先由 Adrian 发起,他声称在听了 QCon 伦敦 Etsy 的演讲之后,让他更清晰地认识到为什么单片应用是一个死胡同,而微服务应该可以取而代之从而能获得持续的可伸缩的部署。John 则指出,虽然微服务带来了更多的选择,但同时引入了更多的约束。而少量较容易理解的工具和模式反倒能带来优势。

Todd 将 Etsy 描述为一家成功的公司,因为该公司拥有着大约 150 个工程师,并且每天会部署超过 60 次的单个单片应用。在他的印象中,虽然很多人将单片应用视为反模式,但是 Etsy 通过采用例如持续集成、自动化部署、良好的监控等手段构建了这个大型的网站,并且做得很好,而且他们基本上都是从主分支进行部署的。

一个用于针对所谓的单片应用问题的解决方案是将它分解成一系列微服务,从而达到松耦合和独立部署这样的目标。但是 Todd 提出了质疑,微服务是达到上述目标的唯一或者最好的方式吗?他指出 Etsy 一天发布多次小型变更的方式也是可选方式的一个现成的例子。

Todd 强调 Etsy 目前一直在单片应用的方式下工作地很好,从而表示了对单片方式的支持。因为即使是在一个单片应用中,复杂度也可以被封装到每个服务之中。他将服务与代码库进行了比较,并表示只要是足够稳定的接口,也可以像拥有自己生命周期的独立产品一样对待。一旦接口发生变化,不管是使用代码库还是服务,新的版本就会创建。Todd 相信,只要基于合适的软件工程,单片的程序也可以工作地很好。

查看英文原文: Microservices vs Monolithic Applications

2014-08-22 00:391643
用户头像

发布了 52 篇内容, 共 23.8 次阅读, 收获喜欢 5 次。

关注

评论

发布
暂无评论
发现更多内容

Java高级特性之多线程

Java 程序员 后端

Jenkins部署springboot项目

Java 程序员 后端

JVM及GC机制

Java 程序员 后端

Linux入门(二) ~ Linux的常用命令

Java 程序员 后端

Kurento实战之四:应用开发指南

Java 程序员 后端

markdown+七牛云,让写文更容易

Java 程序员 后端

JSP“三大请求传参方式”及“中文乱码问题解决方案”详解

Java 程序员 后端

K8S环境的Jenkin性能问题处理续篇(任务Pod设置)

Java 程序员 后端

keepalived实现双机热备(1)

Java 程序员 后端

Kubernetes 常用命令大全

Java 程序员 后端

Log4j2的Appenders配置详解

Java 程序员 后端

JetBrains 又出了一款新神器,一套代码适应多端!

Java 程序员 后端

k8s常见问题大收集

Java 程序员 后端

keepalived实现双机热备

Java 程序员 后端

Linux极速上手,超全面总结

Java 程序员 后端

Java高并发编程课后总结

Java 程序员 后端

JVM之调优及常见场景分析

Java 程序员 后端

Layui图片上传组件使用指南

Java 程序员 后端

Memcached缓存

Java 程序员 后端

Java面试题超详细整理《JVM篇》

Java 程序员 后端

Jsoup解析html

Java 程序员 后端

Linux系统:第六章:Linux服务

Java 程序员 后端

Linux系统:第四章:Linux文件系统

Java 程序员 后端

Java面试题超详细整理《JVM篇》(1)

Java 程序员 后端

Java黄金五年——1~5年一个Java程序员从入行到大牛的晋升之路

Java 程序员 后端

Kurento实战之一:KMS部署和体验

Java 程序员 后端

Linux常用命令(面试题)

Java 程序员 后端

Java面试题大全(持续更新中)

Java 程序员 后端

JDK8-Object源码

Java 程序员 后端

Kubernetes任务调用Job与CronJob及源码分析

Java 程序员 后端

Linux下jdk的安装卸载切换

Java 程序员 后端

微服务与单片应用之间的较量_SOA_Jan Stenberg_InfoQ精选文章