AI实践哪家强?来 AICon, 解锁技术前沿,探寻产业新机! 了解详情
写点什么

微服务和软件开发目标

  • 2015-03-12
  • 本文字数:1092 字

    阅读完需:约 4 分钟

Dan North QCon 伦敦大会的演讲中说,软件的目标就是持续地使筹建时间减至最少以产生积极的商业影响,其他事情都是具体细节。他描述了有关代码推理的方法及其如何适应于微服务架构风格。

对IT 业思想先驱North 来说,软件开发的目标就是创造商业影响,这里引用了Gojko Adzic 在其著作《影响地图》中的流行语。商业影响在组织的内部(比如新客户)或者降低运营成本的效果是可见的。软件开发的目标是实现这一商业影响,或者更具体地最小化筹建时间,即从发现商机到完成解决方案的时间。这样做上几次是容易的,难在持续这样做,这推导出North 前述的软件开发的目标。

North 将代码分为三类,一种是你最新写的并且很熟悉;一种是 North 称其为 fabric 的、每个人都熟悉、代码附有充分的测试和文档;一种是没人熟悉的,依赖不明确且牵一发而动全身。对 North 而言,软件开发中最大的问题是第三类代码,没有人熟悉代表着成本和争端。从 North 的观点得出,代码要么稳定要么干掉,永远不要使其成为第三类,未知的代码。因而,North 搬出了几个模式来支持这一观点并将其引入到微服务之中。

第一种模式是短软件半衰期,参照物理学和不稳定原子衰变之快。North 相信代码应该有一个非常短的软件半衰期,以突显目标明确的代码最重要的是可以被推导的、可以存意使其稳定或将其废弃。他强调,理解的代码的目的是非常重要的。

第二种模式是如我所想(fits in my head),这是引自 James Lewis 的表达。这种模式是关于推理代码能力的;推理大系统的一种方法是将其分解,另一种方法是简化问题或者忽略大的部分而每次关注一个小的特定部分。同样的原理可以用于不同规模上的推理,如何定义一个方法的功能、如何建模一项工程、如何建模通信机制等等。

North 从他的推理中定义了一种架构风格,他称其为可替换的组件架构,通过上下文一致可以很好地将短期软件半衰期和如我所想两种模式结合在一起。所有的组件都是完全可以替换的,它们包装在隐藏内部细节的 API 中,并通过发送消息相互通信。这些组件就像微小的电脑一样传递信息,North 强调了 30 年前 Alan Kay 是如何定义的面向对象(OO)编程的。

微服务可作为一种可替换的组件架构,当优化替换性和一致性时,这两块儿都可以作出每日选择。North 认为使用微服务存在一个概念上的错误,微意味着更小并不总是最好的,更应该是可替换的更好。

查看英文原文: http://www.infoq.com/news/2015/03/microservices-software


感谢丁晓昀对本文的审校。

给InfoQ 中文站投稿或者参与内容翻译工作,请邮件至 editors@cn.infoq.com 。也欢迎大家通过新浪微博( @InfoQ )或者腾讯微博( @InfoQ )关注我们,并与我们的编辑和其他读者朋友交流。

2015-03-12 00:572276

评论

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

组合模式打印窗口组件的树结构

纯纯

融云 CTO 杨攀:出海社交娱乐项目的通信技术应用指南

Geek_116789

架构师训练营第三周 - 学习总结

Eric

极客大学架构师训练营

用于可视化软件体系结构的C4模型(转载)

清风徐徐

ARTS-week4

王钰淇

ARTS 打卡计划

架构师训练营--第三周作业

花花大脸猫

极客大学架构师训练营

架构师训练营第 3 周——学习总结

在野

极客大学架构师训练营

8行代码的21问题: 如何有效Code Review?

zzj8704

Code Review 代码规范 可测性 CR常见规则 结构化CR

第三周作业

芒夏

极客大学架构师训练营

架构师训练营第三周作业

Linuxer

极客大学架构师训练营

利用组合设计模式编写一个界面打印

elfkingw

极客大学架构师训练营

学习总结

Mr.Monkey

【漫画】最近,老王又Get了CDN的新技能

阿里云Edge Plus

CDN

奈学教育《大数据开发工程师》课程大纲

古月木易

大数据

到底是什么让IT人如此苦逼???

纯洁的微笑

程序员 程序人生

第三周作业

changtai

极客大学架构师训练营

架构师训练营 - 第 3 周学习总结

牛牛

学习 极客大学架构师训练营

夏日一起“奥”!麥吉 machi machi奥利奥风味布蕾奶茶限量上市!

Geek_116789

奈学教育《大数据开发工程师》课程大纲

奈学教育

大数据

架构师训练营第三周 - 作业

Eric

极客大学架构师训练营

架构师训练营--第三周学习总结

花花大脸猫

极客大学架构师训练营

大庆金桥:基于 SpreadJS 开发实现计量器具检定证书的在线生成与打印

葡萄城技术团队

SpreadJS 计量器具检定 检定证书

CDN百科第五讲 | CDN和游戏加速器有什么区别?

阿里云Edge Plus

CDN

奈学教育<P7架构师>课程大纲(第一阶段)

古月木易

极客大学架构师训练营

操作 Docker 容器 | Docker 系列

AlwaysBeta

Docker 容器

招谁惹谁了

池建强

写作 分享

作业

Mr.Monkey

一行一行源码分析清楚AbstractQueuedSynchronizer

猿灯塔

Java Netty 并发

组合模式设计窗口组件

孙野

奈学教育<P7架构师>课程大纲(第一阶段)

奈学教育

极客大学架构师训练营

作业

GalaxyCreater

作业

微服务和软件开发目标_语言 & 开发_Jan Stenberg_InfoQ精选文章