《AKKA实战》PDF下载

  • 购买积分:12 如何计算积分?
  • 作  者:(美)雷蒙德·罗斯腾伯格(RAYMOND ROESTENBURG),罗勃·贝克尔(ROB BAKKER),罗勃·威廉姆斯(ROB WILLIAMS)著;程继洪,肖川译
  • 出 版 社:北京:机械工业出版社
  • 出版年份:2019
  • ISBN:7111613428
  • 页数:328 页
图书介绍:

第1章Akka简介 1

1.1什么是Akka? 3

1.2 Actor简介 3

1.3两种扩展方法:建立实例 4

1.4传统扩展 5

1.4.1传统扩展和持久性:一切移入数据库 5

1.4.2传统扩展和交互应用:轮询 7

1.4.3传统扩展和交互应用:Web服务 8

1.5用Akka进行扩展 9

1.5.1用Akka扩展和持久化:发送和接收消息 10

1.5.2用Akka扩展和交互应用:消息推送 11

1.5.3用Akka扩展和容错:异步解耦 12

1.5.4 Akka方式:发送和接收消息 12

1.6 Actor:向上和向外扩展的编程模型 13

1.6.1异步模型 14

1.6.2 Actor操作 15

1.7 Akka Actor 17

1.7.1 ActorSystern 17

1.7.2 ActorRef、邮箱和Actor 18

1.7.3分发器 18

1.7.4 Actor和网络 20

1.8总结 20

第2章 搭建和运行 21

2.1克隆、构建和测试接口 21

2.1.1用sbt进行构建 22

2.1.2快进到GoTicks…com REST服务器 23

2.2探索应用中的App 26

2.2.1 App结构 26

2.2.2处理销售的Actor: TicketSeller 30

2.2.3 BoxOffice Actor 31

2.2.4 RestApi 32

2.3部署到云上 34

2.3.1在Heroku上创建App 34

2.3.2在Heroku上部署并运行 35

2.4总结 36

第3章Actor测试驱动开发 37

3.1测试Actor 37

3.2单向消息 39

3.2.1 SilentActor实例 39

3.2.2 SendingActor实例 42

3.2.3 SideEffectingActor实例 46

3.3双向消息 48

3.4总结 49

第4章 容错 50

4.1容错概述 50

4.1.1普通对象与异常 52

4.1.2 Let it crash 55

4.2 Actor生命周期 58

4.2.1启动事件 58

4.2.2停止事件 58

4.2.3重启事件 59

4.2.4生命周期综合 60

4.2.5生命周期监控 62

4.3监视 63

4.3.1监视器层次结构 63

4.3.2预定义策略 65

4.3.3自定义策略 66

4.4总结 70

第5章Future 71

5.1 Future的应用实例 71

5.2 Future无阻塞 75

5.3 Future错误处理 79

5.4 Future组合 82

5.5 Future组合Actor 89

5.6总结 90

第6章 第一个分布式Akka App 91

6.1向外扩展 91

6.1.1通用网络术语 91

6.1.2采用分布式编程模型的原因 92

6.2远程扩展 93

6.2.1把GoTicks…com app改造成分布式应用 94

6.2.2远程REPL活动 95

6.2.3远程查找 98

6.2.4远程部署 104

6.2.5多JVM测试 107

6.3总结 111

第7章 配置、日志和部署 113

7.1配置 113

7.1.1尝试Akka配置 113

7.1.2使用默认值 116

7.1.3 Akka配置 117

7.1.4多系统 118

7.2日志 120

7.2.1 Akka中的日志记录 120

7.2.2使用日志 121

7.2.3 Akka的日志控制 122

7.3部署基于Actor的应用 123

7.4总结 126

第8章Actor的结构模式 127

8.1管道和过滤器 127

8.1.1企业集成模式:管道和过滤器 128

8.1.2 Akka中的管道和过滤器 128

8.2企业集成模式:分发-收集模式 131

8.2.1适用性 131

8.2.2 Akka处理并行任务 132

8.2.3使用接收者列表实现分发组件 133

8.2.4使用聚合器模式实现收集组件 134

8.2.5组合组件实现分发-收集模式 138

8.3企业集成模式:路由表模式 139

8.4总结 143

第9章 路由消息 144

9.1企业集成路由模式 144

9.2使用Akka Router实现负载平衡 145

9.2.1 Akka Router池 147

9.2.2 Akka Router群组 152

9.2.3 ConsistentHashing Router 156

9.3用Actor实现路由模式 160

9.3.1基于内容的路由 160

9.3.2基于状态的路由 160

9.3.3 Router的实现 162

9.4总结 163

第10章 消息通道 164

10.1通道类型 164

10.1.1点对点通道 165

10.1.2发布-订阅通道 165

10.2特殊通道 172

10.2.1死信 172

10.2.2保证投递 174

10.3总结 178

第11章 有限状态机和代理 179

11.1使用有限状态机 179

11.1.1有限状态机简介 179

11.1.2创建FSM模型 180

11.2 FSM模型的实现 182

11.2.1实现转换 182

11.2.2实现入口动作 185

11.2.3 FSM定时器 189

11.2.4 FSM的终止 191

11.3使用代理实现共享状态 192

11.3.1使用代理简单地共享状态 192

11.3.2等待状态更新 194

11.4总结 195

第12章 系统集成 196

12.1消息终端 196

12.1.1归一化 197

12.1.2规范数据模型 199

12.2使用Apache Camel实现终端 200

12.2.1创建从外部系统接收消息的消费者终端 201

12.2.2实现生产者向外部系统发送消息 206

12.3实现HTTP接口 209

12.3.1 HTTP实例 209

12.3.2用Akka-http实现REST终端 212

12.4总结 216

第13章流 217

13.1基本流处理 217

13.1.1使用源和接收器复制文件 221

13.1.2实体化可运行图 223

13.1.3用Flow处理事件 227

13.1.4处理流中的错误 230

13.1.5用BidiFlow创建协议 231

13.2 HTTP流 233

13.2.1接收HTTP流 233

13.2.2 HTTP响应流 235

13.2.3内容类型和协调的自定义编组与解组 235

13.3用Graph DSL进行扇入和扇出 239

13.3.1广播流 239

13.3.2合并流 241

13.4协调生产者和消费者 243

13.5图的速率隔离 246

13.5.1对较慢的消费者,对事件进行汇总 247

13.5.2快速消费者的扩展度量 247

13.6总结 248

第14章 集群 249

14.1为什么使用集群? 249

14.2集群成员关系 251

14.2.1加入集群 252

14.2.2离开集群 257

14.3集群作业处理 261

14.3.1启动集群 264

14.3.2使用路由进行工作分配 265

14.3.3弹性作业处理 267

14.3.4测试集群 271

14.4总结 274

第15章Actor持久化 276

15.1事件提取恢复状态 277

15.1.1适时更新记录 277

15.1.2不使用update持久化状态 278

15.1.3 Actor的事件提取 279

15.2持久化Actor 280

15.2.1持久化Actor 281

15.2.2测试 283

15.2.3快照 285

15.2.4持久化查询 288

15.2.5序列化 290

15.3集群持久化 294

15.3.1单例集群 297

15.3.2分片集群 299

15.4总结 302

第16章 性能提示 304

16.1性能分析 304

16.1.1系统性能 305

16.1.2性能参数 306

16.2 Actor性能测量 307

16.2.1收集邮箱数据 308

16.2.2收集处理数据 313

16.3解决瓶颈、提高性能 314

16.4配置分发器 315

16.4.1识别线程池问题 315

16.4.2使用多个分发器实例 316

16.4.3静态调整线程池的大小 318

16.4.4使用动态线程池 320

16.5改变线程释放策略 321

16.6总结 324

第17章 展望 325

17.1 Akka-typed模块 325

17.2 Akka分布式数据 328

17.3总结 328