描述
开 本: 16开纸 张: 胶版纸包 装: 平装-胶订是否套装: 否国际标准书号ISBN: 9787121321092
适读人群
:云计算从业人员、Go语言开发人员。
1.云原生是云计算时代的发展趋势和必然结果
《Cloud Native Go:构建基于Go和React的云原生Web应用与微服务》通过一个云原生应用项目的构建,为大家介绍了云原生的道与术,引导读者了解云原生理念的产生、应用场景、优势。
2.集现今诸多热点技术之大成
《Cloud Native Go:构建基于Go和React的云原生Web应用与微服务》在构建云原生项目时,涉及Docker、持续集成、微服务、DevOps、事件溯源与CQRS等众多备受关注的技术热点,无疑会让读者受益匪浅。
3.Go语言助理云开发完美实现
Go语言以其简单优雅、快速安全、支持高并发等特性,成为云计算时代的*语言。《Cloud Native Go:构建基于Go和React的云原生Web应用与微服务》将带领读者正确认识Go语言,掌握用Go构建应用程序的方法。
4.流程完整,示例具体详细
《Cloud Native Go:构建基于Go和React的云原生Web应用与微服务》从搭建平台开始,逐步带领读者开发一个完整的云上项目。其中的每一环节都有详细讲解。示例具有代表性,代码详细,帮助读者轻松掌握云原生开发的关键。
云之道的优点 2
遵循简单 2
测试优先,测试一切 3
尽早发布,频繁发布 5
自动化一切 6
建立服务生态系统 7
为什么使用Go 8
简单 8
开源 8
易于自动化和IDE自由化 8
本章小结 9
2 开始 11
正确的工具 11
配置Git 12
安装Homebrew 12
安装Git客户端 13
安装Mercurial和Bazaar 13
创建GitHub账户 14
创建Go环境 14
配置Go工作区 14
检查环境 15
本章小结 16
3 Go入门 17
建立Hello cloud 18
使用基本函数 19
使用结构体 22
介绍Go接口 25
向结构体添加方法 25
Go中的接口动态类型检查 26
使用第三方包 28
创建自有包 30
导出函数和数据 31
创建包 31
本章小结 34
4 持续交付 35
Docker介绍 36
为什么要使用Docker 36
安装Docker 36
运行Docker镜像 38
与Wercker的持续集成 39
持续集成的实践 39
为什么使用Wercker 40
创建Wercker应用程序 41
安装Wercker CLI 42
创建Wercker配置文件 43
使用Wercker进行构建 48
部署到Docker Hub 50
读者练习:创建完整的开发管道 51
高级挑战:集成第三方库 53
本章小结 53
5 在Go中构建微服务 55
设计API First的服务 55
设计match API 56
创建API Blueprint 56
通过Apiary测试和发布文档 58
架设微服务 59
构建Test First的服务 62
创建个失败测试 63
测试Location Header 66
壮丽的蒙太奇:迭代测试 67
在云端部署和运行 70
创建PWS账户 70
配置PCF开发环境 70
提交到Cloud Foundry 71
本章小结 72
6 运用后端服务 75
设计服务系统 75
测试优先构建依赖服务 77
构建fulfillment服务 78
构建catalog服务 81
在服务之间共享结构化数据 87
客户端引用服务端包 88
客户端复制服务端结构 88
客户端与服务端引用共享包 89
使用服务捆绑来外部化地址与元数据 90
服务发现 93
动态服务发现 94
Netflix的服务发现系统Eureka 94
读者练习 97
进阶操作 97
本章小结 98
7 构建数据服务 99
构建MongoDB存储库 100
为什么选择MongoDB 100
更新存储库模型 100
通过Go来操作MongoDB 101
以Test-First方式编写MongoDB存储库 102
集成测试一个Mongo-Backed服务 107
集成临时MongoDB数据库 108
编写一个集成测试 110
在云中运行 115
后端服务的配置 115
本章小结 117
8 事件溯源和CQRS 119
现实源自事件 120
幂等 121
隔离 121
可测试 122
可再现,可恢复 123
大数据 123
拥抱终一致性 123
CQRS简介 124
事件溯源案例 126
天气监测 126
互联网汽车 127
社交媒体消息处理 127
代码示例:管理无人机舰队 128
构建命令处理程序服务 129
RabbitMQ介绍 129
构建命令处理器服务 133
构建事件处理器 135
对事件处理器进行集成测试 140
构建查询处理程序服务 140
本章小结 141
9 使用Go构建Web应用程序 143
处理静态文件和asset 143
支持JavaScript客户端 145
使用服务端模板 148
处理表单 150
使用cookie和会话状态 151
写入cookie 152
读取cookie 153
使用Wercker构建和部署 153
本章小结 155
10 云安全 157
保护Web应用程序 157
应用程序安全性选项 158
设置Auth0账户 159
构建一个OAuth安全的Web应用程序 160
运行安全的Web应用程序 164
保护微服务 166
客户端凭据模式概述 166
使用客户端凭据保护微服务 168
关于SSL的注意事项 169
隐私和数据安全 170
黑客不能得到你没有的 170
读者练习 172
本章小结 173
11 使用WebSockets 175
WebSockets解析 175
WebSockets如何工作 176
WebSockets与服务器发送事件对比 177
设计WebSockets服务器? 177
WebSockets的云原生适应性 178
使用消息服务创建WebSockets应用 180
关于JavaScript框架 183
运行WebSockets示例 183
本章小结 184
12 使用React构建Web视图 185
JavaScript的形势? 186
为什么选择React 186
虚拟DOM 187
组件组合 187
响应式数据流 188
集中焦点 188
使用的便利性 189
React应用程序剖析 189
package.json文件 189
Webpack.config.js文件 191
.babelrc文件 191
理解JSX和Webpack 191
React组件 192
构建简单的React应用程序 192
不赞成的做法 199
测试React应用程序 200
进一步阅读 200
React网站 200
React书籍 201
其他资料? 201
本章小结? 201
13 使用Flux构建可扩展的UI 203
Flux介绍 203
dispatcher 204
store 204
view 205
action 205
source 205
Flux的复杂性 205
创建Flux应用程序 206
本章小结 215
14 创建完整应用World of FluxCraft 217
World of FluxCraft介绍 218
架构概览 219
独立扩展、版本控制和部署 221
数据库不是集成层 221
单向不可变数据流 221
Flux GUI 222
Go UI宿主服务 223
玩家移动时序图 224
命令处理 225
事件处理 226
维持现实服务的状态 227
地图管理 227
自动验收测试 228
本章小结 230
15 结论 231
我们学到了什么 231
Go不是小众语言 231
微服务应该有多“微” 232
持续交付和部署 232
测试一切 232
尽早发布,频繁发布 232
事件溯源、CQRS和更多首字母缩略词 233
下一步 233
附录A 云应用的故障排查 235
译者序
Go语言起源于Google,集中进入大家视线是由于一款革命性的产品——Docker的发布。从Go开始流行,直到其位列TIOBE榜单的前20名,我们都一直关注着这门语言的发展。近两年来,一批批优秀的基于Go语言的开源软件涌现出来,例如etcd、Kubernetes、Prometheus等,这些开源软件被广泛应用于我们的生产环境中。
因为Go语言非常简洁且功能强大,加之其能够充分利用系统的多个核心组件,实现高性能的网络服务,因此我们于2014年将Go语言引入了我们的公司TalkingData,并使用它构建了自己的开源监控系统——OWL(https://github.com/ TalkingData/owl),也基于它实现了对Hadoop集群虚拟化的探索magpie(https://github.com/rootosngjc/
magpie)。
刚开始接触到本书时,我们看到书中提到的那些熟悉的技术和理念后感到非常兴奋,通过这本书,我们可以有机会用一种体系化、结构化的方式与大家交流书中的知识和技术。因此我们决定翻译这本书,并且牺牲了许多工作之余的时间来研究书中的内容和细节,除了出于对技术分享始终保有热情,更是因为想要让各位读者早日看到这本关于Go语言和云原生技术的好书。
Cloud Native Go是一本很好的云原生应用实践手册,全书基于微服务理念编写,书中有丰富的示例和代码,这些代码托管在GitHub上,读者可以很轻松地获取到。另外,书中还介绍了很多不错的工具的实践,这些工具都是免费的,不需要绑定信用卡,大家可以放心使用。而且,原作者风趣幽默的行文非常有吸引力,不会让大家阅读时感到乏味。
这本书涉及的内容非常广泛,读完本书,读者会对云原生应用的构建规则、微服务划分、测试驱动开发、CQRS和事件溯源、持续发布流程、安全、故障排查等整个软件开发生命周期中的重要环节有一个较好的了解,也会对前端开发、前端框架、UI设计有一定的认识,从而在实际的程序开发过程中更加得心应手。
当然,这本书不是一本专门讲解Go语言的书籍,它适用于有一定Go语言基础的读者。阅读关于创建Web应用的部分时,还需要读者对Web应用开发流程有所了解,这对于长期从事后端开发的读者来说可能会比较困难。
除我以外,还有三位TalkingData的同事徐蓓、马超、吴迎松参与了本书的翻译。其中,徐蓓翻译了1~5章,马超翻译了6~8章,吴迎松翻译了9~12章,其余的章节由我翻译,同时我也承担了全书译文的审校工作。
本书能够顺利出版并及时与读者见面,要感谢很多人的帮助。感谢公司的大力支持;感谢电子工业出版社的编辑孙奇俏对本书的大力协助和专业指导;感谢在本书的翻译过程中所有通过朋友圈和https://rootsongjc.github.io/cloud-native-go/网站关注和支持我们的朋友们;后再次感谢所有译者。希望每一位读者都能从本书中获得想要的知识,希望你们喜欢这本书,衷心感谢大家!
前言
当Dan和我开始写这本书时,我们不希望它成为一本参考书或“一本语法书”。相反,我们希望能够充分利用自己为Pivotal客户构建云原生解决方案的经验,以及近一生的综合经验来为各种规模、形态和行业的公司构建软件。
这本书从一个哲学章节“云之道”开始,因为我们坚信构建良好软件的秘诀在于开发人员的心态和纪律,而不是工具或语言。
在本书中,我们将按照测试驱动和高度自动化的方式逐步实现云之道,通过一系列章节提高大家在Go中构建云原生服务的能力。本书涵盖构建服务的基本原理,中间件技术,Git、Docker和Wercker等工具的使用,还包括云基础设施的相关内容,如基于环境的配置、服务发现以及基于响应和推送式的应用程序。本书涵盖了事件溯源和CQRS等模式,书中的所有内容组合成终的示例,相信可以为大家的项目构建提供灵感。
我们始终秉承着一个坚定的信念——构建软件应该像使用它一样有趣(或更有趣)。如果没有乐趣,那么一定是你做错了。我们希望在使用Go构建服务时获得的快乐可以感染读者,希望你在阅读本书时能像我们在写作它时一样,获得更多的乐趣。
云原生是一种新型的架构设计模式和业务理念。云原生使得业务系统可以规避物理资源的限制而享受云的弹性,还帮助开发者用模块化的方式快速构建了松耦合的业务系统。而Go语言则因其分布式友善性和高效性被广泛应用于如Docker、Kubernetes等流行的云原生开源项目中,成为了云计算从业人员的宠儿。本书将两者融合,既有架构层面的*实践,又有从头搭建真实应用的实战演练。而译者更是用流畅的文字,将这本理论结合实践的读物呈现在了国内读者面前。
才云科技CEO,张鑫
随着Cloud的普及,应用程序的架构也需要适应趋势而有所改变。于是,Cloud Native Application的概念被提出来了。虽然当前云原生应用还在不断演化中,具体会是什么样子没有一个定论,但这本书通过一些有趣的示例,可以让大家体验到应用架构和开发思路与以往相比的不同。由于本书中的示例是用Go语言描述的,所以本书也可以作为Go语言云原生应用开发的案例教程,相信大家可以从中学到许多。
QingCloud架构师,王渊命
几乎每个程序员都爱Go语言,也都爱云原生开发。如果能用属于云时代的编程语言Go来开发云原生应用程序,那一定是一件很酷的事情。这本书告诉我们,这件很酷的事情完全可以成为现实。无论云原生的工具链、微服务的构建方式,还是中间件与数据库,乃至前端视图开发,这本书中都给出了实践准则与详细示例。如果你是一位热爱Go语言编程的程序员,那么就拿起这本书开始一场愉快的实战之旅吧!
网易云基础服务总经理,陈谔
这本书是一本写给云时代开发者的书。什么是Cloud Native应用?应用开发者该如何开发一个更适合在云上运行的应用程序?这些问题是任何一个云计算从业者,尤其是云应用开发者无法回避的问题。本书循序渐进地向我们展示了如何利用Go语言实现微服务、持续部署、ES/CQRS模型等云时代应用开发的标签性技术,Cloud Native概念下的云应用形态也随之轮廓毕现、展露无遗!
BoCloud博云CTO,李亚琼
目前,Go语言在云计算领域的地位类似于C语言在操作系统层面上的地位。本书是一本面向实战的技术书。作者选用了一整套技术栈、技术理念甚至哲学,带领读者逐步踏入基于Go语言的云原生应用程序开发的世界。我亲自运用过书中所讲的大部分技术,也很认同作者的主要观点。如果你也正在开发云上的应用项目,相信这本书可以作为你的重要参考。
《Go并发编程实战》作者、GoHackers社群发起人,郝林
伴随着如Docker、Kubernetes、etcd、InfluxDB等诸多优秀云计算开源项目的成功,Go语言也逐渐成为当今*“火”的语言之一,其简单、并发性好、高效等特性获得了越来越多的公司及个人的青睐。另外,云计算逐渐成为业界的潮流和趋势,那么如何能找到一种全面拥抱云构建应用程序的方法呢?本书列举大量Go语言示例,结合构建云原生应用所需要遵循的“道”,很好地为大家解答了这个问题。
腾讯云PaaS产品总监,邹辉
Go语言被誉为云时代的系统语言,而目前市面上刚好缺少一本基于云平台的实战经验手册,而这本书的出现恰好弥补了这个空缺。本书详细地讲解了在云计算时代如何使用Go语言进行应用程序开发、自动化测试、运维及部署,我非常看好这本书,它一定能成为云计算时代的Go语言开发标准手册。
Apple核心系统高级工程师,谢孟军
Go语言具备简洁的语法、超高的开发效率以及优异的性能,这使其成为云计算时代后端开发的*语言。这本书不是一本关于Go语言的教程,而是从实战的角度出发,介绍如何在云环境下以Go语言为核心开发业务系统的实践手册,书中还介绍了系统开发过程中需要遵循的开发原则和哲学,相信读者会从中获益匪浅。
PingCAP工程副总裁、TiDB技术负责人,申砾
拿到本书的英文原版书籍时,我快速浏览了内容,当即就决定组织团队翻译这本书。因为在这本书中我看到了整个技术运营部门过去两年走过的路,以及未来要走的路,也看到了Go开发的基础设施和微服务将是未来松耦合和弹性架构的重要支持者。这本书包含Go语言基础知识、持续交付、Web框架、微服务以及安全等整个云服务开发流程中的关键点,是一本不错的实战手册。再次感谢这本书的翻译者宋净超、吴迎松、徐蓓、马超。
TalkingData运维总监,潘松柏
推荐序1
作为一个在IT行业摸爬滚打20余年的老程序员,我一直认为程序员的工作不仅仅是进行代码编写。很多情况下,程序员的工作和作家类似,都是在进行创作。很多非常出色的程序员同时也是出色的作家,比如程序员王小波除了是一个C语言和汇编语言高手,同时还创作了《时代三部曲》,进而成为知名的作家。当然,大部分程序员没有王小波那份驾驭文字的功力,没办法跨界写小说。不过,总结日常的一些技术点滴使其成为文章或者翻译国外的博客、技术书籍,这些对于大部分程序员来讲还是不难做到的,因此这也成为我们团队所有程序员的OKR。
近几个月的周六,我经常看到宋净超同学静坐在自己的工位上,或若有所思,或埋头打字,屏幕上闪烁的不是编程的IDE,倒像是码字的word文档。经过几个月的辛苦努力,终于,由宋净超、吴迎松、徐蓓、马超几位技术运营团队的同学翻译的这本《Cloud Native Go:构建基于Go和React的云原生Web应用与微服务》摆在了我的面前。
Cloud Native的概念来自Pivotal的Matt Stine,是面向现代DevOps、微服务、持续集成等技术的一种思想,其本身并不是某一种具体的技术。顾名思义,这本书就是将这种思想利用Go语言进行实践和落地。结合我们技术运营团队过去两年的工作,我深刻地理解他们为什么要翻译这本书,因为这本书中的很多思想正是我们技术运营团队在过去两年中一直践行的。对于在实践的路上苦苦前行的程序员来讲,看到一本与自己的技术理念非常一致的书,内心的激动可想而知,我相信这也是他们要加班加点将这本书翻译出来并介绍给国内广大同行的重要原因。
从一个经常阅读技术书籍的读者角度来看,本书是一本很贴近实战的技术书籍。对于没有Go语言开发经验的读者来讲,这本书介绍了Go语言的基础知识,并且指导读者去实践,从而为掌握书中的其他内容打下基础。不过,这毕竟不是一本Go语言专著,如果想了解更多Go语言的特性和高级用法,还需要查阅专门讲解Go语言的书籍或访问Go语言技术社区。既然这本书是面向Cloud Native的,那么关于Cloud Native的概念无疑才是本书的核心内容。在这本书中,大家除了可以了解到持续交付、测试优先、微服务、服务治理、数据服务、CQRS、云安全等概念,同时还可以通过书中的示例一步步地实践,终完成一个真实的World of FluxCraft项目。一本优秀的技术书籍应该能够在理念上给人以启迪,让人产生思考和共鸣,同时又能够真正落到实地,让技术人员可以亲自去探索和验证,而这本书无疑是优秀书籍的代表。
工作多年,我阅读过很多由国内技术人员翻译的计算机方面的书籍,体验不尽相同。很多技术书籍的翻译水准欠佳,且不说能否达到信、达、雅的境界,能够满足没有常识性错误和语句通顺这两个基本要求就已经很难得了,因此,有的时候我宁愿去读英文原版。刚刚拿到这本书的翻译稿时,老实讲,我十分担心翻译质量,在这个AI逐渐取代人类工作的时代,如果翻译质量不高,不如使用谷歌翻译更为合适。然而通篇读下来,整本书的翻译质量出乎我的意料!虽然是翻译稿,但是整本书的语言风格非常本土化,并且能看出译者的文字功底非常深厚。无数个周末的无休,只是为了能够给大家带来一部高质量的技术书籍,也不枉原作者辛苦创作,我觉得技术运营团队的同学们的这种态度非常难得!
由于负责TalkingData的主要线上业务和数据业务的技术研发工作,因此我每天都会面临着如何能够使线上系统在并发压力和数据规模持续增加的情况下还能保证稳定和快速迭代的挑战。为了应对这些挑战,我们在几年前就开始尝试将DevOps的理念引入团队中,开发并开源监控报警系统OWL,这让我们能够全天候、多通道地支持系统报警。同时我们也将微服务化、灰度上线、端到端自动测试等应用于日常工作中。
这本书中的很多理念给了我深刻启发,也让我坚信我们正走在一条正确的路上。相信国内和我们面临同样挑战的团队还有很多,这本书无疑可以给面临类似问题的团队带来很大的帮助。同时,我也衷心希望我们的技术团队未来能够将自己的经验和教训积累下来,出版我们自己的原创技术书籍。
阎志涛
TalkingData副总裁
2016年6月
推荐序2
很多年以前,我便听说过Go语言的大名,因为它的创始人中有大名鼎鼎的Ken Thompson以及Rob Pike。年轻一代的程序员或许不了解这两位“爷爷”辈的程序员,但在我学习计算机的年代,这两位大师非常受人崇敬,他们参与开发的Unix、Plan 9、UTF-8等也都是可以载入史册的伟大产品。尤其是Thompson,他早在1983年就因对Unix以及C语言做出卓越贡献而获得了图灵奖。不过当我次听到Go这个新的程序语言时,多少还是有些怀疑,Go究竟能不能被程序员所接受呢?毕竟现在的开发者可以选择的语言工具已经极其丰富,无论在哪一种场景下,都已经存在太多的选择。
几年过去了,随着Docker的大热,我才突然意识到其背后的开发语言竟然就是这个新生不久的Go。随之而来的是,越来越多的企业和产品开发项目开始采用Go。这个名单很长,其中包括Kubernetes、OpenShift、CoreOS、MongoDB、Twitch以及Uber等。尤其让我感到惊讶的是,以全面采用Python语言著称的Dropbox居然也将核心的组件从Python迁移到了Go上面,原因在于程序语言的性能不同。受到这个事件的影响,我开始将Go语言加入到我的学习清单里面。
众所周知,云计算已经成为了这个时代中IT技术发展重要的方向,同时因为我所任职的企业AWS在云计算领域拥有巨大的影响力,于是我就会特别留心一切与云计算开发相关的话题。自从2015年AWS发布了针对Go语言的SDK,越来越多的开发者开始了Go语言的云计算开发之旅。我相信许多开发者在学习的过程中需要的不仅仅是一门讲解程序语言语法的教程,他们更希望的是拥有一本针对云计算的Go实践开发手册。《Cloud Native Go:构建基于Go和React的云原生Web应用与微服务》应该就是这样的一本书,书中的一切内容都围绕着云计算的实践来展开,当中每一段代码示例都可以被应用到实践中。
写一本书是很辛苦的,而高质量的翻译无疑是使这样一本书能够被广泛接受的关键所在。感谢作者和译者们为此而付出的辛苦努力,也希望所有开发者能够在云计算的时代因此而受益。
古人云:理无专在,而学无止境也。是以为记。
费良宏
AWS首席布道师
2017年6月
译者序
Go语言起源于Google,集中进入大家视线是由于一款革命性的产品——Docker的发布。从Go开始流行,直到其位列TIOBE榜单的前20名,我们都一直关注着这门语言的发展。近两年来,一批批优秀的基于Go语言的开源软件涌现出来,例如etcd、Kubernetes、Prometheus等,这些开源软件被广泛应用于我们的生产环境中。
因为Go语言非常简洁且功能强大,加之其能够充分利用系统的多个核心组件,实现高性能的网络服务,因此我们于2014年将Go语言引入了我们的公司TalkingData,并使用它构建了自己的开源监控系统——OWL(https://github.com/ TalkingData/owl),也基于它实现了对Hadoop集群虚拟化的探索magpie(https://github.com/rootosngjc/
magpie)。
刚开始接触到本书时,我们看到书中提到的那些熟悉的技术和理念后感到非常兴奋,通过这本书,我们可以有机会用一种体系化、结构化的方式与大家交流书中的知识和技术。因此我们决定翻译这本书,并且牺牲了许多工作之余的时间来研究书中的内容和细节,除了出于对技术分享始终保有热情,更是因为想要让各位读者早日看到这本关于Go语言和云原生技术的好书。
Cloud Native Go是一本很好的云原生应用实践手册,全书基于微服务理念编写,书中有丰富的示例和代码,这些代码托管在GitHub上,读者可以很轻松地获取到。另外,书中还介绍了很多不错的工具的实践,这些工具都是免费的,不需要绑定信用卡,大家可以放心使用。而且,原作者风趣幽默的行文非常有吸引力,不会让大家阅读时感到乏味。
这本书涉及的内容非常广泛,读完本书,读者会对云原生应用的构建规则、微服务划分、测试驱动开发、CQRS和事件溯源、持续发布流程、安全、故障排查等整个软件开发生命周期中的重要环节有一个较好的了解,也会对前端开发、前端框架、UI设计有一定的认识,从而在实际的程序开发过程中更加得心应手。
当然,这本书不是一本专门讲解Go语言的书籍,它适用于有一定Go语言基础的读者。阅读关于创建Web应用的部分时,还需要读者对Web应用开发流程有所了解,这对于长期从事后端开发的读者来说可能会比较困难。
除我以外,还有三位TalkingData的同事徐蓓、马超、吴迎松参与了本书的翻译。其中,徐蓓翻译了1~5章,马超翻译了6~8章,吴迎松翻译了9~12章,其余的章节由我翻译,同时我也承担了全书译文的审校工作。
本书能够顺利出版并及时与读者见面,要感谢很多人的帮助。感谢公司的大力支持;感谢电子工业出版社的编辑孙奇俏对本书的大力协助和专业指导;感谢在本书的翻译过程中所有通过朋友圈和https://rootsongjc.github.io/cloud-native-go/网站关注和支持我们的朋友们;后再次感谢所有译者。希望每一位读者都能从本书中获得想要的知识,希望你们喜欢这本书,衷心感谢大家!
宋净超
2017年6月
评论
还没有评论。