分布式中间件技术实战:Java版:Java version 版权信息
- 出版社:机械工业出版社
- 出版时间:2020-01-01
- ISBN:9787111641513
- 条形码:9787111641513 ; 978-7-111-64151-3
分布式中间件技术实战:Java版:Java version 本书特色
《分布式中间件技术实战(Java版)》站在初学者的角度,介绍了几款比较流行的分布式中间件,带领读者从零开始一步一个脚印地学习Java企业级应用开发。书中在讲解必要的理论知识和应用场景后都给出了实际项目案例,可以提高读者的开发水平和项目实战能力。
《分布式中间件技术实战(Java版)》共10章,分为3篇。第1篇开发工具准备,介绍了分布式系统架构的相关知识要点,包括其功能、作用及演进历程,并由此引出了分布式中间件的相关介绍。第2篇开发实战,全面介绍了目前在实际开发中应用比较广泛的几款Java中间件,包括缓存中间件Redis、消息中间件RabbitMQ、统一协调管理中间件ZooKeeper和综合中间件Redisson等,重点介绍了这几款中间件的基本概念、典型应用场景及相应的功能组件等。第3篇总结,对相关内容做了重点回顾与总结。值得一提的是,《分布式中间件技术实战(Java版)》在介绍几款中间件的理论知识时,还以Spring Boot微服务框架作为奠基,整合了相关中间件之间的依赖,并结合作者的实际项目经验进行了代码实战。
《分布式中间件技术实战(Java版)》特别适合中间件实践经验为零的开发者阅读;对于有一定Java应用开发经验的工程师而言,通过阅读《分布式中间件技术实战(Java版)》可以了解中间件在构建企业级应用过程中所提供的思路和解决方案;IT培训机构的学员,也可以通过《分布式中间件技术实战(Java版)》系统地学习中间件技术。
分布式中间件技术实战:Java版:Java version 内容简介
CSDN博客专家、51CTO学院/CSDN学院/网易云课堂知名讲师力作
结合近30个案例及88幅流程图,全面介绍分布式中间件的原理及应用
容易上手:手把手带领读者从零开始逐步学习常用的分布式中间件技术
图文并茂:结合88幅流程图进行讲解,可以加深读者对中间件原理的理解
注重实战:结合大量简洁、优雅的高质量代码实例进行开发实践,提高读者的开发水平
案例丰富:结合近30个实际项目中的典型业务场景案例进行讲解,让读者身临其境
分布式系统架构的演进历程是怎么样的?
有哪些常用的典型分布式中间件?其作用又是什么?
Redis的作用及其典型应用场景有哪些?
如何基于微服务项目使用Redis?
如何设计一款可扛住高并发的红包系统?
RabbitMQ的作用以及有哪些典型的应用场景?
如何基于微服务使用RabbitMQ?
什么是延迟/死信队列以及有哪些应用场景?
如何基于Spring Boot项目实战死信队列?
什么是分布式锁以及有哪些实现方式?
如何基于微服务项目使用Redisson?
如何基于微服务项目使用ZooKeeper?
如何实现模仿微博高并发量的点赞、评论等常规操作?CSDN博客专家、51CTO学院/CSDN学院/网易云课堂知名讲师力作
结合近30个案例及88幅流程图,全面介绍分布式中间件的原理及应用
容易上手:手把手带领读者从零开始逐步学习常用的分布式中间件技术
图文并茂:结合88幅流程图进行讲解,可以加深读者对中间件原理的理解
注重实战:结合大量简洁、优雅的高质量代码实例进行开发实践,提高读者的开发水平
案例丰富:结合近30个实际项目中的典型业务场景案例进行讲解,让读者身临其境
分布式系统架构的演进历程是怎么样的?
有哪些常用的典型分布式中间件?其作用又是什么?
Redis的作用及其典型应用场景有哪些?
如何基于微服务项目使用Redis?
如何设计一款可扛住高并发的红包系统?
RabbitMQ的作用以及有哪些典型的应用场景?
如何基于微服务使用RabbitMQ?
什么是延迟/死信队列以及有哪些应用场景?
如何基于Spring Boot项目实战死信队列?
什么是分布式锁以及有哪些实现方式?
如何基于微服务项目使用Redisson?
如何基于微服务项目使用ZooKeeper?
如何实现模仿微博高并发量的点赞、评论等常规操作?
如何基于Spring Boot整合中间件实现业务功能?
… …
通过阅读《分布式中间件技术实战(Java版)》,你将了解这些问题的确切答案,甚至你都可以举一反三,自主学习掌握更多的技术进行实现。
超值赠送:
完整的源代码(需要下载)
相关开发工具(需要下载)
分布式中间件技术实战:Java版:Java version 目录
第1篇 开发工具准备
第1章 走进分布式中间件 2
1.1 分布式系统概述 2
1.1.1 白话分布式系统 3
1.1.2 分布式系统发展历程 3
1.1.3 分布式系统特性 6
1.1.4 分布式系统常见问题 7
1.2 分布式中间件概述 7
1.2.1 白话分布式中间件 7
1.2.2 常见中间件介绍 8
1.3 本书核心知识要点 9
1.4 本书实战要求与建议 10
第2章 搭建微服务项目 11
2.1 Spring Boot概述 11
2.1.1 什么是Spring Boot 11
2.1.2 Spring Boot的优势 12
2.1.3 Spring Boot的几大特性 13
2.2 搭建规范与搭建流程 13
2.2.1 Spring Boot项目搭建规范 14
2.2.2 Spring Boot项目搭建流程 14
2.2.3 写个Hello World吧 26
2.3 总结 28
第2篇 开发实战
第3章 缓存中间件Redis 30
3.1 Redis概述与典型应用场景介绍 30
3.2 Redis的使用 32
3.2.1 快速安装Redis 32
3.2.2 在Windows环境下使用Redis 34
3.2.3 Spring Boot项目整合Redis 37
3.2.4 Redis自定义注入Bean组件配置 38
3.2.5 RedisTemplate实战 39
3.2.6 StringRedisTemplate实战 43
3.3 Redis常见数据结构实战 45
3.3.1 字符串 45
3.3.2 列表 47
3.3.3 集合 48
3.3.4 有序集合 50
3.3.5 哈希Hash存储 52
3.3.6 Key失效与判断是否存在 54
3.4 Redis实战场景之缓存穿透 56
3.4.1 什么是缓存穿透 57
3.4.2 缓存穿透的解决方案 58
3.4.3 实战过程 58
3.4.4 其他典型问题介绍 65
3.5 总结 66
第4章 Redis典型应用场景实战之抢红包系统 67
4.1 整体业务流程介绍 67
4.1.1 抢红包系统业务流程 68
4.1.2 业务流程分析 68
4.1.3 业务模块划分 70
4.2 数据库表设计与环境搭建 71
4.2.1 数据库表设计 71
4.2.2 开发环境搭建 73
4.2.3 开发流程介绍 83
4.3 “红包金额”随机生成算法实战 85
4.3.1 随机数算法 86
4.3.2 红包随机金额生成算法要求 86
4.3.3 二倍均值法简介 87
4.3.4 红包随机金额生成算法实战 88
4.3.5 红包随机金额生成算法自测 90
4.4 “发红包”模块实战 91
4.4.1 业务模块分析 92
4.4.2 整体流程实战 93
4.4.3 业务模块自测 99
4.5 “抢红包”模块实战 101
4.5.1 业务模块分析 101
4.5.2 整体流程 102
4.5.3 业务模块自测 105
4.5.4 总结 109
4.6 Jmeter压力测试高并发抢红包 110
4.7 问题分析与优化方案 116
4.7.1 问题分析 117
4.7.2 优化方案介绍 118
4.7.3 优化方案之Redis分布式锁实战 118
4.7.4 不足之处 122
4.8 总结 122
第5章 消息中间件RabbitMQ 124
5.1 RabbitMQ简介 124
5.1.1 认识RabbitMQ 125
5.1.2 典型应用场景介绍 126
5.1.3 RabbitMQ后端控制台介绍 132
5.1.4 基于Spring的事件驱动模型实战 133
5.2 Spring Boot项目整合RabbitMQ 137
5.2.1 RabbitMQ相关词汇介绍 138
5.2.2 Spring Boot项目整合RabbitMQ 139
5.2.3 自定义注入配置Bean相关组件 140
5.2.4 RabbitMQ发送、接收消息实战 142
5.2.5 其他发送接收消息方式实战 147
5.3 RabbitMQ多种消息模型实战 152
5.3.1 基于FanoutExchange的消息模型实战 152
5.3.2 基于DirectExchange的消息模型实战 160
5.3.3 基于TopicExchange的消息模型实战 165
5.4 RabbitMQ确认消费机制 171
5.4.1 消息高可用和确认消费 172
5.4.2 常见的确认消费模式介绍 174
5.4.3 基于自动确认消费模式实战 176
5.4.4 基于手动确认消费模式实战 182
5.5 典型应用场景实战之用户登录成功写日志 188
5.5.1 整体业务流程介绍与分析 188
5.5.2 数据库表设计 189
5.5.3 开发环境搭建 197
5.5.4 基于TopicExchange构建日志消息模型 200
5.5.5 异步发送接收登录日志消息实战 201
5.5.6 整体业务模块自测实战 205
5.6 总结 208
第6章 死信队列/延迟队列实战 209
6.1 死信队列概述 209
6.1.1 死信队列简介与作用 209
6.1.2 典型应用场景介绍 212
6.2 RabbitMQ死信队列实战 213
6.2.1 死信队列专有词汇介绍 214
6.2.2 死信队列消息模型实战 215
6.2.3 死信队列延迟发送消息实战 221
6.3 典型应用场景实战之商城平台订单支付超时 226
6.3.1 整体业务场景介绍 227
6.3.2 整体业务流程分析 228
6.3.3 数据库设计 229
6.3.4 构建RabbitMQ死信队列消息模型 236
6.3.5 Controller层开发用户下单及订单失效功能 240
6.3.6 “用户下单支付超时”延迟发送接收实战 246
6.3.7 “用户下单支付超时”整体功能自测 250
6.4 总结 254
第7章 分布式锁实战 256
7.1 分布式锁概述 256
7.1.1 锁机制 257
7.1.2 分布式锁登场 263
7.1.3 典型应用场景介绍 265
7.1.4 小结 268
7.2 基于数据库实现分布式锁 268
7.2.1 乐观锁简介 268
7.2.2 乐观锁实战 269
7.2.3 Jmeter高并发测试乐观锁 280
7.2.4 悲观锁简介 286
7.2.5 悲观锁实战 288
7.2.6 Jmeter高并发测试悲观锁 290
7.2.7 小结 291
7.3 基于Redis实现分布式锁 292
7.3.1 Redis温故而知新 292
7.3.2 分布式锁的实现流程与原理分析 294
7.3.3 基于Redis实战实现分布式锁 295
7.3.4 Jmeter高并发测试 303
7.3.5 小结 307
7.4 基于ZooKeeper实现分布式锁 308
7.4.1 ZooKeeper简介与作用 308
7.4.2 分布式锁的实现流程与原理分析 310
7.4.3 Spring Boot整合ZooKeeper 312
7.4.4 基于ZooKeeper实现分布式锁 315
7.4.5 Jmeter高并发测试 317
7.4.6 小结 319
7.5 典型应用场景之书籍抢购模块设计与实战 319
7.5.1 整体业务流程介绍与分析 319
7.5.2 数据库表设计与用例设计 321
7.5.3 书籍抢购核心业务逻辑开发实战 324
7.5.4 Jmeter重现“库存超卖”的问题 328
7.5.5 采用分布式锁解决问题 330
7.5.6 小结 334
7.6 总结 334
第8章 综合中间件Redisson 336
8.1 Redisson概述 336
8.1.1 Redisson简介与作用 337
8.1.2 Redisson的功能特性 339
8.1.3 典型应用场景之布隆过滤器与主题 340
8.1.4 典型应用场景之延迟队列与分布式锁 345
8.1.5 Spring Boot整合Redisson 348
8.2 Redisson常见功能组件实战 352
8.2.1 布隆过滤器 352
8.2.2 发布-订阅式主题 355
8.2.3 数据结构之映射Map 361
8.2.4 数据结构之集合Set 366
8.2.5 队列Queue实战 370
8.2.6 延迟队列Delayed Queue实战1 374
8.2.7 延迟队列Delayed Queue实战2 381
8.3 分布式锁实战 385
8.3.1 重温分布式锁 385
8.3.2 分布式锁之一次性锁实战 387
8.3.3 分布式锁之可重入锁实战 392
8.4 总结 398
第9章 Redisson典型应用场景实战之高性能点赞 399
9.1 整体业务流程介绍与分析 399
9.1.1 业务背景介绍 400
9.1.2 业务流程介绍与分析 401
9.1.3 业务模块划分与数据库设计 404
9.2 “点赞与取消点赞”操作模块实战 409
9.2.1 “点赞与取消点赞”业务流程分析 409
9.2.2 Controller层接收请求信息 412
9.2.3 Service层插入、更新并缓存记录信息 415
9.2.4 业务模块自测 421
9.3 “排行榜”业务模块实战 424
9.3.1 “排行榜”业务流程分析 425
9.3.2 接收前端请求并触发缓存排行榜 426
9.3.3 业务模块自测 428
9.4 总结 432
第3篇 总结
第10章 总结与回顾 434
分布式中间件技术实战:Java版:Java version 相关资料
《分布式中间件技术实战(Java版)》由浅入深、循序渐进地介绍了当前构建分布式系统架构的主流中间件,并以Java企业级应用开发为出发点,全面介绍了应用系统架构演进的历程,以及各种典型中间件在这一历程中所起的作用。除此之外,《分布式中间件技术实战(Java版)》还以大量的图文、丰富简洁的代码实战中间件,可以让读者能真正做到学以致用。
——广东橙加科技有限公司开发部经理 神雕大侠
《分布式中间件技术实战(Java版)》实战为主,理论为辅,这很符合作者的风格。书中讲解的内容很能锻炼读者的代码编写能力及对业务场景的思考能力。书中提供的大量流程图和程序代码可以让读者更容易理解中间件每个功能组件的底层执行原理。
——广东橙加科技有限公司技术总监 Eken
作者阿修罗是一个喜欢将复杂问题简单化的开发者。特别是对于框架、组件、代码及业务系统,他更是“习惯性”地热衷于将这些东西简单化,并通过大众化的语言和略带幽默的风格表达出来。《分布式中间件技术实战(Java版)》也不例外。
——酷狗科技技术经理 阿汜
通篇阅读完《分布式中间件技术实战(Java版)》,发现这是一本颇为值得细读的书。抛开作者对中间件原理的扎实论述不说,书中给出的大量流程图更是让人大呼过瘾,这对理解中间件至关重要。可以说,清晰的流程图是进行代码实战的前提,而《分布式中间件技术实战(Java版)》在这一点上做得很好。
——唯品会信息科技有限公司高级后端开发工程师 淡然
《分布式中间件技术实战(Java版)》是一本不可多得的能真正将中间件应用到实际项目和业务场景中的书籍。作者站在初学者的角度详细介绍了比较流行的几款分布式中间件的相关知识,带领读者学习Java企业级应用开发。
——北京搜狗科技发展有限公司资深开发工程师 程诚一
分布式中间件技术实战:Java版:Java version 作者简介
钟林森 网名debug,Java高级后端工程师。目前在国内某互联网公司担任开发组长,负责公司Java应用后端开发,并参与公司IT基础架构体系的研发。CSDN博客专家,发表了大量的原创博客文字,博客访问量达百万人次。51CTO学院、CSDN学院及网易云课堂等知名教育平台讲师,教授学员上万人。追求技术,热爱分享,相信技术改变生活,技术成就梦想,一直在不断地学习和积累新知识,秉承修罗之道,花名“阿修罗”。