描述
开 本: 16开纸 张: 胶版纸包 装: 平装-胶订是否套装: 否国际标准书号ISBN: 9787121388248丛书名: 咕泡学院Java架构师成长丛书
★ 首次对Spring Cloud Alibaba进行系统性介绍的书籍
★ 结合作者多年对互联网技术及微服务架构的理解和实践
★ 从入门示例、原理剖析和源码分析等方面讲解每个模块
★ 对“实用主义者”,直接“show you the code”
★ 对“底层探究者”,会补充原理性内容,加深理解
★ 展示了微服务架构中涉及的核心技术原理和实现
★ 是学习微服务架构与分布式系统技术的必备书籍
基础篇
- 微服务的发展史
- 微服务解决方案之Spring Cloud
- Spring Cloud的核心之Spring Boot
微服务实战篇
- 微服务架构下的服务治理(Dubbo、ZooKeeper、Dubbo Spring Cloud)
- 服务注册与发现(Alibaba Nacos、Dubbo)
- Nacos实现统一配置管理
- 基于Sentinel的微服务限流及熔断
- 分布式事务Seata
- RocketMQ分布式消息通信
- 微服务网关之Spring Cloud Gateway
本书针对Spring Cloud Alibaba生态下的技术组件从应用到原理进行全面的分析,涉及的技术组件包括分布式服务治理Dubbo、服务配置和服务注册中心Nacos、分布式限流与熔断Sentinel、分布式消息通信RocketMQ、分布式事务Seata及微服务网关Spring Cloud Gateway。由于Spring Cloud中所有的技术组件都是基于Spring Boot微服务框架来集成的,所以对于Spring Boot的核心原理也做了比较详细的分析。
本书中涉及的所有技术组件,笔者都采用“场景→需求→解决方案→应用→原理”高效技术学习模型进行设计,以便让读者知其然且知其所以然。在“原理”部分,笔者采用大量的源码及图形的方式来进行分析,帮助读者达到对技术组件深度学习和理解的目标。
我看过市面上很多关于分布式和微服务的书,对于初学者或者想要进阶的人来说,总感觉缺少一点什么。我希望能够写一本书帮助更多的同学快速并且正确地成长。当然,促使我写这本书的另外一个原因是我的职业生涯的转折。
我从事Java开发工作接近10年时间,然后在职业教育这个“风口”下选择以讲师的身份创业,幸运的是创业过程还算顺利,也有不少收获。从程序员转行到讲师之后,我接触了几十万名有不同背景和不同经验的程序员,慢慢总结了一些课程设计的方法和授课的方法,最大的收获是要针对不同层次的学员合理设计内容的铺垫方式和技术的讲解方式,从而达到事半功倍的效果。因此,我想基于这套方法论,结合目前比较主流的微服务架构,写这样一本书去帮助大家。
诚然,写书和讲课或者写代码是完全不一样的。对于这本书中的每一句话、每一个字,我都仔细斟酌,抱着一种程序员对于代码的极致追求的心态来写这本书。实际上我们都知道程序是不可能完美的,希望读者能够抱着容忍程序中出现小bug的心态来原谅我文字表达的不完美。
我从2012年开始接触Dubbo,当时公司正面临大规模服务化之后的服务治理和服务监控等一系列问题,Dubbo的出现解决了很多快速发展起来的互联网公司的技术难题。从那以后,我开始深入研究Dubbo的底层原理。
2015年,公司内部全面推动微服务架构,当时采用Spring Boot Dubbo来构建微服务,基于微服务的治理生态和运维生态的逐步完善,我逐步认识到微服务带来的价值。在Spring Cloud还没有在国内大规模运用时,我们要解决服务注册与发现、服务熔断和降级、服务监控、服务路由等问题,采用的技术大部分是大公司或者Apache组织开源的。各种技术的拼凑和组装给企业带来了比较大的挑战。
从2016年开始,Spring Cloud逐步在国内普及,它提供了微服务开发、服务治理、监控等一体化解决方案。有了这个生态,中小型互联网公司要构建微服务,不需要再去找各种开源组件来集成。通过Spring Cloud可以轻松快速地构建微服务。
Spring Cloud服务治理的整个体系采用的是Netflix公司提供的开源组件,但是Netflix公司开源组件的活跃度不是很高,并且Netflix公司官方也声明了对于很多组件逐步进入维护模式。所以Spring Cloud官方发布了声明,Spring Cloud Netflix下的相关组件也会逐步进入维护模式(进入维护模式的意思就是从目前一直到以后一段时间Spring Cloud Netflix提供的服务和功能就这么多了,不再开发新的组件和功能了)。同时Spring Cloud 官方也在积极孵化其他替代品,以满足Spring Cloud 版本迭代的需求。
值得高兴的是,2018年10月31日的凌晨,Spring Cloud Alibaba正式入驻Spring Cloud官方孵化器,并在Maven中央库发布了第一个版本;2019年8月1日,在Alibaba仓库发布了第一个毕业版本。
Spring Cloud Alibaba生态下的各个组件其实在国内很多公司很早之前就有使用,它们在服务治理方面比Spring Cloud Netflix更加强大,而且比较符合国内互联网公司的业务特性,未来可期!
本书会从技术背景到基本使用再到深层次的设计思想和原理,对Spring Cloud Alibaba进行全面的分析,帮助大家全面构建Spring Cloud Alibaba技术体系。
本书特色
- 系统化的深度整理
Spring Cloud Alibaba在官网上有很多非常详细的资料,但是这些资料太散,没有系统性和深度。很多开发者需要花费大量的时间和精力去研究,很低效。本书系统分析了各个组件的使用方法和原理,对于初学者或者有一定经验的开发者来说,都能提供非常大的帮助。
- 高效的技术学习模型
以往我们学习一个技术往往直接从应用着手,这种方式会使得读者知其然而不知其所以然。本书对于Spring Cloud Alibaba生态下的技术组件采用高效的技术学习模型“场景→需求→解决方案→应用→原理”来展开,可以让读者更加了解技术背景,更好地理解技术的本质。
- 不仅有应用,还有核心原理
一个“不安分”的程序员,必然不会仅停留在技术的使用层次,技术实现原理的探索会给他带来更多的惊喜。本书在介绍Spring Cloud Alibaba生态下各个技术组件的使用方法的同时,会剖析其实现原理,并且结合一些核心源码分析设计方案的落地过程。这无疑给那些充满好奇心的读者带来了“福利”。
- 大量图形化设计,化繁为简
对于复杂的技术原理,如果一味地用书面化的文字来表述,难免会增加理解成本,读者可能要花大半天的时间去理解一句话。“书”对于开发者来说,是一个很好的学习渠道,理应化繁为简,所以本书采用“动不动就画图”的方式,在书中穿插了大量的图形,帮助读者更好地掌握技术原理。
示例源码
本书相关示例源码可以在GitHub站点下载:https://github.com/2227324689/Spring-Cloud-Alibaba-。
致谢
这本书笔者筹划了很久,中间因为各种原因,一直拖到2019年的11月份才正式动笔,接着到一月份又赶上了疫情在家里隔离,索性就利用隔离的这段时间没日没夜地把这本书写完了,也算是圆了自己写一本书的小梦想。
本书能够顺利出版,首先得感谢合伙人谭勇德、蒋孟枝的不断督促,以及本书的责任编辑董英的鼓励。其次,我要感谢我的妻子,是你的支持使我在写书期间可以“两耳不闻窗外事”,专注写作,从而顺利交稿。
我还要特别感谢我的好友汤陈,为本书提供了第7章的初稿。在整个写作过程中我们对于技术问题的交流,为我的写作提供了很多很好的思路。
Spring Cloud Alibaba于2019年8月开源以来,受到了国内诸多企业和开发者的青睐,但是市面上缺少对其系统性介绍的相关图书。本书作者结合其多年来对互联网技术及微服务架构的理解和实践经验,从入门示例、原理剖析和源码分析等各个方面整理了每个模块的知识。无论你是刚入门的Java开发者,还是从事开发工作多年的资深码农,本书都能让你受益匪浅。
——汤陈 阿里巴巴高级开发工程师
Spring Cloud Alibaba的优势绝不仅仅在于“更服国内的水土”,更在于其脱胎于内部中间件、在多年海量业务场景下打磨出的微服务生态组件,其技术含量与工业成熟度在全球范围内也极具竞争力。本书作者谭锋在微服务方面具备丰富的实战经验,并不断将自己的所学所想分享给职场小伙伴们。本书是他的实战经验总结,值得阅读。
——李嘉鹏(你假笨/寒泉子) PerfMa CEO
我与Mic老师既是老同事,也是老朋友。从他的身上,我很明显地感受到他已经从一位大牛架构师,变成了一位“不但能讲人话”、还能“授人以渔”的优秀讲师。本书的目录编排、讲述方式,深谙程序员所求。对“实用主义者”,它直接“show you the code”;对“底层探究者”,它又会进阶地补充一些原理性的内容,以加深理解。无论你是Spring Cloud Alibaba的初学者,还是正在团队推动技术转型的“老鸟”,这本书都能为你提供很好的帮助,减小你“踩坑”的概率。
——顾冬煜 赋优信息技术CTO,沪江网前技术总监
微服务已经在国内技术圈风靡多时,但能够紧跟时代步伐“知其然又知其所以然”的人不多,能够从“教”“学”“用”多个视角剖析和实践的人则更少。作者既有十多年一线实践经验,又有在教育行业创业与教学的多年经历,相信可以带领大家领略到Spring Cloud Alibaba微服务体系的“精彩”与“拍案”。
——王福强 阿里巴巴资深架构师,Canal产品技术奠基人,《Spring揭秘》《Spring Boot揭秘》《深度思考揭秘》《极简管理课》作者
作者深耕Java十余年,熟悉微服务和分布式系统中的常用技术,本书是他的经验总结和汇总,循序渐进地向我们展示了微服务架构中涉及的核心技术原理和实现,是学习微服务架构与分布式系统技术的必备书籍。
——加多 《Java并发编程之美》作者,公众号“技术原始积累”作者
推荐序1
近几年来,我们大家都体会到了移动互联网带来的便利,企业在应对外部环境的快速变化时需要快速创新。无论是传统企业还是互联网企业,都需要不断地对IT架构进行升级和改进,从而支持企业的数字化转型。
说到微服务架构,想必大家都不陌生,尤其在互联网应用中谈到企业应用架构时,微服务架构是当前必聊的话题。微服务架构是从单体架构、垂直架构和SOA架构逐渐演变而来的。微服务架构这么火热是因为相比之前的应用架构它有许多优点,例如更快速、灵活,更能适应现在需求变更快速的大环境。
Spring Cloud Alibaba是一套完整的微服务架构解决方案,它为开发人员提供了一些工具来快速构建分布式系统,这对于中小型互联网公司来说是一种“福音”,它能帮助企业在应对业务发展的同时,大大减少开发的成本。
Spring Cloud Alibaba于2019年8月开源以来,受到国内诸多企业和开发者的青睐,但在市面上缺少对其系统性的介绍和使用方法的相关内容。本书作者结合自己多年对互联网技术及微服务架构的理解和实践经验,从入门示例、原理剖析和源码分析等各个方面整理了每个模块的知识。无论你是刚入门的Java开发者,还是从事开发工作多年的资深码农,都会受益匪浅。
我是阿里巴巴淘系技术部的一名技术小二,很高兴能参与其中推广公司的开源技术。希望本书能够帮助大家快速理解和掌握微服务架构,通过技术的力量帮助企业快速成长。当然,我也希望更多的同学能够加入阿里巴巴。
汤陈
阿里巴巴高级开发工程师
推荐序2
近年来,随着互联网技术的蓬勃发展,微服务理念逐渐深入人心。围绕微服务的讨论,一刻也未曾停止。而关于“Dubbo VS Spring Cloud”的技术选型,是其中一个“长盛不衰”的热门话题。大家普遍认为,Dubbo是一款具备一定服务治理能力的RPC框架,而Spring Cloud是一整套微服务生态体系,双方的比较并不在对等的维度上。
Dubbo由阿里巴巴于2011年开源,很快发展成为国内最火爆的RPC框架,其经典程度毋庸置疑。Spring Cloud的出现,打开了微服务技术的新局面,全家桶式的解决方案,给广大开发者带来了极大的便利。Spring Cloud制定了集成标准,允许开源社区来提供组件的实现。Netflix公司在其中扮演了重要的角色,贡献了REST RPC框架、服务注册中心、服务网关、断路器、客户端负载均衡等多个服务治理组件。
2017年,阿里巴巴“重启”Dubbo的维护,不久就推出了支持Spring Boot的版本。而随后Spring Cloud Alibaba的问世,不仅宣告了拥抱Spring Cloud标准,也与Netflix系的解决方案站在了对等竞争的位置。对于很多偏好Dubbo的国内开发者来说,面对补齐的微服务生态,无疑又多了一个坚定选择它的理由。Spring Cloud Alibaba的优势绝不仅仅在于“更服国内的水土”,其脱胎于内部中间件、在多年海量业务场景下打磨出的微服务生态组件,技术含量与工业成熟度在全球范围内也是极具竞争力的。
本书作者谭锋在微服务架构方面具备丰富的实战经验,并不断将自己所学所想分享给职场小伙伴们,本书是他的实战经验总结,推荐给大家。另外,也欢迎大家来“PerfMa应用性能技术社区”交流。
李嘉鹏(你假笨/寒泉子)
PerfMa CEO
推荐序3
我曾带领团队从2016年开始调研Spring Cloud的整体生态,在了解到其完整的一体化解决方案后,决定将其引入公司做成一套全新的研发框架。由于我当时所在的是一家已经成立15年以上的老牌互联网公司,其内部的研发架构、运维体系等都向这次转型提出了“挑战”。不同于从0开始搭建,我们对Spring Cloud的组件进行了大量的二次开发工作,目的是能更平滑地完成这次转变。比如,在跨系统交互时,我们依然保留着一些通过api-gateway进行通信的方式;在微服务的运维部署上,公司内并存着容器化(既有Mesos也有Kubernetes)和虚拟机部署的方式等。在进行这些工作时,给我感触最深的就是,单纯地使用Spring Cloud整个生态的技术,已经需要一定的技术素养和研究成本。而在其基础上进行二次开发,就会面临参考资料不足、文档和书籍匮乏等问题,不得不花上大量的精力去研究源码。
用一句话形容程序员的进阶,那就是“从说IT术语,变成说人话”,这里当然有夸张的成分。我与Mic老师既是老同事,也是老朋友。我从他的身上,很明显地感受到他已经从一位大牛架构师,变成了一位“不但能讲人话”,还能“授人以渔”的优秀讲师。本书的目录编排、讲述方式,深谙程序员所求。对“实用主义者”,它直接“show you the code”;对“底层探究者”,它又会进阶地补充上一些原理性的内容,增强理解。相信无论你是新接触Spring Cloud Alibaba,还是和我当时一样正在团队推进技术转型,这本书都能为你提供很好的帮助,减小你“踩坑”的概率。
目前国内的开源项目越来越多地在开源社区发光发热,Apache基金会的顶级项目中,也有越来越多的“中国制造”。感谢Mic老师这本“干货”教材对Spring Cloud Alibaba的推广,为更多的IT开发者、IT研发团队赋能增效。
顾冬煜
赋优信息技术CTO、沪江网前技术总监
评论
还没有评论。