架构之美

本文为读书笔记

一、架构决策的案例

  • 架构设计
    • 决策
    • 交流
  • 对并发的考虑不足,使用Spark导致瓶颈无法解决
  • 由于是微服务,接口保证了可扩展性,整体迁移到ES,前端不需要修改
  • 决策失败:对实际场景的瓶颈预计不足,选型不从实际性能瓶颈出发
  • 架构设计不是闭门造车,而是集体交流的结果
  • 白板便利贴
白板便利贴

二、架构视图

RUP 4+1视图
  • 业务场景

    • 用户视角的实际业务场景
    • 关键用例


      业务场景
  • 逻辑视图

    • 关注参与业务子系统(角色)
    • 角色
      • 产品
      • 开发
      • 运维
      • 测试
    • 分层架构


      逻辑视图
逻辑视图 分层架构
  • 开发视图

    • 分包、分命名空间
    • 用于约束开发人员,统一思想,确定边界


      开发视图
  • 进程视图

    • 运行时的调用情况
    • 对业务性能要求高的很重要


      进程视图
  • 物理视图

    • 系统部署


      物理视图

三 架构模型

C4架构模型
  • Context
    • 黑盒子
    • 有上下游
  • Container
    • 子模块划分
    • 边界确认
  • Componet
    • 流式处理业务(组合、判断)
      • source 输入流
      • channel 处理流
        • 多个细粒度的processor组合
        • 不包含业务,而是组合业务
        • 把有副作用(修改外部元素或流)和无副作用的processor区分开
        • 输入输出尽量是模型对象而不是基本类型,避免职责模糊
        • Processor甚至命名很长,但可重用性高,同时方便单元测试
      • sink 输出流
  • Classes
    • 具体执行类


      C4架构模型

四 架构风格

  • REST架构风格

    • 核心是状态模式
    • 通过状态模式实现的应用层的无状态,降低系统的复杂性(mvi也有类似的实现)


      REST架构风格
  • 微服务风格

    • 小而美,松耦合,按需扩展
    • 单独迭代进化
    • 优点
      • 可以任意增删,按需扩展
    • 缺点
      • 增加了系统的复杂度
    • 优先设计成微服务
      • 频繁更新变更
      • 采用不同技术栈
      • 高并发可以水平扩展


        微服务风格

        image.png
  • 关键部件

    • 服务注册发现
    • 配置中心
    • 断路器 避免死锁,超时强制抛异常。重启服务等。
    • 分布式事务
    • 负载均衡
    • 监控 方便运维
      • 服务监控
      • 日志监控
      • 数据库监控
      • 资源监控
  • CQRS - 命令、查询职责分离

    • command
      • 无返回、有副作用
      • 如果返回,则返回结果
    • query
      • 无副作用,有返回
    • Event store用于做副作用事件日志


      image.png

五 分层架构模式

  • 经典3层
    • View 用户界面层
    • Presenter 业务逻辑层
    • Model 数据访问层
    • Data 数据库
  • 演进分层架构
    • 前端
      • Web UI、Mobile UI、3rd-party serviceces
      • 面向用户
    • 控制层
      • 中间层
      • 面向通信、路由、鉴权、负载均衡
    • 应用层
      • 组合业务逻辑
      • 组合领域层调用
      • 面向应用、业务
    • 领域层
      • 执行单一业务逻辑
      • 面向具体业务
    • 基础设施层
      • 数据库、设置、设备
      • 面向资源/设备


        演进分层架构
  • 稳定依赖原则
    • 依赖稳定的,即接口,因为接口抽象(依赖倒置)
    • 上游依赖下游,下游不应依赖上游
六边形架构
  • 核心是domain和application
  • 外延是adapter
  • 作用是可以被多种上下游复用


    六边形架构

六 架构设计的过程

架构设计的过程
领域驱动设计DDD
设计过程
  • 战略设计
    • 通过问题域和业务期望来划分边界
    • 统一语言(接口),限制边界上下文
  • 战术设计
    • 模块内的自迭代(实现、维护、重构)
推广到分包实践
  • 业务(interface - 实现)- VP
    • 如果要替换一个模块 会替换的是功能,而绝不是同类集合
    • 也可能被抽出作为公共库
  • 公共接口(Util 日志)
  • 资源(JavaBean 常量 基础接口(BaseVP)M层入口(视情况))
  • 基类、没必要放到下一级分包
  • 统一命名,方便团队统一理解
举例
  • a包
    • a包提供的A接口
      • a1包
        • 实现A接口的A1类
      • a2包
        • 实现A接口的A2类

七 总结,架构思想

  • 分而治之,控制规模【领域、边界】
    • 团队太小会导致团队过于松散,团队太大又会增加管理成本。程序跟团队管理也是一样的。
  • 简单、清晰、一致【统一上下文】
    • 统一命名,方便团队统一理解
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 162,475评论 4 372
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 68,744评论 2 307
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 112,101评论 0 254
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 44,732评论 0 221
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 53,141评论 3 297
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 41,049评论 1 226
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 32,188评论 2 320
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,965评论 0 213
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,716评论 1 250
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,867评论 2 254
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,341评论 1 265
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,663评论 3 263
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,376评论 3 244
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,200评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,990评论 0 201
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 36,179评论 2 285
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,979评论 2 279

推荐阅读更多精彩内容

  • 安卓开发技术发展到现在已经非常成熟,有很多的技术专项如插件,热修,加固,瘦身,性能优化,自动化测试等已经在业界有了...
    常兴E站阅读 2,970评论 3 55
  • 美的核心在于概念完整性——即一组抽象和规则,在整个系统中尽可能简单地应用它们。 我们将计算机系统的架构定义为一组最...
    testfor阅读 1,218评论 0 0
  • 第九章 软件架构设计 9.1 软件架构概述 9.1.1 软件架构的定义 定义1:软件或计算机系统的软件架构是该系统...
    步积阅读 4,676评论 0 17
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,112评论 18 139
  • 无意中看王牌对王牌第一集看到成龙大哥,曾志伟,张国立这些老咖,好有感觉。 想想已可以撑起一档节目的王祖蓝曾是超级掌...
    阿ZA阅读 185评论 0 0