图书介绍

可伸缩服务架构 框架与中间件PDF|Epub|txt|kindle电子书版本网盘下载

可伸缩服务架构 框架与中间件
  • 李艳鹏,杨彪,李海亮,贾博岩,刘淏著 著
  • 出版社: 北京:电子工业出版社
  • ISBN:9787121335723
  • 出版时间:2018
  • 标注页数:560页
  • 文件大小:56MB
  • 文件页数:581页
  • 主题词:互联网络-网络服务器

PDF下载


点此进入-本书在线PDF格式电子书下载【推荐-云解压-方便快捷】直接下载PDF格式图书。移动端-PC端通用
种子下载[BT下载速度快]温馨提示:(请使用BT下载软件FDM进行下载)软件下载地址页直链下载[便捷但速度慢]  [在线试读本书]   [在线获取解压码]

下载说明

可伸缩服务架构 框架与中间件PDF格式电子书版下载

下载的文件为RAR压缩包。需要使用解压软件进行解压得到PDF格式图书。

建议使用BT下载工具Free Download Manager进行下载,简称FDM(免费,没有广告,支持多平台)。本站资源全部打包为BT种子。所以需要使用专业的BT下载软件进行下载。如BitComet qBittorrent uTorrent等BT下载工具。迅雷目前由于本站不是热门资源。不推荐使用!后期资源热门了。安装了迅雷也可以迅雷进行下载!

(文件页数 要大于 标注页数,上中下等多册电子书除外)

注意:本站所有压缩包均有解压码: 点击下载压缩包解压工具

图书目录

第1章 如何设计一款永不重复的高性能分布式发号器1

1.1可选方案及技术选型2

1.1.1为什么不用UUID2

1.1.2基于数据库的实现方案2

1.1.3 Snowflake开源项目3

1.1.4小结4

1.2分布式系统对发号器的基本需求4

1.3架构设计与核心要点6

1.3.1发布模式6

1.3.2 ID类型7

1.3.3数据结构7

1.3.4并发9

1.3.5机器ID的分配9

1.3.6时间同步10

1.3.7设计验证11

1.4如何根据设计实现多场景的发号器11

1.4.1项目结构12

1.4.2服务接口的定义14

1.4.3服务接口的实现15

1.4.4 ID元数据与长整型ID的互相转换22

1.4.5时间操作25

1.4.6机器ID的生成27

1.4.7小结32

1.5如何保证性能需求32

1.5.1嵌入发布模式的压测结果33

1.5.2中心服务器发布模式的压测结果33

1.5.3 REST发布模式(Netty实现)的压测结果33

1.5.4 REST发布模式(Spring Boot+Tomcat实现)的压测结果34

1.5.5性能测试总结34

1.6如何让用户快速使用35

1.6.1 REST发布模式的使用指南35

1.6.2服务化模式的使用指南38

1.6.3嵌入发布模式的使用指南41

1.7为用户提供API文档43

1.7.1 RESTful API文档44

1.7.2 Java API文档45

第2章 可灵活扩展的消息队列框架的设计与实现49

2.1背景介绍50

2.2项目目标50

2.2.1简单易用50

2.2.2高性能51

2.2.3高稳定性51

2.3架构难点51

2.3.1线程模型51

2.3.2异常处理53

2.3.3优雅关机53

2.4设计与实现54

2.4.1项目结构54

2.4.2项目包的规划55

2.4.3生产者的设计与实现57

2.4.4消费者的设计与实现58

2.4.5启动模块的设计与实现67

2.4.6消息处理器的体系结构76

2.4.7反射机制79

2.4.8模板项目的设计80

2.5使用指南82

2.5.1安装步骤82

2.5.2 Java API83

2.5.3与Spring环境集成84

2.5.4对服务源码进行注解85

2.6 API简介87

2.6.1 Producer API87

2.6.2 Consumer API88

2.6.3消息处理器88

2.6.4消息处理器定义的注解90

2.7消息处理机模板项目91

2.7.1快速开发向导91

2.7.2后台监控和管理92

第3章 轻量级的数据库分库分表架构与框架93

3.1什么是分库分表94

3.1.1使用数据库的三个阶段94

3.1.2在什么情况下需要分库分表95

3.1.3分库分表的典型实例96

3.2三种分而治之的解决方案97

3.2.1客户端分片97

3.2.2代理分片100

3.2.3支持事务的分布式数据库101

3.3分库分表的架构设计102

3.3.1整体的切分方式102

3.3.2水平切分方式的路由过程和分片维度106

3.3.3分片后的事务处理机制107

3.3.4读写分离119

3.3.5分库分表引起的问题119

3.4流行代理分片框架Mycat的初体验123

3.4.1安装Mycat123

3.4.2配置Mycat124

3.4.3配置数据库节点128

3.4.4数据迁移129

3.4.5 Mycat支持的分片规则129

3.5流行的客户端分片框架Sharding JDBC的初体验138

3.5.1 Sharding JDBC简介138

3.5.2 Sharding JDBC的功能139

3.5.3 Sharding JDBC的使用141

3.5.4 Sharding JDBC的使用限制152

3.6自研客户端分片框架dbsplit的设计、实现与使用153

3.6.1项目结构154

3.6.2包结构和执行流程155

3.6.3切片下标命名策略159

3.6.4 SQL解析和组装167

3.6.5 SQL实用程序168

3.6.6反射实用程序173

3.6.7分片规则的配置177

3.6.8支持分片的SplitJdbcTemplate和SimpleSplitJdbcTemplate接口API179

3.6.9 JdbcTemplate的扩展SimpleJdbcTemplate接口API184

3.6.10用于创建分库分表数据库的脚本工具187

3.6.11使用dbsplit的一个简单示例192

3.6.12使用dbsplit的线上真实示例展示199

第4章 缓存的本质和缓存使用的优秀实践201

4.1使用缓存的目的和问题202

4.2自相似,CPU的缓存和系统架构的缓存203

4.2.1 CPU缓存的架构及性能205

4.2.2 CPU缓存的运行过程分析206

4.2.3缓存行与伪共享208

4.2.4从CPU的体系架构到分布式的缓存架构218

4.3常用的分布式缓存解决方案221

4.3.1常用的分布式缓存的对比221

4.3.2 Redis初体验225

4.4分布式缓存的通用方法229

4.4.1缓存编程的具体方法229

4.4.2应用层访问缓存的模式233

4.4.3分布式缓存分片的三种模式235

4.4.4分布式缓存的迁移方案238

4.4.5缓存穿透、缓存并发和缓存雪崩244

4.4.6缓存对事务的支持246

4.5分布式缓存的设计与案例248

4.5.1缓存设计的核心要素248

4.5.2缓存设计的优秀实践250

4.5.3关于常见的缓存线上问题的案例253

4.6客户端缓存分片框架redic的设计与实现257

4.6.1什么时候需要redic258

4.6.2如何使用redic258

4.6.3更多的配置258

4.6.4项目结构260

4.6.5包结构261

4.6.6设计与实现的过程261

第5章 大数据利器之Elasticsearch268

5.1 Lucene简介269

5.1.1核心模块269

5.1.2核心术语270

5.1.3检索方式271

5.1.4分段存储273

5.1.5段合并策略275

5.1.6 Lucene相似度打分278

5.2 Elasticsearch简介286

5.2.1核心概念286

5.2.2 3C和脑裂289

5.2.3事务日志291

5.2.4在集群中写索引294

5.2.5集群中的查询流程295

5.3 Elasticsearch实战298

5.3.1 Elasticsearch的配置说明298

5.3.2常用的接口300

5.4性能调优305

5.4.1写优化305

5.4.2读优化308

5.4.3堆大小的设置313

5.4.4服务器配置的选择315

5.4.5硬盘的选择和设置316

5.4.6接入方式318

5.4.7角色隔离和脑裂319

第6章 全面揭秘分布式定时任务321

6.1什么是定时任务322

6.2分布式定时任务341

6.2.1定时任务的使用场景342

6.2.2传统定时任务存在的问题342

6.2.3分布式定时任务及其原理344

6.3开源分布式定时任务的用法347

6.3.1 Quartz的分布式模式347

6.3.2 TBSchedule356

6.3.3 Elastic-Job365

第7章 RPC服务的发展历程和对比分析377

7.1什么是RPC服务378

7.2 RPC服务的原理379

7.2.1 Sokcet套接字379

7.2.2 RPC的调用过程380

7.3在程序中使用RPC服务382

7.4 RPC服务的发展历程383

7.4.1第一代RPC:以ONC RPC和DCE RPC为代表的函数式RPC384

7.4.2第二代RPC:支持面对象的编程388

7.4.3第三代RPC: SOA和微服务398

7.4.4架构的演进402

7.5主流的RPC框架403

7.5.1 Thrift403

7.5.2 ZeroC Ice410

7.5.3 gRPC418

7.5.4 Dubbo430

第8章 Dubbo实战及源码分析436

8.1 Dubbo的四种配置方式437

8.1.1 XML配置437

8.1.2属性配置440

8.1.3 API配置441

8.1.4注解配置443

8.2服务的注册与发现446

8.2.1注册中心446

8.2.2服务暴露449

8.2.3引用服务451

8.3 Dubbo通信协议及序列化探讨455

8.3.1 Dubbo支持的协议455

8.3.2协议的配置方法456

8.3.3多协议暴露服务457

8.3.4 Dubbo协议的使用注意事项458

8.3.5 Dubbo协议的约束459

8.4 Dubbo中高效的I/O线程模型459

8.4.1对Dubbo中I/O模型的分析459

8.4.2 Dubbo中线程配置的相关参数460

8.4.3在Dubbo线程方面踩过的坑461

8.4.4对Dubbo中线程使用的建议462

8.5集群的容错机制与负载均衡462

8.5.1集群容错机制的原理462

8.5.2集群容错模式的配置方法464

8.5.3六种集群容错模式464

8.5.4集群的负载均衡465

8.6监控和运维实践467

8.6.1日志适配467

8.6.2监控管理后台467

8.6.3服务降级473

8.6.4优雅停机475

8.6.5灰度发布475

8.7 Dubbo项目线上案例解析477

8.7.1线上问题的通用解决方案477

8.7.2耗时服务耗尽了线程池的案例480

8.7.3容错重试机制引发服务雪崩的案例481

8.8深入剖析Dubbo源码及其实现483

8.8.1 Dubbo的总体架构设计483

8.8.2配置文件486

8.8.3 Dubbo的核心RPC488

8.8.4 Dubbo巧妙的URL总线设计491

8.8.5 Dubbo的扩展点加载SPI492

8.8.6 Dubbo服务暴露的过程493

8.8.7服务引用502

8.8.8集群容错和负载均衡503

8.8.9集群容错504

8.8.10负载均衡509

第9章 高性能网络中间件512

9.1 TCP/UDP的核心原理及本质探索513

9.1.1网络模型513

9.1.2 UDP、IP及其未解决的问题515

9.1.3 TCP详解519

9.1.4是否可以用UDP代替TCP527

9.1.5网络通信的不可靠性讨论529

9.2网络测试优秀实践530

9.2.1网络测试的关键点530

9.2.2那些必不可少的网络测试工具532

9.2.3典型的测试报告539

9.3高性能网络框架的设计与实现544

9.3.1对代理功能的测试及分析545

9.3.2网络中间件的使用介绍549

9.3.3内存和缓存的优化551

9.3.4快速解析流数据554

热门推荐