分布式係統常用技術及案例分析

分布式係統常用技術及案例分析 pdf epub mobi txt 电子书 下载 2025

柳偉衛
圖書標籤:
想要找书就要到 求知書站
立刻按 ctrl+D收藏本页
你会得到大惊喜!!
第1章 分布式系统基础知识 1
1.1 概述 2
1.1.1 什么是分布式系统 2
1.1.2 集中式系统VS.分布式系统 3
1.1.3 如何设计分布式系统 4
1.1.4 分布式系统所面临的挑战 5
1.2 线程 6
1.2.1 什么是线程 6
1.2.2 进程和线程 7
1.2.3 编程语言中的线程对象 8
1.2.4 SimpleThreads示例 11
1.3 通信 14
1.3.1 网络基础知识 14
1.3.2 网络I/O模型的演进 19
1.3.3 远程过程调用(RPC) 33
1.3.4 面向消息的通信 41
1.4 一致性 43
1.4.1 以数据为中心的一致性模型 44
1.4.2 以客户为中心的一致性 45
1.5 容错性 46
1.5.1 基本概念 46
1.5.2 故障分类 47
1.5.3 使用冗余来掩盖故障 48
1.5.4 分布式提交 48
1.6 CAP理论 52
1.6.1 什么是CAP理论 52
1.6.2 为什么说CAP只能三选二 53
1.6.3 CAP常见模型 55
1.6.4 CAP的意义 56
1.6.5 CAP最新发展 56
1.7 安全性 57
1.7.1 基本概念 58
1.7.2 加密算法 60
1.7.3 安全通道 63
1.7.4 访问控制 72
1.8 并发 74
1.8.1 线程与并发 75
1.8.2 并发与并行 75
1.8.3 并发带来的风险 76
1.8.4 同步(Synchronization) 78
1.8.5 原子访问(Atomic Access) 83
第2章 分布式系统架构体系 85
2.1 基于对象的体系结构 86
2.1.1 分布式对象 86
2.1.2 微软DCOM(COM+) 87
2.1.3 CORBA 88
2.1.4 Java RMI 90
2.2 面向服务的架构(SOA) 93
2.2.1 架构VS.标准 94
2.2.2 SOA的基本概念 95
2.2.3 基于Web Services的SOA 97
2.2.4 SOA的演变 112
2.3 REST风格的架构 112
2.3.1 什么是REST 112
2.3.2 REST有哪些特征 113
2.3.3 Java实现REST的例子 115
2.3.4 REST API最佳实践 125
2.4 微服务架构(MSA) 128
2.4.1 什么是MSA 128
2.4.2 MSA VS. SOA 130
2.4.3 何时采用MSA 134
2.4.4 如何构建微服务 135
2.5 容器技术 139
2.5.1 虚拟化技术 139
2.5.2 容器VS.虚拟机 139
2.5.3 基于容器的持续部署 142
2.6 Serverless架构 149
2.6.1 什么是Serverless架构 150
2.6.2 Serverless典型的应用场景 151
2.6.3 常见的Serverless框架 153
2.6.4 Serverless架构原则 155
2.6.5 例子:使用Serverless实现游戏全球同服 157
第3章 分布式消息服务 164
3.1 Apache ActiveMQ 165
3.1.1 Apache ActiveMQ简介 165
3.1.2 Apache ActiveMQ安装配置 166
3.1.3 例子:producer-consumer 173
3.1.4 例子:使用JMX来监控ActiveMQ 174
3.1.5 例子:使用Java实现producer-consumer 176
3.2 RabbitMQ 180
3.2.1 RabbitMQ简介 180
3.2.2 RabbitMQ安装配置 181
3.2.3 例子:Work Queues 185
3.2.4 例子:Publish/Subscribe 191
3.2.5 例子:Routing 195
3.2.6 例子:Topics 200
3.2.7 例子:RPC 204
3.3 RocketMQ 210
3.3.1 RocketMQ简介 210
3.3.2 RocketMQ安装配置 213
3.3.3 例子:使用Java实现producer-consumer 214
3.3.4 RocketMQ最佳实践 219
3.4 Apache Kafka 223
3.4.1 Apache Kafka简介 224
3.4.2 Apache Kafka的核心概念 225
3.4.3 Apache Kafka的使用场景 228
3.4.4 Apache Kafka的安装、配置、使用 229
第4章 分布式计算 236
4.1 MapReduce 237
4.1.1 MapReduce简介 237
4.1.2 MapReduce的编程模型 238
4.1.3 MapReduce的实现 243
4.1.4 MapReduce的使用技巧 248
4.2 Apache Hadoop 251
4.2.1 Apache Hadoop简介 252
4.2.2 Apache Hadoop核心组件 253
4.2.3 Apache Hadoop单节点上的安装配置 254
4.2.4 Apache Hadoop集群上的安装配置 258
4.2.5 例子:词频统计WordCount程序 267
4.3 Apache Spark 272
4.3.1 Apache Spark简介 272
4.3.2 Apache Spark与Apache Hadoop的关系 274
4.3.3 Apache Spark 2.0的新特性 275
4.3.4 Apache Spark的安装和使用 279
4.3.5 Apache Spark集群模式 280
4.4 Apache Mesos 282
4.4.1 Apache Mesos简介 283
4.4.2 Apache Mesos的安装、使用 285
4.4.3 设计高可用的Mesos framework 289
第5章 分布式存储 296
5.1 Bigtable 297
5.1.1 Bigtable简介 297
5.1.2 Bigtable的数据模型 298
5.1.3 Bigtable的实现 300
5.1.4 Bigtable的性能优化 304
5.2 Apache HBase 308
5.2.1 Apache HBase简介 308
5.2.2 Apache HBase基本概念 310
5.2.3 Apache HBase架构 318
5.2.4 Apache HBase的安装、配置、使用 332
5.2.5 本地伪分布式 336
5.2.6 完全分布式 338
5.3 Apache Cassandra 342
5.3.1 Apache Cassandra简介 342
5.3.2 Apache Cassandra的应用场景 345
5.3.3 Apache Cassandra的架构、数据模型 346
5.3.4 用于配置Apache Cassandra的核心组件 347
5.3.5 Apache Cassandra的安装、配置、使用 349
5.4 Memcached 352
5.4.1 Memcached简介 352
5.4.2 Memcached的架构 353
5.4.3 Memcached的安装、使用 355
5.4.4 Memcached客户端 358
5.5 Redis 370
5.5.1 Redis简介 370
5.5.2 Redis的下载、安装、使用 372
5.5.3 Redis的数据类型及抽象 372
5.6 MongoDB 392
5.6.1 MongoDB简介 392
5.6.2 MongoDB的安装、配置、运行 394
5.6.3 MongoDB核心概念 401
5.6.4 MongoDB的数据模型 406
5.6.5 示例:Java连接MongoDB 420
第6章 分布式监控 422
6.1 Nagios 423
6.1.1 Nagios简介 423
6.1.2 Nagios的安装、使用 424
6.1.3 Nagios监控 428
6.1.4 Nagios插件 446
6.2 Zabbix 448
6.2.1 Zabbix简介 449
6.2.2 安装Zabbix 451
6.2.3 Zabbix对于容器的支持 460
6.2.4 Zabbix基本概念 463
6.3 Consul 474
6.3.1 Consul简介 475
6.3.2 Consul架构 476
6.3.3 Consul的安装和使用 478
6.3.4 Consul agent 492
6.4 ZooKeeper 501
6.4.1 ZooKeeper简介 501
6.4.2 ZooKeeper的安装和使用 505
6.4.3 ZooKeeper内部工作原理 509
6.4.4 例子:ZooKeeper实现barrier和producer-consumer queue 514
第7章 分布式版本控制系统 522
7.1 Bazaar 523
7.1.1 Bazaar简介 523
7.1.2 Bazaar的核心概念 525
7.1.3 Bazaar的安装 526
7.1.4 Bazaar的使用 528
7.2 Mercurial 533
7.2.1 Mercurial简介 533
7.2.2 Mercurial的核心概念 533
7.2.3 Mercurial的安装 537
7.2.4 Mercurial的使用 538
7.3 Git 545
7.3.1 Git简介 545
7.3.2 Git的安装 546
7.3.3 Git的基础概念 548
7.3.4 Git的使用 551
第8章 RESTful API、微服务及容器技术 578
8.1 Jersey 579
8.1.1 Jersey简介 579
8.1.2 Jersey的模块和依赖 580
8.1.3 JAX-RS核心概念 583
8.1.4 例子:用SSE构建实时Web应用 595
8.2 Spring Boot 603
8.2.1 Spring Boot简介 603
8.2.2 Spring Boot的安装 604
8.2.3 Spring Boot的使用 610
8.2.4 Spring Boot的属性与配置 615
8.3 Docker 620
8.3.1 Docker简介 621
8.3.2 Docker的特性 621
8.3.3 Docker的概念和原理 622
8.3.4 Docker Engine的安装 628
8.3.5 Docker的使用 633
第9章 淘宝网:“双11”神话的缔造者 636
9.1 从LAMP到Java平台的转变 637
9.1.1 淘宝网的诞生与发展 637
9.1.2 “平民英雄”LAMP架构 638
9.1.3 数据库更改为Oracle 639
9.1.4 向Java平台转变 642
9.2 坚定不移地走“去IOE”的道路 643
9.2.1 使用小型机、EMC存储 644
9.2.2 考虑“去IOE” 644
9.2.3 如何去“I” 646
9.2.4 如何去“O” 649
9.2.5 如何去“E” 650
9.3 打造云计算,决战“双11” 653
9.3.1 “大淘宝”战略简介 653
9.3.2 成立阿里云,专注云计算 656
9.3.3 利用大数据优化物流 660
9.3.4 技术是决胜“双11”的关键 661
第10章 Twitter:实时信息传递的王者 664
10.1 缓存,让响应更快 665
10.1.1 Twitter的诞生 665
10.1.2 RoR的蛮荒时代 666
10.1.3 使用Memcached 667
10.2 服务拆分与治理 668
10.2.1 关系数据库不是万灵药 668
10.2.2 系统拆分,平台转换 670
10.2.3 Finagle 670
10.3 抗击流量的洪流 672
10.3.1 业务的重新设计 673
10.3.2 Storm处理实时的大数据 675
10.3.3 从Storm到Heron 676
参考文献 680
· · · · · · (收起)

具体描述

《分布式係統常用技術及案例分析》全麵介紹在設計分布式係統時所要考慮的技術方案,內容豐富、案例新穎,相關理論與技術實踐較為前瞻。《分布式係統常用技術及案例分析》不僅僅介紹瞭分布式係統的原理、基礎理論,同時還引入瞭大量市麵上常用的最新分布式係統技術,不僅告訴讀者怎麼用,同時也分析瞭為什麼這麼用,並闡述瞭這些技術的優缺點。希望《分布式係統常用技術及案例分析》可以成為讀者案頭的工具書,供讀者隨手翻閱。

《分布式係統常用技術及案例分析》分為三大部分,即分布式係統基礎理論、分布式係統常用技術以及經典的分布式係統案例分析。第一部分主要介紹分布式係統基礎理論知識,總結一些在設計分布式係統時需要考慮的範式、知識點以及可能會麵臨的問題,其中包括綫程、通信、一緻性、容錯性、CAP理論、安全性和並發等相關內容;同時講述分布式係統的常見架構體係,其中也包括最近比較火的RESTful風格架構、微服務、容器技術等。第二部分主要列舉瞭在分布式係統應用中經常用到的一些主流技術,並介紹這些技術的作用和用法;這些技術涵蓋瞭分布式消息服務、分布式計算、分布式存儲、分布式監控係統、分布式版本控製、RESTful、微服務、容器等領域的內容。第三部分選取瞭以淘寶網和Twitter為代錶的國內外知名互聯網企業的大型分布式係統案例,分析其架構設計以及演變過程;這部分相當於是對第二部分零散的技術點做一個“串燒”,讓讀者可以結閤技術的理論,看到實戰的效果。

《分布式係統常用技術及案例分析》主要麵嚮的讀者是對分布式係統感興趣的計算機專業的學生、軟件工程師、係統架構師等。

用户评价

评分

##本书非常适合初学者,特别是刚刚接触分布式系统的我,在本书里面,对于之前工作中有用到radis的我,但是具体的部署操作都不懂,看了书以后,顿时豁然开朗;虽然本书大多都是安装部署甚至是简单的介绍,但是非常实用,非常适合我,谢谢作者的share;也拜读过作者的blog,佩服作者多年来一如既往的坚持,点赞,好好加油,多为我们分享工作中的经验!

评分

评分

##你这水平也出书?

评分

全是安装部署的东西,到处抄,不知道你们这种给五颗星的是怎么想的

评分

##受教了。对于像我这样的初级人员来说,这本书可以让我了解当今世界主流的分布式系统的原理,以及常用的技术。难能可贵的是,这本书不但是讲述理论,还会给你呈现一个示例,这个示例可能是真实项目的一个原型。支持作者!

评分

评分

评分

##本书的内容比较全面,涵盖分布式系统基础理论、常用技术以及经典的案例分析。全书篇幅较多,对分布式系统中的线程、通信、一致性、容错性、CAP理论、安全性、并发、RESTful风格架构、微服务、容器技术,以及分布式消息服务、分布式计算、分布式存储、分布式监控系统、分布式版本控制、RESTful、微服务等相关技术和知识点都作了详细的讲解,并辅以淘宝网和Twitter为代表的国内外知名互联网企业的大型分布式系统为案例,分析其架构设计以及演变过程,做到了理论和实践相结合。

评分

##随便翻了下Mafka部分就发现关于Consumer/ConsumerGroup的基本错误。Redis的部分基本都是概念。案例分析选淘宝双十一,有种过于熟悉的感觉。作者像是为了追求大而全,匆忙上架。

本站所有內容均為互聯網搜索引擎提供的公開搜索信息,本站不存儲任何數據與內容,任何內容與數據均與本站無關,如有需要請聯繫相關搜索引擎包括但不限於百度google,bing,sogou

© 2025 tushu.tinynews.org All Rights Reserved. 求知書站 版权所有