写点什么

如何避免新代码变包袱?阿里通用方法来了!

  • 2019-10-10
  • 本文字数:1884 字

    阅读完需:约 6 分钟

如何避免新代码变包袱?阿里通用方法来了!

前言

即使代码多年的人都会对这两个问题有点蒙圈:什么是设计?什么是架构?


从单词上看:设计是 Software Design,架构是 Software Architecture;分别对应的作者是:Designer 和 Architect:


  • Architect 都是 Designer,但 Designer 未必是 Architect。正如所有的架构设计都是设计,但设计未必是架构设计;

  • Design 关注微观代码(inside component),Architecture 关注宏观软件结构(between components);

  • Architect 应该都是从 Designer 成长起来的。毕业了用 code 编写软件;成长了用 ppt 设计软件;

  • 只会用 ppt 设计,但代码写得不好的 Architect 都是假的 Architect;

  • Architecture 里听到比较多的词语:Serverless、FAAS、Microservice、multi-layer、Event driven、OSGI、NBF…

  • Design 里听到比较多的词语:SOLID、 DDD、正交设计、Design Pattern;

  • 搞不清 SOLID,也不可能把软件的层次分好,也无法理解什么是 OSGI 的价值;

  • 好的 Designer 是通往好的 Architect 的必经之路。

服务化架构的基本原则

New System

从零开始建立一个新的系统,有几个特征:


  • 历史包袱小

  • 上下文简单

  • 设计的约束小

  • 新写的每行代码都可能成为明天的历史包袱


由于调用方还没有,新系统可以比较完美的执行我们预想的架构设计,但是切记,最后那行才是最重要的那行:不要让今天的代码成为明天的历史包袱,新的每行代码都在书写历史。


上图的 1,2,3,4 代表新建系统的顺序:


  1. 由“相”抽象出“心”:先思考,那么多的业务场景下“相”,共同的特征“心”是什么。并反向用更多的相去验证心。

  2. 将“心”具象成领域模型:关注领域模型(Domain Model),解耦数据模型(Persistence Model):将 TUNNEL SPI 化。

  3. 将领域模型中的依赖 SPI 化:解耦对外部系统的依赖,反转依赖控制权。

  4. Mock 所有 spi 实现,确保“心”领域模型包裹的单元测试完全通过

  5. 实现 TUNNEL BUNDLE:设计数据模型(Persistence Model),关注“存”,“取”不关注领域模型。

  6. 实现依赖 SPI 适配 BUNDLE:连接真实依赖服务。

  7. 包装 domain service:模型相关,业务无关。

  8. 根据业务需求组合/编排 domain service 成为 scenario bundle 或者业务 SOP。

Working on legacy

对于一个软件工程师来讲,写代码最痛苦的事情莫过于 coding on legacy,但同时又给了我们各种说辞:


  • 这些代码太烂了,改起来太费劲【需要更多人】

  • 这事做不到,因为以前系统架构问题导致的【责任不在我】

  • 经过我的修改,现在已经好很多了,工单数量大批下降【我功劳显著】

  • 知不知道:接手你代码的人其实也在重复说上述 3 件事情


如何能有效的在遗留代码上工作,业内有本非常不错的书,叫"Working Effectively with Legacy Code",值得精读:



图片来源:书籍《Working Effectively with Legacy Code》


所以我这里的标题可能不准确,我要讨论的更多是"遗留代码的重构",什么时候我们开始讨论需要把现有系统重构:


  • 代码确实腐化到无法正常维护,或者新加一个需求代价很大;

  • 目前代码的技术架构满足不了下一步业务的发展;

  • 很多特性已经下线作废,却跟有用的代码藕断丝连;

  • 业务逻辑随着发展分散到不同的应用里,界限不清;

  • 专家级的未雨绸缪,着眼未来的规划和新技术的应用;

  • 换老大了,需要立新的 flag。


架构的基本原则依然是上面那幅图。但上下文的不同,我们的发力点和优先级有明显的区别。阿里整个体系里的依赖关系错综复杂,要对阿里环境下的系统做重构是件绝对谨小慎微的事情。为了完成在这么复杂体系下的架构及代码重构,我们必须有条不紊的分离关注点以及一如既往的坚持软件卓越。


聚焦与收敛上游调用



解耦下游依赖



以服务为单位切换



老系统下线


经过一步一步的分解,legacy 系统已经完全被重构,并且具备随时切换的准备。这里我给几个建议:


  1. 先把老实现作为 API 的默认实现,新的实现作为老的实现的降级实现,并使用策略分流一部分流量(具体比例跟团队信心相关);

  2. 对于有业务需求变更的部分应尽快实现在新的实现里,并将新实现作为 API 的默认实现,老实现作为新实现的降级实现,策略应该是即时降级,也就是新实现出现问题立刻降级到老实现;

  3. 运行一段时间没有问题后,讲所有默认实现切换为新实现,并将老实现作为新实现的降级实现;

  4. 其实这时就算所有切换完毕:老实现可以永远作为新实现的降级实现,也就是只要我升级一次服务,上一次成功版本就可以作为这次的降级实现,这样,线上问题回滚就是秒级的。

总结

本文基于借助 NBF 提供的远程多态,服务编排等能力下基础资料,商品,组网等系统新建,重构的经验及方法论总结。仅供遇到架构重构,解耦等问题困扰的技术团队参考。


本文转载自公众号阿里技术(ID:ali_tech)


原文链接


https://mp.weixin.qq.com/s/1nFNAtpDPKzv2TyRd3UOjg


2019-10-10 08:004242

评论

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

关于征集第六届世界智能大会平行论坛活动方案的通知

InfoQ 天津

一周信创舆情观察(9.27~10.10)

统小信uos

如何选择 Web 的数据存储方式?看我就够了

神策技术社区

存储数据 Web JS SDK sessionStorage

官方线索|1024短信盲盒,掘友你好,见字如面

xcbeyond

1024我在现场

入职腾讯的前一天,我哭了(传统行业被裁,奋战一年成功逆袭!)

收到请回复

架构 编程语言 后端 语言 & 开发 java

超低延迟直播架构解析

百度开发者中心

音视频 直播技术 智能视频

Telemetry标准日志接口如何提升运维效率?

怀瑾握瑜

运维 存储 SSD nvme

GrowingIO Design 组件库搭建之 CI/CD

GrowingIO技术专栏

持续集成 CI/CD 持续交付 Github Actions 组件库

Java 17 与 Java 11 相比有什么变化?

码语者

Java

微服务链路追踪组件Skywalking实战

Fox666

Spring Cloud Skywalking 链路追踪组件 微服务调用链

第六届世界智能大会主题征集活动入选主题公布

InfoQ 天津

爱奇艺埋点投递治理实践

爱奇艺技术产品团队

数据治理 埋点 pingback

SSH工具有哪些?哪款好用?

行云管家

运维 SSH 文件传输 SSH工具

SSD可靠性指标MTTF、MTBF、AFR解析

怀瑾握瑜

SSD nvme 可靠性 固态硬盘数据恢复

浪潮云荣登“中国数字安全能力图谱-信息计算环境”多项安全能力者领域

云计算

Knative Autoscaler 自定义弹性伸缩

全象云低代码

Knative Serverless Kubernetes

红黑树

Dobbykim

织信OA考勤管理系统是如何解放企业内部考勤的?

优秀

低代码

如何在 Web 前端做 3D 音效处理

ZEGO即构

大前端 音视频 3D音效 范围语音

如何说孩子才肯听,怎么听孩子才肯说(下)

石云升

读书笔记 育儿 10月月更

从Ftrace开始内核探索之旅

金蝶天燕云

Linux内核 Ftrace

北鲲云超算平台提供生命科学领域所需要的哪些软件?

北鲲云

等级保护测评机构哪里可以查询?谁能告知一下!

行云管家

网络安全 等保测评 安全等级保护

开源应用中心 | KodExplorer高效流畅云端存储&协同办公新体验

开源 开源技术

​涉密信息外泄,移动办公信息安全将如何保障?

BeeWorks

产品、

《原则》在解决技术问题中的应用

Changing Lin

10月月更

☕【Java技术指南】「技术盲区」看看线程以及线程池的异常处理机制都有哪些?

码界西柚

Java 线上程序问题 线程异常 10月月更

人社部、工信部颁布人工智能国家职业技能标准,百度参与制定

百度大脑

人工智能

物流CRM软件能帮你送快递吗?

低代码小观

企业管理 物流行业 CRM 管理系统 物流系统

【得物技术】自动化生成代码几种方案的演变

得物技术

自动化 代码 生成代码 机器 自动

没想到!我在简历上写了“精通MySQL”,阿里面试官跟我死磕后就给我发了高薪offer

收到请回复

Java MySQL 数据库 面试

如何避免新代码变包袱?阿里通用方法来了!_文化 & 方法_辉子_InfoQ精选文章