写点什么

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

  • 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:004232

评论

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

世界顶级SQL技术专家呕心沥血半年才整理出这份:SQL优化核心思想笔记,手慢无

Java 程序员 后端

业务中台的困境、及可能的解,java基础笔试题判断题

Java 程序员 后端

明道云在保险经纪公司中的应用场景例举

明道云

一见面就脱裤子?这份Spring Cloud微服务笔记应对面试怎么这么骚?

Java 程序员 后端

世界顶级Linux技术大神,耗时一年力作1300页Linux开发实战

Java 程序员 后端

15个问题自查真的了解java编译优化吗

华为云开发者联盟

Java 编译 对象 语义 符号表

两年半,50W的offer,三本,springboot运行原理生命周期

Java 程序员 后端

为什么大公司要使用微服务?(建议收藏),java基础案例教程第二版答案

Java 程序员 后端

三年Java开发经验,四面阿里成功斩获offer,分享面经,java面试问项目部署

Java 程序员 后端

三面阿里被灵魂追问,出门就被Java面试官逼哭!,java虚拟机的运行原理

Java 程序员 后端

三、Redis在SpringBoot中使用案例,java程序员面试笔试真题与解析

Java 程序员 后端

三年Java开发每天增删改查,终于靠着这份面试题,成功上岸京东

Java 程序员 后端

不是吧工作3年你都不知道这份超详细JVM内存结构,怎么涨薪?

Java 程序员 后端

不能错过的分布式ID生成器(Leaf-),积累总结

Java 程序员 后端

两道面试题,带你解析Java类加载机制,零基础也能看得懂

Java 程序员 后端

丹丹学妹哭着对我说:学长,JVM如何实现动态类型语言支持的呢

Java 程序员 后端

一篇神文让你“一夜封神“Mycat 中间件 (最详细讲解),linux操作系统实用教程文东戈课后答案

Java 程序员 后端

一线互联网大厂面经分享:阿里三面+头条四面(1),java基础入门第二版电子版

Java 程序员 后端

为什么分布式一定要有Redis?,java面试逻辑题三个开关三盏灯

Java 程序员 后端

七、Redis持久化的两种方式RDB和AOF理解,mybatis接口实现原理

Java 程序员 后端

上线GitHub七天后就标星87,并发知识体系大全

Java 程序员 后端

不是吧阿sir,你这业务太熟了吧,震惊面试官第八年,献给真心想学Java的打工人

Java 程序员 后端

不是吧阿sir,你这计算机网络也太熟了,震惊面试官一整年

Java 程序员 后端

两年Java开发经验,混迹“中浩科技,java全套百度云视频

Java 程序员 后端

为了你们不错过金三银四,我真是操碎了心!RabbitMQ面试真题来了

Java 程序员 后端

为了进大厂,我深扒了阿里字节等大厂面经,总结了50道必考题

Java 程序员 后端

一辈子也不容错过学习的微服务网关与用户身份识别,Zuul过滤器

Java 程序员 后端

不是吧工作3年你都不知道这份超详细JVM内存结构,怎么涨薪?(1)

Java 程序员 后端

不是吧阿sir!System,java面试问项目中遇到的技术难点

Java 程序员 后端

一线互联网大厂面经分享:阿里三面+头条四面,Java面试心得必备技能储备详解

Java 程序员 后端

三面美团Java岗,HR现场直接发offer,他是横着走出来的

Java 程序员 后端

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