读源码学架构:系统架构师思维训练之道
¥
35
5.0折
¥
69.9
九品
仅1件
作者郝佳
出版社人民邮电出版社
出版时间2022-06
版次1
装帧平装
货号@9
上书时间2023-11-29
商品详情
- 品相描述:九品
图书标准信息
-
作者
郝佳
-
出版社
人民邮电出版社
-
出版时间
2022-06
-
版次
1
-
ISBN
9787115590558
-
定价
69.90元
-
装帧
平装
-
开本
其他
-
纸张
胶版纸
-
页数
222页
-
字数
250千字
- 【内容简介】
-
《读源码学架构:系统架构师思维训练之道》以软件架构师的能力培养为切入点,结合作者在过去10多年的工作中积累的经验,介绍了一名合格甚至优秀的架构师应该具备的能力。
《读源码学架构:系统架构师思维训练之道》分为4篇,总计9章,基本涵盖了大部分生产环境下的系统设计原则以及方案。本书主要内容有基本设计原则、轻松应对后续的变化、优雅地暴露内部属性、复杂逻辑的拆解与协同、复用的人性化设计、屏蔽外部依赖的防火墙设计、事件的分散性与协议化封装、基于Reactor模式的系统优化、代码边界的延伸——善用SDK。
《读源码学架构:系统架构师思维训练之道》尽管内容篇幅短小,但是信息量相当密集。本书适合具有一定编程经验,在业务上仍然有追求,希望能晋升为软件架构师的软件开发人员阅读。同时,对设计模式感兴趣的初级开发人员,可以通过本书掌握与架构设计相关的知识。
- 【作者简介】
-
郝佳,前阿里巴巴高级架构师,现硕磐智能首席架构师,一直专注于中间件领域与数据服务领域的研究和开发;擅长系统的性能优化、系统设计与大数据服务处理,热衷于研究各种优秀的开源框架,尤其对Spring、MyBatis、JMS、Tomcat等源码有深刻的理解和认识;拥有4项技术专利,写作出版的书《Spring源码深度解析》深受读者好评。
- 【目录】
-
第 1章 基本设计原则1
1.1 单一职责原则2
1.1.1 简述2
1.1.2 示例3
1.1.3 小结8
1.2 开闭原则8
1.2.1 简述8
1.2.2 示例10
1.2.3 小结13
1.3 依赖倒置原则14
1.3.1 简述14
1.3.2 示例15
1.3.3 小结17
1.4 里氏替换原则17
1.4.1 简述17
1.4.2 示例18
1.4.3 小结20
1.5 迪米特法则20
1.5.1 简述20
1.5.2 示例21
1.5.3 小结22
1.6 接口隔离原则22
1.7 总结24
第 2章 轻松应对后续的变化27
2.1 抛出问题27
2.2 问题分析32
2.3 Spring中的PostProcessor机制33
2.3.1 示例33
2.3.2 思路抽象38
2.4 设计优化40
2.4.1 需求分析与设计40
2.4.2 代码实现41
2.5 总结49
第3章 优雅地暴露内部属性51
3.1 抛出问题51
3.2 问题分析58
3.2.1 违背设计原则58
3.2.2 设计看似优雅,实则不然59
3.3 Spring中的Aware机制61
3.3.1 Aware概述64
3.3.2 ApplicationContextAware的实现逻辑65
3.3.3 思路抽象67
3.3.4 优势分析68
3.4 问题优化71
3.5 总结75
第4章 复杂逻辑的拆解与协同77
4.1 抛出问题77
4.2 问题分析81
4.2.1 PostProcessor模式的错误选型82
4.2.2 模板方法模式的错误选型83
4.3 Tomcat中的PipeLine机制87
4.3.1 Tomcat容器结构与协同处理88
4.3.2 思路抽象91
4.4 问题优化93
4.4.1 设计优化93
4.4.2 关键代码94
4.4.3 链表与for循环的区别101
4.5 总结104
第5章 复用的人性化设计105
5.1 抛出问题105
5.2 问题分析112
5.2.1 大量冗余代码112
5.2.2 AOP切割原子逻辑114
5.3 Spring中事务的封装与复用118
5.3.1 Spring的事务处理118
5.3.2 思路抽象123
5.4 问题优化125
5.4.1 注解设计128
5.4.2 定义切面逻辑129
5.4.3 定义拦截器134
5.5 总结137
第6章 屏蔽外部依赖的防火墙设计139
6.1 抛出问题139
6.2 问题分析140
6.2.1 服务雪崩140
6.2.2 逻辑入侵146
6.3 思路抽象149
6.4 问题优化151
6.4.1 优化对接层151
6.4.2 构建防腐层152
6.5 总结154
第7章 事件的分散性与协议化封装157
7.1 抛出问题157
7.2 问题分析160
7.2.1 扩展类爆炸160
7.2.2 扩展机制与监听机制的错用161
7.3 WebSocket事件的封装与协议化164
7.3.1 WebSocket164
7.3.2 通信设计166
7.3.3 思路抽象171
7.4 问题优化174
7.4.1 生产者视角174
7.4.2 消费者视角178
7.5 总结182
第8章 基于Reactor模式的系统优化185
8.1 抛出问题185
8.2 问题分析187
8.2.1 加机器187
8.2.2 串行调用改为并发调用187
8.2.3 预处理188
8.3 Netty中的Reactor模式188
8.3.1 Netty概述188
8.3.2 BIO与NIO189
8.3.3 Reactor编程模型192
8.3.4 思路抽象197
8.4 问题优化199
8.4.1 方案设计199
8.4.2 代码优化201
8.5 总结216
第9章 代码边界的延伸——善用SDK217
9.1 抛出问题217
9.2 问题分析与优化217
9.2.1 SDK与API的区别218
9.2.2 SDK可以解决的问题219
9.2.3 SDK缺点与解决221
点击展开
点击收起
— 没有更多了 —
以下为对购买帮助不大的评价