写点什么

软件工程技术的未来

  • 2016-12-08
  • 本文字数:1853 字

    阅读完需:约 6 分钟

“云、架构即代码、具有 API 和反脆弱系统的联邦架构,这些软件系统开发技术正迅速成为关注焦点”。这是 Mary Poppendieck GOTO Berlin 2016 大会上做“软件工程技术的未来”演讲时所提出的。

当数据量大到无法被单机所管理时,有两个解决方案,即纵向扩展和横向扩展。纵向扩展通过扩容单机的能力实现,Poppendieck 指出通常这并非是解决问题的正确方向。很多情况下需要做横向扩展,通过添加更多的计算机构建集群系统。

Poppendieck 在演讲中给出了两种不同的横向扩展方法:

  • 文件的横向扩展。以 Google 的搜索技术为例,文件被分割为多个小块并分别拷贝到多个服务器中。这样搜索可并行地完成,并通过合并各个服务器所给出的结果得到最终的搜索结果。
  • 架构的横向扩展。以 Amazon 的做法为例,事务会被切分为多个服务,每个服务使用特定服务器实现。当事务存在瓶颈时,可在多个服务器上复制服务,并且每个服务由一个半自治的“双比萨”团队(译者注:“双批萨”原则指团队规模不应超过两个披萨饼还不够吃的人数)负责。

Poppendieck 提到,越来越多的系统正在向云上迁移,云就是未来。她指明:

相比于大多数预制的数据中心,云更便宜、更稳定、更安全并且更具扩展性。

将已有的应用转化为基于云的应用是十分具有挑战性的。Poppendieck 引用了 IBM 的 Arthur Cole 所说的话:

针对传统数据架构所设计的应用如果不做大量的代码重构工作,就无法在云中很好地运行。

Poppendieckz 在演讲中给出了几个已有的架构即代码解决方案:

  • 使用容器,实现了过程的标准化和自动化。
  • 无服务器架构,以更低的价格提供了灵活的计算容量。
  • 软件定义网络,使用软件而非硬件实现了规模扩展。

单一的中央数据库会产生依赖性问题,这是由于所有的应用都依赖于数据,数据库的改变将会影响到很多的应用。Poppendieck 指出:“企业数据库是一个巨大的依赖性生成器”。由于每个独立团队的工作必须要和其它共享同一数据库的团队协作,这导致每个团队都无法实现自治的部署。联邦架构是单一数据库的替代技术,它将数据分割为适合各个独立模块或服务需求的本地数据存储,数据的存取只能通过 API 方法。API 正在替代中央共享数据库,并使物联网成为可能。Poppendieck 指出,使用 API 是软件工程的必备技术。API 应作为有具体团队负责的产品看待,并通过聚焦于 API 用户来推进和开发新的功能。

Poppendieck 说,没有必要尽力去实现系统零故障,我们可以换一种思维。当前很多的系统都是脆弱的,虽然它们在刚上线时都是鲁棒的,但是随着时间的进展,它们变得越发地难以维护。Poppendieck 提出,当今系统需要的是反脆弱,并具有面对故障的能力。在发生故障时,系统应能限定损害的程度,并从故障中恢复。

如何获取反脆弱系统取决于系统测试的方法,即如何通过注入故障产生给定的运行错误。Poppendieck 指出,为达到所期望的可用性和鲁棒性等级,系统需要隔离故障并从故障自动恢复。

Poppendieck 提到了当前开发软件的关键事宜,她说,为具备持续集成的能力,需要一个部署流水线;为获得持续集成所承诺的优点,需要具有一个包括产品管理、测试和运营的跨功能团队。部署流水线依赖于自动的测试、迁移和部署过程。持续集成需要所有团队通过代码库做交流,实现针对主干分支的持续集成。团队应维持软件时常处于发布就绪的状态,如果事实并非如此,你必须停下来并做到上述要求。只要实现了持续的部署,一旦有用的软件增量或功能就绪,就可通过切换或转换实现软件的增量发布。

Poppendieck 提出,持续交付提供了必要的端到端反馈。研究显示在半数情况下产品经理是错的,产品规格说明中会有三分之二的特性和功能是没有必要的。导致这些问题产生的原因在于做实验验证某个特性是否可以真正地解决手头问题之前,就试图达成具体开发特性的细节。为确保开发的解决方案能很好地适用于所需解决问题,需要通过实际的使用产生快速的反馈,这也正是精益开发和敏捷开发实践的真正价值所在。Poppendieck 建议将发布团队转变为在一定条件下可解决问题的团队。

Poppendieck 建议在系统开发的过程中采用基本的工程性过程实践、在现实制约因素的范围内学习,并且建议从模式或者信号而非需求或是特性开始。然后聚焦于问题本身并使用假设去规划工作。基于上述方法,开展多个实验并使用实验结果数据决定应如何继续工作。

查看英文原文: Technologies for the Future of Software Engineering


感谢张卫滨对本文的审校。

给InfoQ 中文站投稿或者参与内容翻译工作,请邮件至 editors@cn.infoq.com 。也欢迎大家通过新浪微博( @InfoQ @丁晓昀),微信(微信号: InfoQChina )关注我们。

2016-12-08 18:003261
用户头像

发布了 227 篇内容, 共 75.7 次阅读, 收获喜欢 28 次。

关注

评论

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

SLS 数据加工全面升级,集成 SPL 语法

阿里巴巴云原生

阿里云 云原生 服务日志

你在找提升效率的解决方案还是追求效果的解决方案

客户在哪儿AI

内容营销 ToB营销 大客户营销

缺陷管理系统指南:中大企业的首选

爱吃小舅的鱼

缺陷管理 中大型企业 缺陷管理工具推荐

AI项目验收!用友助力鑫阳钢铁进入智能判钢新时代

用友BIP

win版Adobe Acrobat Reader DC(PDF阅读软件)

iMac小白

4K Video Downloader(高清视频下载软件) v4.32.0便携版

iMac小白

喜报!钛铂数据 TapDB 通过中国信通院文档数据库产品测试

tapdata

国产数据库 TapDB 国产分布式文档数据库 钛铂分布式文档数据库 中国信通院测试

「漏洞原理」SQL 注入漏洞之理论讲解

我再BUG界嘎嘎乱杀

网络安全 安全 漏洞 SQL注入

最佳缺陷管理解决方案:2024年8大工具

爱吃小舅的鱼

缺陷管理系统 缺陷管理 缺陷管理工具

精益管理| 河南钢铁集团:以盈利型采购生态应对复杂的市场挑战

用友BIP

活动预告|8月3日 Streaming Lakehouse Meetup · Online 与你相约!

Apache Flink

StarRocks 实时湖仓 paimon

多重认可!嘉为科技入选《Gartner 2024中国基础设施战略成熟度曲线》

嘉为蓝鲸

AIOPS Gartner 可观测 OpenTelemetry

天翼云TeleDB数据库获得中国信通院两项测试证书

Geek_2d6073

如何从自建开源 Prometheus 迁移到阿里云托管 Prometheus 服务

阿里巴巴云原生

阿里云 云原生 Prometheus

win版PhotoScape X Pro(图片处理工具) v4.2.3 直装版

iMac小白

中石化中海燃供总会计师刘汉坤:一场数智革命,对内打破部门墙,对外抢占先机

用友BIP

win版Capture One 23 Pro(图片编辑软件)v16.4特别版

iMac小白

Gartner《IT服务管理平台市场指南》报告解读

嘉为蓝鲸

ITSM Gartner gartner中国 IT服务管理

从消息流平台Serverless之路,看Serverless标准演进

华为云PaaS服务小智

Serverless 华为云

ETL vs. ELT:数据集成的最佳实践是什么?

tapdata

etlelt区别 什么是ETL 什么是ELT 数据集成最佳实践

顶级项目管理系统大揭秘:全周期10大热门工具

爱吃小舅的鱼

项目管理 项目管理工具 项目管理软件

win版EndNote 21(文献管理软件) v21.4特别版

iMac小白

win版Turbo Studio(虚拟封装软件) v24.7.14 激活版

iMac小白

不断发展的AI监管如何影响网络安全

我再BUG界嘎嘎乱杀

人工智能 AI 网络安全 安全 网安

职场<火焰杯>测试开发大赛决赛成绩及获奖名单公布!

霍格沃兹测试开发学社

高效管理项目:9款国内软件深度剖析

爱吃小舅的鱼

项目管理 项目管理工具 项目管理软件

TapData 信创数据源 | 国产信创数据库达梦(Dameng)数据迁移指南,加速国产化进程,推进自主创新建设

tapdata

达梦数据库 达梦数据迁移 达梦增量同步

win版4K Video Downloader(高清视频下载软件)特别版下载

iMac小白

win版Adobe Acrobat Pro DC 2024(PDF编辑软件)绿色便携版

iMac小白

GraalVM 静态编译下 OTel Java Agent 的自动增强方案与实现

阿里巴巴云原生

阿里云 云原生 可观测

win版Adobe Acrobat Pro DC 2024(PDF编辑软件)

iMac小白

软件工程技术的未来_数据库_Ben Linders_InfoQ精选文章