性能之道 分布式系统全栈性能优化 版权信息
- ISBN:9787111767244
- 条形码:9787111767244 ; 978-7-111-76724-4
- 装帧:平装-胶订
- 册数:暂无
- 重量:暂无
- 所属分类:>>
性能之道 分布式系统全栈性能优化 本书特色
性能的重要性越来越高,但是要想真正实现高性能,必须具有架构思维,从多个层面进行设计和优化。
在AI时代,具有性能 架构这种综合性能力的技术人将成为企业中的高薪者。
本书以方法论为基础,站在架构层面,以网络、通信、客户端、单服务器、数据库为优化方向,深入解读软件全栈优化解决方案,内含4大主流产品优化案例。可以帮助你成为企业中的高端人才。
性能之道 分布式系统全栈性能优化 内容简介
这是一本从点、线、面、体4个维度深度解读分布式系统性能优化方法的专业工具书,更是一套全栈性能优化解决方案。其中,“点”指的是代码中的单个语句或函数,“线”指的是代码中的执行路径,“面”则上升到模块、子系统级别,“体”则指的是整个系统。4个维度对应4个不同的优化层次,只有这4个维度配合,才可以真正实现分布式系统的整体性优化。
全书融合了5位长期(*长有近30年工作经验)从事软件开发及优化工作的一线专家的实践经验和深刻理解,不仅从理论层面深入解读了性能优化的本质,还从软件开发整体流程的角度构建性能优化体系和评估策略。全书本着“没有jue对的好设计,只有适合的设计”的理念展开介绍,不仅提供可落地的技巧,还直指本质,让读者知其然并知其所以然,从而设计出适合自己的性能优化方案。
本书共分为17章。
第1~4章 主要介绍作者对性能优化的理解以及性能优化体系及评测方法,这部分的目的是帮读者形成性能优化方法论,其中包括架构的本质、性能优化的本质、性能优化策略、性能优化4个维度、影响性能的因素、性能测试工具、性能测试方法和流程等重点内容。
第5~9章 对网络、通信、客户端、单服务实体、数据库这5个性能约束特点进行深度剖析,并给出具体的优化方法与策略。
第10章和第11章分别对缓存系统、消息队列在性能优化中的应用进行解读,这两个是实现高性能的途径,也是研发人员必须掌握的技巧。
第12~15章通过对智能音箱、网上商城、营销红包、交易系统4个典型案例性能设计与优化的全面解读,帮读者学以致用,并更深刻理解性能优化的原理。
第16章和第17章分别介绍全链路观测或压测的具体实现方法与应用场景,以及云原生技术对性能的影响。
性能之道 分布式系统全栈性能优化 目录
目 录前言 性能是软件非功能特性的基本面认知篇第1章 软件架构的时空观 21.1 软件架构的时空定义 21.2 软件架构的分类 31.2.1 体系结构上的分类 31.2.2 流程决策上的架构分类 41.3 软件架构设计的原则与模式 51.3.1 软件架构设计的原则 51.3.2 软件架构设计的模式 61.4 软件架构的常用技术栈 81.5 本章小结 10第2章 软件性能的时空观 11目 录前言 性能是软件非功能特性的基本面认知篇第1章 软件架构的时空观 21.1 软件架构的时空定义 21.2 软件架构的分类 31.2.1 体系结构上的分类 31.2.2 流程决策上的架构分类 41.3 软件架构设计的原则与模式 51.3.1 软件架构设计的原则 51.3.2 软件架构设计的模式 61.4 软件架构的常用技术栈 81.5 本章小结 10第2章 软件性能的时空观 112.1 软件性能的宏观多维模型 112.1.1 系统边界 122.1.2 内部结构 132.1.3 外部效应 132.1.4 连接输入 142.1.5 本节小结 142.2 软件性能的一般含义 142.3 软件性能的时空视角 152.3.1 系统性能的时间指标 162.3.2 软件性能的空间指标 172.3.3 系统性能指标的时空关联 182.3.4 常见的软件性能指标 182.4 软件性能的描述方式与工具 192.4.1 软件性能的时间描述—— 时序图 202.4.2 软件性能的空间描述—— 组件描述直方图 202.5 软件的性能测试与监控 202.5.1 性能测试 212.5.2 监控性能拐点 212.5.3 容量规划 222.6 本章小结 22第3章 软件性能优化体系 233.1 软件性能优化策略 233.1.1 控制资源需求相关因素 243.1.2 管理资源相关因素 253.2 基于“点”的性能优化 273.3 基于“线”的性能优化 283.4 基于“面”的性能优化 303.5 基于“体”的性能优化 333.5.1 **阶段:常规优化 343.5.2 第二阶段:使用缓存与 读写分离 343.5.3 第三阶段:异步化与事务 353.6 性能优化的PDCA 373.7 性能与其他非功能要素 383.8 本章小结 39第4章 性能测试与评估 404.1 软件性能的度量 404.1.1 性能测试的目的及意义 404.1.2 性能测试的度量指标 424.1.3 常见基础设施性能指标 444.2 性能测试常用工具 454.2.1 性能测试场景 454.2.2 性能测试工具简介 474.2.3 性能测试工具选择 514.3 性能测试的方法、误区和流程 534.3.1 性能测试的方法 534.3.2 性能测试的误区 544.3.3 性能测试的流程 564.4 性能测试的结果分析与评估 614.4.1 施压机器的指标观测 624.4.2 软件的指标分析 644.4.3 软件的事后评估 694.5 本章小结 71实践篇第5章 网络性能 745.1 互联网的性能问题 745.1.1 规模问题 755.1.2 距离瓶颈 755.2 内容分发的方式与性能 755.2.1 集中托管 755.2.2 数据中心 765.2.3 分布式CDN 765.2.4 P2P网络 775.3 CDN的选择 775.4 应用层的网络性能优化 785.4.1 减少传输层开销 795.4.2 寻找更好的路由 795.4.3 内容预取 795.4.4 使用压缩和增量编码 795.4.5 边缘组装 805.4.6 边缘计算 805.5 计算密集型应用的性能提升—— 高性能网络 805.5.1 Inf?iniband网络与RDMA 815.5.2 RDMA的关键特性 825.5.3 RDMA的上层接口 835.5.4 RDMA的底层实现 855.5.5 RDMA的性能优势与 主要应用场景 865.6 网络性能观测工具 865.6.1 网络可观测性建设 875.6.2 网络分析工具 885.7 本章小结 89第6章 通信性能 906.1 面向互联网的软件 906.1.1 网络应用并非只是计算 906.1.2 计算中的通信视角 916.1.3 网络应用的通信视角 926.2 通信协议的分层设计与优化 946.2.1 通信协议的分层设计 946.2.2 通信协议的优化 956.3 软件通信中的数据组织 956.3.1 XML、JSON和 Protocol Buffer 966.3.2 性能视角的数据包大小 966.4 软件通信中的复用机制 976.5 软件通信的纠错处理 986.5.1 前向纠错与重传纠错 986.5.2 重传机制 996.6 软件通信中的流量控制 1006.6.1 反向压力 1006.6.2 减负载 1006.6.3 熔断 1016.7 通信协议的优化示例:基于 HTTP的性能优化 1026.7.1 链路复用 1026.7.2 数据压缩 1036.7.3 SSL加速 1036.8 本章小结 103第7章 客户端性能/前端性能 优化 1057.1 性能优化指标 1057.1.1 以用户为中心的性能指标 1067.1.2 三大核心指标 1077.1.3 前端性能测量工具汇总 1127.2 前端系统优化 1137.2.1 HTTP中的性能优化 1137.2.2 代码压缩 1167.2.3 JavaScript中的性能优化 1177.2.4 Webpack优化 1217.2.5 Vue项目性能优化 1287.3 客户端系统优化 1317.3.1 Flutter项目优化 1317.3.2 PC端QT项目优化 1387.3.3 客户端性能监控的思考 1397.4 本章小结 140第8章 单服务实体的性能优化 1418.1 单服务实体性能问题定位的 简单策略 1418.1.1 度量指标 1428.1.2 资源列表 1428.1.3 功能模块图 1438.1.4 度量方法 1438.1.5 软件资源 1438.1.6 性能定位的简单策略 1448.2 操作系统的配置优化 1448.3 代码性能的基础保障—— 静态分析 1468.4 API的性能约定 1478.4.1 面向API的性能分类 1478.4.2 API的性能约定 1498.5 资源池的应用 1518.5.1 连接池 1528.5.2 线程池 1558.5.3 内存池 1568.6 本章小结 157第9章 数据库性能 1589.1 从数据库技术发展看性能问题 1589.1.1 数据库对系统性能的影响 1589.1.2 数据库技术的整体发展 1599.1.3 关系数据库的诸多挑战 1599.1.4 NoSQL运动的百花齐放 1649.1.5 分布式演进的步步为营 1649.1.6 分布式数据库的风起云涌 1689.2 面向分布式应用的数据库 性能分析 1709.2.1 制定数据库性能规划目标 1709.2.2 通过压测了解数据库性能 1709.2.3 分析应用数据库性能瓶颈 1719.2.4 数据库性能优化一般方法 1719.3 MySQL的常见优化方法 1749.3.1 操作系统参数优化 1749.3.2 数据库配置优化 1759.3.3 数据库设计优化 1789.3.4 SQL查询优化 1849.3.5 SQL写入优化 1879.3.6 应用连接池优化 1879.4 本章小结 189第10章 缓存的应用 19010.1 无处不在的缓存 19110.2 客户端缓存 19210.2.1 页面缓存 19210.2.2 浏览器缓存 19410.2.3 App上的缓存 19510.3 网络端缓存 19610.3.1 Web代理缓存 19610.3.2 边缘缓存 19710.4 服务端缓存 19810.4.1 平台级缓存 19810.4.2 分布式缓存的应用 19810.5 数据库缓存 19910.5.1 数据库缓存:MySQL的 查询缓存 19910.5.2 检验Query Cache的 合理性 20010.5.3 数据库缓存:InnoDB的 缓存性能 20010.6 营销场景案例:优惠券 (红包)发放与核销 20210.7 电商案例:应用多级缓存 模式支撑海量读服务 20410.7.1 多级缓存介绍 20410.7.2 如何缓存数据 20510.8 本章小结 208第11章 消息队列 21011.1 消息队列概述 21011.2 消息队列使用场景 21111.2.1 削峰填谷 21111.2.2 应用解耦 21311.2.3 异步处理 21311.2.4 分布式事务一致性 21411.2.5 大数据分析 21811.3 消息中间件的选型 21911.3.1 RocketMQ 22111.3.2 RabbitMQ 22211.3.3 ActiveMQ 22311.3.4 Kafka 22311.4 本章小结 224案例篇第12章 小度音箱的性能优化 22812.1 智能音箱的组成和系统架构 22812.1.1 对话式AI操作系统—— DuerOS 22912.1.2 智能音箱的典型工作 流程 23112.2 小度音箱的性能分析 23212.2.1 核心的性能指标 23212.2.2 核心指标的度量 23212.3 小度音箱系统的网络拓扑 优化 23412.4 小度音箱系统的应用协议 优化 23412.5 小度音箱系统的业务逻辑 优化 23512.5.1 智能音箱业务中的 延时分布 23612.5.2 预测预取 23612.5.3 连接池的应用 23712.6 小度音箱系统的缓存应用 23812.7 本章小结 238第13章 网上商城的性能优化 23913.1 网上商城的架构与业务流程 23913.1.1 核心模块 24213.1.2 核心业务 24213.2 商城系统的性能指标 24413.3 网上商城核心模块的性能 优化 24513.3.1 商品管理 24513.3.2 用户管理 24813.3.3 购物车管理 25113.3.4 订单管理 25413.3.5 秒杀系统设计 25713.4 本章小结 274第14章 典型并发场景—— 营销红包的性能优化 27514.1 类支付宝红包系统的业务流 和挑战 27514.1.1 类支付宝红包业务动作 和潜在技术挑战分析 27514.1.2 讨论方案:大商户红包 热点问题 27614.1.3 多级缓存策略 27714.1.4 讨论方案:单笔支付咨询 多红包问题 27714.2 类微信红包系统的业务流和 挑战 27814.2.1 类微信红包业务动作 分析 27814.2.2 异步化 27814.2.3 SET化:分拆资源 27914.2.4 无并发写的实践 27914.3 预加载和考虑备案 28014.4 性能优化策略与案例的关系 28114.5 本章小结 282第15章 支付系统/核心交易 系统的性能优化 28315.1 支付系统/核心交易系统的 架构特点 28415.1.1 支付系统的作用 28415.1.2 支付系统的架构 28515.2 交易系统的链路优化 29115.3 对账系统的设计 30215.3.1 对账系统概述 30215.3.2 对账需求分析 30415.3.3 对账流程和规则设计 30515.3.4 对账系统实现说明 31115.4 本章小结 312扩展篇第16章 全链路性能压测 31416.1 全链路性能压测的背景与 价值 31416.2 端到端全链路监控分析 31516.2.1 APM技术 31616.2.2 Apache Skywalking 31616.3 线上流量复制与染色 31816.3.1 流量复制 31816.3.2 流量复制工具 31816.3.3 流量染色 32116.4 全链路压测的数据安全与 隔离 32116.4.1 数据隔离 32216.4.2 影子库与影子表 32216.4.3 ShardingSphere的影子库 功能 32316.5 全链路压测下相关系统的 改造 32416.5.1 业务系统的改造 32416.5.2 消息队列的改造 32616.5.3 外调服务的挡板功能 32616.5.4 缓存中间件的改造 32716.6 全链路压测的行业案例 32816.6.1 滴滴出行的全链路压测 32816.6.2 美团全链路压测自动化 实践 32916.6.3 饿了么全链路压测平台 33116.7 本章小结 331第17章 云原生技术为性能带来的 机遇与变革 33317.1 云原生弹性的实现原理 33417.1.1 Kubernetes的资源类型 33417.1.2 Kubernetes的资源管理和 调度 33917.1.3 Kubernetes的资源动态 调整能力 34217.1.4 Kubernetes的资源碎片 问题 34517.2 云原生的可观测性 34617.2.1 可观测性与传统监控的 区别 34717.2.2 可观测性的维度 34917.3 云原生要解决的性能问题、 带来的挑战及应对 35317.3.1 云原生解决了哪些性能 问题 35317.3.2 云原生带来了哪些新的 挑战 35417.3.3 如何应对云原生带来的 挑战 35517.4 本章小结 356
展开全部
性能之道 分布式系统全栈性能优化 相关资料
现在市面上虽然不乏一些软件系统性能领域的经典之作,然而,大多数书对于分布式系统,尤其是互联网应用来说,内容还远远不够。《性能之道:分布式系统全栈性能优化》一书结合了系统性的方法论与丰富的具体实践案例,为软件性能优化提供了极具价值的参考。对于有追求的软件工程师来说,如果希望在实际工作中实现更高效的系统性能优化,这本书无疑是一本不可或缺的案头手册!——清华大学软件学院 长聘副教授 博士生导师 高跃——听云前总裁、某创业公司联合创始人 赵宇辰博士作为一名曾主导多个十亿级用户系统架构的技术负责人,我强烈建议大家在编程初期就对“性能”这一概念建立明确的认识。本书无疑是一本全面的入门宝典,其作者都是我非常熟悉的国内头部架构专家,他们皆拥有丰富的平台设计经验。我相信这本书能够为大家呈现一份深入而全面的性能设计与优化指南。——融云联合创始人 前 CTO 杨攀
性能之道 分布式系统全栈性能优化 作者简介
于君泽 某大型互联网公司前资深技术专家,在营销、支付、财务等业务中台方面有丰富的经验。畅销书《深入分布式缓存》 《程序员的三门课》联合作者,《持续架构实践》联合译者,公众号“技术琐话”主理人,独立咨询顾问。培训和咨询内容包括数字化转型、业务中台、持续架构实践、内建质量、异地团队搭建与发展等。曹洪伟 百度DuerOS原首席布道师,渡鸦原CTO,近30年产研经验,曾就职于美国高通等世界500强企业。创业项目有Mobile SFA、O2O应用商店和大学生发现式移动社交等。作为全栈工匠,对嵌入式系统runtime和应用框架有深刻理解,对驱动、OS、框架、App、前端、后台、分布式系统、数据库、大数据平台、AI应用等均有涉足,对系统高并发、稳定性、性能有体系性见解。目前任诺谛智能的首席架构师,从事AI应用赋能及智能硬件的研发工作,工作之余维护公众号及CSDN博客:wireless_com。李伟山 某知名人工智能公司前CTO,在数字化、人工智能、电商和金融等领域积累了丰富的平台架构设计经验,擅长组建产品研发团队、塑造部门文化、提升团队效能、打造学习型技术团队。具备丰富的项目管理经验,精通IPD和敏捷开发流程管理。于君泽 某大型互联网公司前资深技术专家,在营销、支付、财务等业务中台方面有丰富的经验。畅销书《深入分布式缓存》 《程序员的三门课》联合作者,《持续架构实践》联合译者,公众号“技术琐话”主理人,独立咨询顾问。培训和咨询内容包括数字化转型、业务中台、持续架构实践、内建质量、异地团队搭建与发展等。曹洪伟 百度DuerOS原首席布道师,渡鸦原CTO,近30年产研经验,曾就职于美国高通等世界500强企业。创业项目有Mobile SFA、O2O应用商店和大学生发现式移动社交等。作为全栈工匠,对嵌入式系统runtime和应用框架有深刻理解,对驱动、OS、框架、App、前端、后台、分布式系统、数据库、大数据平台、AI应用等均有涉足,对系统高并发、稳定性、性能有体系性见解。目前任诺谛智能的首席架构师,从事AI应用赋能及智能硬件的研发工作,工作之余维护公众号及CSDN博客:wireless_com。李伟山 某知名人工智能公司前CTO,在数字化、人工智能、电商和金融等领域积累了丰富的平台架构设计经验,擅长组建产品研发团队、塑造部门文化、提升团队效能、打造学习型技术团队。具备丰富的项目管理经验,精通IPD和敏捷开发流程管理。秦金卫(网名kimmking) Apache Dubbo、ShardingSphere PMC,某集团前高级总监,某商业银行研发中心前负责人。关注互联网、电商、金融、支付、区块链等领域,有近20年研发管理和架构经验。《微服务架构实战》 《JVM核心技术32讲》作者之一。近3年参与2家国有大行的分布式新核心项目,主导了分布式技术平台、微服务、单元化等的设计与实现。目前作为独立顾问从事金融行业数字化转型、分布式微服务架构、单元化架构、开源治理与信创、非功能体系建设等相关的咨询与培训工作。陈龙泉 某大型互联网公司技术专家,有十多年的大型互联网项目开发经验。喜欢对技术进行深度思考,在性能优化、线上故障排查、系统稳定性建设等领域有丰富的实践经验。