大型网站技术架构

出版社:电子工业出版社
出版日期:2013-9-1
ISBN:9787121212000
作者:李智慧
页数:218页

内容概要

李智慧
曾在阿里巴巴担任技术专家,参与阿里巴巴基础技术平台开发和www.alibaba.com架构设计。
目前就职英特尔亚太研发中心从事云计算与大数据方面的研发工作。

书籍目录

第1篇  概述
1 大型网站架构演化
2
1.1 大型网站软件系统的特点
3
1.2 大型网站架构演化发展历程
4
1.2.1 初始阶段的网站架构
4
1.2.2 应用服务和数据服务分离
4
1.2.3 使用缓存改善网站性能
5
1.2.4 使用应用服务器集群改善网站的并发处理能力
6
1.2.5 数据库读写分离
7
1.2.6 使用反向代理和CDN加速网站响应
8
1.2.7 使用分布式文件系统和分布式数据库系统
9
1.2.8 使用NoSQL和搜索引擎
10
1.2.9 业务拆分
11
1.2.10 分布式服务
11
1.3 大型网站架构演化的价值观
13
1.3.1 大型网站架构技术的核心价值是随网站所需灵活应对
13
1.3.2 驱动大型网站技术发展的主要力量是网站的业务发展
13
1.4 网站架构设计误区
14
1.4.1 一味追随大公司的解决方案
14
1.4.2 为了技术而技术
14
1.4.3 企图用技术解决所有问题
14
1.5 小结
15
2 大型网站架构模式
16
2.1 网站架构模式
16
2.1.1 分层
17
2.1.2 分割
18
2.1.3 分布式
18
2.1.4 集群
19
2.1.5 缓存
20
2.1.6 异步
20
2.1.7 冗余
21
2.1.8 自动化
22
2.1.9 安全
23
2.2 架构模式在新浪微博的应用
23
2.3 小结
25
3 大型网站核心架构要素
26
3.1 性能
27
3.2 可用性
28
3.3 伸缩性
29
3.4 扩展性
30
3.5 安全性
30
3.6 小结
31
第2篇 架构
4 瞬时响应:网站的高性能架构
34
4.1 网站性能测试
35
4.1.1 不同视角下的网站性能
35
4.1.2 性能测试指标
36
4.1.3 性能测试方法
39
4.1.4 性能测试报告
41
4.1.5 性能优化策略
41
4.2 Web前端性能优化
42
4.2.1 浏览器访问优化
42
4.2.2 CDN加速
43
4.2.3 反向代理
44
4.3 应用服务器性能优化
45
4.3.1 分布式缓存
45
4.3.2 异步操作
52
4.3.3 使用集群
53
4.3.4 代码优化
54
4.4 存储性能优化
58
4.4.1 机械硬盘vs. 固态硬盘
58
4.4.2 B+树vs. LSM树
59
4.4.3 RAID vs. HDFS
61
4.5 小结
64
5 万无一失:网站的高可用架构
66
5.1 网站可用性的度量与考核
67
5.1.1 网站可用性度量
67
5.1.2 网站可用性考核
67
5.2 高可用的网站架构
69
5.3 高可用的应用
71
5.3.1 通过负载均衡进行无状态服务的失效转移
72
5.3.2 应用服务器集群的Session管理
73
5.4 高可用的服务
76
5.5 高可用的数据
78
5.5.1 CAP原理
79
5.5.2 数据备份
82
5.5.3 失效转移
84
5.6 高可用网站的软件质量保证
85
5.6.1 网站发布
85
5.6.2 自动化测试
86
5.6.3 预发布验证
87
5.6.4 代码控制
88
5.6.5 自动化发布
90
5.6.6 灰度发布
91
5.7 网站运行监控
91
5.7.1 监控数据采集
92
5.7.2 监控管理
93
5.8 小结
94
6 永无止境:网站的伸缩性架构
95
6.1 网站架构的伸缩性设计
97
6.1.1 不同功能进行物理分离实现伸缩
97
6.1.2 单一功能通过集群规模实现伸缩
98
6.2 应用服务器集群的伸缩性设计
99
6.2.1 HTTP重定向负载均衡
100
6.2.2 DNS域名解析负载均衡
101
6.2.3 反向代理负载均衡
102
6.2.4 IP负载均衡
103
6.2.5 数据链路层负载均衡
104
6.2.6 负载均衡算法
105
6.3 分布式缓存集群的伸缩性设计
106
6.3.1 Memcached分布式缓存集群的访问模型
107
6.3.2 Memcached分布式缓存集群的伸缩性挑战
107
6.3.3 分布式缓存的一致性Hash算法
109
6.4 数据存储服务器集群的伸缩性设计
112
6.4.1 关系数据库集群的伸缩性设计
113
6.4.2 NoSQL数据库的伸缩性设计
117
6.5 小结
119
7 随需应变:网站的可扩展架构
121
7.1 构建可扩展的网站架构
122
7.2 利用分布式消息队列降低系统耦合性
123
7.2.1 事件驱动架构
123
7.2.2 分布式消息队列
124
7.3 利用分布式服务打造可复用的业务平台
126
7.3.1 Web Service与企业级分布式服务
128
7.3.2 大型网站分布式服务的需求与特点
129
7.3.3 分布式服务框架设计
130
7.4 可扩展的数据结构
131
7.5 利用开放平台建设网站生态圈
132
7.6 小结
134
8 固若金汤:网站的安全架构
135
8.1 道高一尺魔高一丈的网站应用攻击与防御
136
8.1.1 XSS攻击
136
8.1.2 注入攻击
138
8.1.3 CSRF攻击
139
8.1.4 其他攻击和漏洞
140
8.1.5 Web应用防火墙
141
8.1.6 网站安全漏洞扫描
142
8.2 信息加密技术及密钥安全管理
142
8.2.1 单向散列加密
143
8.2.2 对称加密
144
8.2.3 非对称加密
144
8.2.4 密钥安全管理
145
8.3 信息过滤与反垃圾
146
8.3.1 文本匹配
147
8.3.2 分类算法
148
8.3.3 黑名单
149
8.4 电子商务风险控制
150
8.4.1 风险
151
8.4.2 风控
151
8.5 小结
153
第3篇 案例
9 淘宝网的架构演化案例分析
156
9.1 淘宝网的业务发展历程
157
9.2 淘宝网技术架构演化
158
9.3 小结
162
10 维基百科的高性能架构设计分析
163
10.1 Wikipedia网站整体架构
163
10.2 Wikipedia性能优化策略
165
10.2.1 Wikipedia前端性能优化
165
10.2.2 Wikipedia服务端性能优化
166
10.2.3 Wikipedia后端性能优化
167
11 海量分布式存储系统Doris的高可用架构设计分析
169
11.1 分布式存储系统的高可用架构
170
11.2 不同故障情况下的高可用解决方案
171
11.2.1 分布式存储系统的故障分类
172
11.2.2 正常情况下系统访问结构
172
11.2.3 瞬时故障的高可用解决方案
173
11.2.4 临时故障的高可用解决方案
174
11.2.5 永久故障的高可用解决方案
175
12 网购秒杀系统架构设计案例分析
176
12.1 秒杀活动的技术挑战
177
12.2 秒杀系统的应对策略
177
12.3 秒杀系统架构设计
178
12.4 小结
182
13 大型网站典型故障案例分析
183
13.1 写日志也会引发故障
184
13.2 高并发访问数据库引发的故障
184
13.3 高并发情况下锁引发的故障
185
13.4 缓存引发的故障
185
13.5 应用启动不同步引发的故障
186
13.6 大文件读写独占磁盘引发的故障
186
13.7 滥用生产环境引发的故障
187
13.8 不规范的流程引发的故障
187
13.9 不好的编程习惯引发的故障
188
13.10 小结
188
第4篇 架构师
14 架构师领导艺术
190
14.1 关注人而不是产品
191
14.2 发掘人的优秀
191
14.3 共享美好蓝图
192
14.4 共同参与架构
193
14.5 学会妥协
194
14.6 成就他人
194
15 网站架构师职场攻略
196
15.1 发现问题,寻找突破
197
15.2 提出问题,寻求支持
199
15.3 解决问题,达成绩效
201
16 漫话网站架构师
203
16.1 按作用划分架构师
203
16.2 按效果划分架构师
204
16.3 按职责角色划分架构师
205
16.4 按关注层次划分架构师
205
16.5 按口碑划分架构师
206
16.6 非主流方式划分架构师
207
附录A 大型网站架构技术一览
208
附录B Web开发技术发展历程
215
后记
218

作者简介

《大型网站技术架构:核心原理与案例分析》通过梳理大型网站技术发展历程,剖析大型网站技术架构模式,深入讲述大型互联网架构设计的核心原理,并通过一组典型网站技术架构设计案例,为读者呈现一幅包括技术选型、架构设计、性能优化、Web 安全、系统发布、运维监控等在内的大型网站开发全景视图。
《大型网站技术架构:核心原理与案例分析》不仅适用于指导网站工程师、架构师进行网站技术架构设计,也可用于指导产品经理、项目经理、测试运维人员等了解网站技术架构的基础概念;还可供包括企业系统开发人员在内的各类软件开发从业人员借鉴,了解大型网站的解决方案和开发理念。


 大型网站技术架构下载 精选章节试读 更多精彩书评



发布书评

 
 


精彩书评 (总计28条)

  •     这本书对大型网站的演化发展的过程,做了一个比价详尽的概述,虽然比较宽泛,但对于对架构敢兴趣的同学,非常值得一读,网站的演化过程,架构模式,性能,高可用性,伸缩性,扩展性,安全性等等都有涉及,看完这本书,让我对“架构”这两个字,有了更进一步的了解了,现在公司项目的架构很有问题,在加上本人技术菜鸟级别,还是要多学习学习~~~
  •     两个视角1.技术是因业务存在而存在网站业务发展的各个阶段造就了技术支撑体系的不断发展演化。2.大型网站的5个核心要素性能、可靠性、可用性、可扩展、安全性围绕着这五点有各个篇章讲解各种应对解决方案。后续的两块1.典型系统的案例架构分析2.写给架构师的工作经验手册和建议读此书的感觉1.结构思路很清晰,可读性很高,很接地气。2.这本书涉及网站的方方面面,见识到很多可用的思路和解决方案
  •     评价一本书需要从这本书不同目标受众的视角,对于资深架构师来说,这本书可能没有什么;对于初中级WEB运维和开发工程师,这本书可以让你节省很多摸索的时间,少走很多弯路;对于项目经理和产品经理,这本书是很好的互联网技术“科普”读物。

精彩短评 (总计50条)

  •     如果你是个新手 那可以用这本书作为入门:如果你有一定的编程经验 或者经历过一个网站从后到前的开发历程了 那这本书只能算是泛泛而谈 罗列些条目而已。
  •     一部介绍大型网站架构技术的手册,了解主流技术和手段,可以作为入门参考
  •     #读书#最近把大型架构的书看完,虽然看得蛮快的,但是正在受用的不多。整本书讲得很多都是概念性的东西,感觉就是一本大型网站相关名词介绍,然后加一些实例。而后面几章关于架构师角色和工作成长也是如此。整体来说,此书可以作为一本工具书,具体的实施方案,各种细节作者并为写出来。有一种感觉就是作者不够真诚,感觉他接触过很多,但是都是一笔带过,没有具体的细节。到最后没有一个真正的实例,从无到有开始利用他构架出来的理论来做一个大型网站的设计。虽然他说,大型网站不是说一开始就有的,是逐步演进的。然而却木有实例一步一步构建出来。
  •     主要提供思路和方向,具体实施细节还要自己钻研啊
  •     虽然有点年头了,但是对完全不同网站架构的新手来说,还是把概念讲的很明白,书的整体逻辑也很清晰,赞。
  •     讲的比较泛,能大概了解大型网站的演进过程和相关技术
  •     扫盲书,地铁路上和厕所读物
  •     技术性太低,都是一些理论知识,如果架构大系统的大家都知道要服务器越多越好的,可如果处理好多台服务器间性能合理,服务器分类并没有实际的说明到。
  •     菜鸟当科普了
  •     网站架构_科普!
  •     科普书。
  •     大而全,适合入门
  •     简单易懂
  •     内容3星,三观加1星
  •     入门的架构书籍,大型网站设计的科普读物。这本书讲了很多关于网站设计和架构的知识,极大开拓了我的视野
  •     面试的嘴炮神器!嘴炮架构师速成秘籍!
  •     罗列了一个架构师应该知道的一切,对于新手入门来说非常有用,对于架构师查漏补缺应该也不错。总之,书里内容很简单,随便读读也没有多大负担,开卷有益说的就是这种书吧
  •     技术科普类书籍,没有深度,每个章节都是一个技术点,要想深入了解还是要另外找资料。适合新兵入门全面了解,然后再确定自己的发展方向。老兵也可以迅速看看,然后把目录和附录贴在办公桌前,工作的时候提醒自己别忘记什么。
  •     对于一个想了解架构所设计的方方面面的人而言,本书做了很好的介绍,不会觉得太过专业晦涩而放弃。相反,花一点时间,就可以对网站架构有一个全面的了解,虽然不一定有机会从事,但是对于我们在对于自己技术的定位以及未来的发展有一定的指导意见。
  •     还行吧,虽然写的不深入,但也算有条理,适合入门
  •     给服务端小白涨姿势还是很够了。
  •     用来了解大型网站的技术发展路线还是挺合适的,不含有可供实操的内容,最后一章讲架构师这个角色的定位等比较有趣的内容,还挺不错的
  •     这本书不会探讨很深的技术点,但很全面包括了大型交互式网站的方方面面,提供很多值得借鉴的解决方案。
  •     网站架构入门科普,简单易懂完整形成了体系。总结归纳性的书,页数很少,两三天就看完了,内容当然泛泛而谈了
  •     架构入门
  •      虽然都是泛泛而谈但是用来作为架构过程中需要考虑的清单索引还是够用的
  •     很耐读,知识点都涵盖到了,可以作为一本大型互联网企业技术索引手册
  •     所有互联网产品经理都应该读一读再去和技术讨论
  •     介绍了主流网站一般架构的设计,适合想了解大型网站架构设计的读者。当然如果要深入具体的实施细节,基本上每一章都可以独立成书了,但由于技术更新得快,这方面的知识可以从互联网上获取。
  •     比较通俗易懂,对于网站架构的演化,涉及方面均有介绍。可靠性,伸缩性,扩展性方面撰述的较多。后半部分太过于简单,书中有些案例可简单翻翻。
  •     虽然属于程序员高阶知识,但是作者用简单通俗的语言表达出来。内容不多,花个两三个小时就能读完,很适合架构入门。
  •     一本正经的科普了网站架构,捡起了不少零碎的概念和原理,还是那句,知易行难。推荐给对网站开发,分布式系统,大数据感兴趣的同学。
  •     也就是读读来面试了,没啥大作用
  •     新东西不多
  •     理清了我对网站技术演变的看法,如果从技术角度考虑,知道大概在哪个阶段需要做点什么事情。
  •     能对常见的网站架构及其技术有个简单了解。
  •     技术不是凭空想象出来的,技术是不断遇见问题,不断解决问题的过程中总结出来的。最后附上本书的结尾词:互联网正在并将继续改变这个世界,一切才刚刚开始,你我正生逢其时!
  •     值得借鉴
  •     比较范着讲的大型网站技术架构方式,分多个方面讲了大型网站可以才用的架构,也举了一些作者自己了解的大型公司案例,简明易懂,适合想了解架构的人和小型互联网公司的技术人员看看
  •     入门看看还行
  •     好的科普书
  •     对主流互联网技术的一个科普吧,没有深入的技术知识点,从事相关工作的都能看明白~
  •     作为互联网网站的架构演化和设计的入门读物。作者写的比较浅显易懂。
  •     特别棒 长见识 想去做类似的工作
  •     技术原理,科普读物,拓宽视野
  •     Weber 必读,作为一个前端可以把后端的一些架构,解耦思想用到前端里面来,代码不一样,思想是一样了
  •     作者对于网站的架构分析很是高屋建瓴,各方面的内容也说得很恰当,适合有一定工作经验的人看
  •     入门挺好
  •     对形成大体认识很有帮助
  •     对后台架构感兴趣的话,入门还行
 

外国儿童文学,篆刻,百科,生物科学,科普,初中通用,育儿亲子,美容护肤PDF图书下载,。 零度图书网 

零度图书网 @ 2024