任何以前做过多线程的人都不会否认管理多线程程序是困难并且痛苦的。 我说管理是因为它开始很容易而且当你看到性能提升时会很兴奋。但是,当你看到你没法从子线程的错误中恢复 或者 这些僵尸bug很难重现 或者 当用性能剖析器时你发现你的线程在更新一个共享状态时阻塞了很长时间时,那真的很痛苦。

我倾向于不说Java的并发API和集合把并发编程变的更轻松和容易了,因为如果你看到这,你肯定渴望对子线程任务有更多控制或者希望更简单但又不愿意去写一堆的锁和同步代码块,而且希望对这种模式有更高层的抽象。

着这个Akka笔记里,我们会将Akka的例子过一遍并且看看这个工具箱里的各种特性。

什么是Actors

直接把Actors想象成人,人与人之间不直接说话,人们通过邮件来交流。

下面展开说。

1.消息 MESSAGING

想象有两个人 - 一个有智慧的老师和一个学生。 学生每天早上发邮件给老师,老师则回复一条妙语。

要点:

  1. 学生发一个邮件。一旦发出,邮件不能被编辑。这叫做不可变性。
  2. 老师在任何他喜欢的时间检查邮箱。
  3. 老师会发回一个邮件(也是不可变的)。
  4. 学生自由的检查自己的邮箱。
  5. 学生不会等待回复(没有阻塞)。

以上基本上解释了Actor模型的最基本模块 - 传递消息。

2. 并发 CONCURRENCY###!

现在,想象有三个老师和三个学生 -每个学生都给每位老师发邮件。那现在有什么事情发生了呢?没啥变化。每个人都有他们自己的邮箱。有一点需要记一下:

默认规则是邮箱里的邮件是按照接收的顺序来阅读/处理

内部实现默认是用ConcurrentLinkedQueue。并且因为没有人等待捡邮箱里的邮件,这是一个简单的非阻塞消息。(有很多内置的邮箱,事实上我们甚至能自己实现一个)

3.故障转移 FAILOVER

想象三个老师来自不同的系 - 历史系,地理系和哲学系

历史老师会对过去的事情进行回复,地理老师会发出一个有趣的地方,哲学老师回复一个格言。每个学生会给每个老师发邮件(消息)并且得到回复。学生并不关心是系里的哪个老师发的回复。如果某一天老师生病了呢?必须至少有一个系里的老师来处理这些邮件(消息)。这时,必须有另一个老师顶替上来处理邮件。

需要注意的:

  1. 需要有一个能做各种不同事情的Actor的后备池。
  2. 一个Actor有可能在处理消息时出现问题。他也不能进行自我恢复。这种情况发生时会有一个新的Actor被创建并且取代老的Actor。一个可选的做法是,Actor可以忽略那个有问题的消息并且直接处理其他还没处理的消息。这种方式叫Directives,我们稍后再说。

4.多任务 MULTITASKING

我们假设老师还会在学生询问的时候用邮件回复考试分数。同样的,Actor可以处理多种类型(type)的消息。

5.串联 CHAINING

如果学生希望拿到一个完整的将三份消息串在一起的邮件而不是三份邮件呢?

我们的Actor仍然可以这么做。我们可以把老师串成一个继承的层次结构。当我们谈到Supervisor和Future时我们还是回到这里。

现在让我们用Actor模型来类推一下这个组件。

学生和老师就是我们的Actors。邮箱就是Mailbox组件。请求和回复都不能被更改。他们是不可变(immutable)对象。最后,Actor中的MessageDispatcher组件是用来管理邮箱并且把消息路由到目标邮箱。

这是我翻译的文章,原文在http://rerun.me/2014/09/11/introducing-actors-akka-notes-part-1/


文章来自微信平台「麦芽面包」,微信号「darkjune_think」。转载请注明。

翻译:AKKA笔记 - 介绍Actors的更多相关文章

  1. [翻译]AKKA笔记 - CHILD ACTORS与ACTORPATH -6

    原文:http://rerun.me/2014/10/21/akka-notes-child-actors-and-path/ Actor是完全的继承结构.你创建的任何Actor肯定都是一个其他Act ...

  2. [翻译]AKKA笔记 - LOGGING与测试ACTORS -2 (二)

    3.THROW IN A LOGBACK.XML 现在我们把SLF4J日志配置在logback. <?xml version="1.0" encoding="UTF ...

  3. [翻译]AKKA笔记 - LOGGING与测试ACTORS -2 (一)

    在前两章 ( 一 , 二 ) ,我们大致讲了Actor和message是怎么工作的,让我们看一下日志和测试我们的 TeacherActor . RECAP 这是上一节我们的Actor代码: class ...

  4. [翻译] AKKA笔记- ACTORSYSTEM (配置CONFIGURATION 与调度SCHEDULING) - 4(一)

    原文在http://rerun.me/2014/10/06/akka-notes-actorsystem-in-progress/ 像我们前面看到的,我们可以用ActorSystem的actorof方 ...

  5. [翻译]AKKA笔记 - 有限状态机 -1

    原文地址:http://rerun.me/2016/05/21/akka-notes-finite-state-machines-1/ 我最近有个机会在工作上使用了Akka FSM,是个非常有趣的例子 ...

  6. [翻译]AKKA笔记 -ACTOR SUPERVISION - 8

    失败更像是分布式系统的一个特性.因此Akka用一个容忍失败的模型,在你的业务逻辑与失败处理逻辑(supervision逻辑)中间你能有一个清晰的边界.只需要一点点工作,这很赞.这就是我们要讨论的主题. ...

  7. [翻译]AKKA笔记 - ACTOR MESSAGING - REQUEST AND RESPONSE -3

    上次我们看Actor消息机制,我们看到开火-忘记型消息发出(意思是我们只要发个消息给Actor但是不期望有响应). 技术上来讲, 我们发消息给Actors就是要它的副作用. 这就是这么设计的.除了不响 ...

  8. [翻译]AKKA笔记 - DEATHWATCH -7

    当我们说Actor生命周期的时候,我们能看到Actor能被很多种方式停掉(用ActorSystem.stop或ActorContext.stop或发送一个PoisonPill - 也有一个kill和g ...

  9. [翻译]AKKA笔记 - ACTOR生命周期 - 基本 -5

    原文地址:http://rerun.me/2014/10/21/akka-notes-actor-lifecycle-basic/ (请注意这了讨论的生命周期并不包括 preRestart 或者pos ...

随机推荐

  1. URAL1132_Square Root

    求解方程,x^2=n (mod P). 解二次同余方程的步骤: 1.首先判断勒让德符号(n,p)是否的等于1,即n^((p-1/2)=1 (mod p)是否成立.不成立显然无解.(略) 2.任取0-( ...

  2. RBAC用户权限管理数据库设计

    RBAC(Role-Based Access Control,基于角色的访问控制),就是用户通过角色与权限进行关联.简单地说,一个用户拥有若干角色,每一个角色拥有若干权限.这样,就构造成“用户-角色- ...

  3. json数据测试接口

    json数据测试接口:http://www.xiaoqiang.org/tools/JsonView/?1348068433

  4. Linux三剑客之awk

    awk awk是linux下的一个命令,他对其他命令的输出,对文件的处理都十分强大,其实他更像一门编程语言,他可以自定义变量,有条件语句,有循环,有数组,有正则,有函数等.他读取输出,或者文件的方式是 ...

  5. Centos 6.X基本维护操作

    设置163源,全新最小化安装时,更改源需先yum install wget mv /etc/yum.repos.d/CentOS-Base.repo /etc/yum.repos.d/CentOS-B ...

  6. Win7下硬盘安装Linux双系统

    Win7下硬盘安装CentOS6.2 一.准备工作:划出磁盘空闲空间和准备安装文件  参考文献: [Win7下硬盘安装Linux总结(CentOS)]来源:Linux社区  作者:lixianlin ...

  7. 【Visual Lisp】人机交互与数据处理(表除外)-lisp

    ;;本专题所讲述的内容是人机交互以及常规数据处理技术;;★★★01.人机交互★★★;;△△△键盘输入交互△△△(getint "请输入整数");;从键盘输入整数,如果不是整数则重复 ...

  8. Sublime+Golang Plugin

    很喜欢在Sublime开发Golang程序,主要是要一个Sublime Golang Plugin, 可以给代码autocomplement.相当的棒! 1.安装Sublime https://www ...

  9. !important

    当你需要确保某元素具有指定的 CSS 时,你可以使用!important. 举例如下: color: pink !important;

  10. [UCSD白板题] Huge Fibonacci Number modulo m

    Problem Introduction The Fibonacci numbers are defined as follows: \(F_0=0\), \(F_1=1\),and \(F_i=F_ ...