上一篇我们简介了Actor系统。说明了Actor之间存在着层次关系,它也是构成Actor应用的最主要的单位。

本篇介绍Actor本身的一些基本概念。
一个Actor包括了State(状态),Behavior(行为)。一个Mailbox(邮箱)和Supervisor Strategy (管理员策略),全部这些都封装在一个Actor引用之中(Actor Reference)。
Actor 引用
一个Actor对象须要和外界隔离开来才干构成一个Actor模型,因此从外部看,一个Actor对象由一个Actor引用来表示(想一想文件句柄的概念,这里有些相似)。一个Actor对象能够被传来传去。但从Actor系统外部一般无法窥视Actor内部的一些结构。
状态
一个Actor对象一般会包括一些变量,能够用来保存Actor当前的一些状态。这能够是一个有限状态机(FSM),一个计数器,等待处理的请求等。

正是因为这些状态才使得Actor变得有价值,而且这些状态须要保护起来以免被其他Actor破坏。一个好消息是Akka的Actor从概念上说都包括一个自己的轻量级的线程,全然和系统的其他部分分隔开来。这意味着你无需考虑同步互锁的情况。
而在幕后。Akka会在一种物理线程上执行多个Actor对象。一般是几个Actor共享一个物理线程。而某个Actor的兴许调用可能会使用不同的物理线程,而这些详细的实现细节对于Akka Actor使用者来说不须要了解。
因为Actor的内部状态对于Actor的操作非常重要。因此保持一致的状态什么必要,因此当一个Actor出错须要由其管理员重新启动时。其状态会又一次构造,就和最初创建Actor一样。
但也能够选择在Actor重新启动时恢复之前的某个存储点。
行为
每当处理一个信息时。它和Actor当前的某个行为做匹配,一个行为为一个函数,它定义了某些动作,也就是某个消息来时须要做的事。比方在用户通过验证是转发请求而在验证失败时拒绝请求。这些行为可能随时间而变化。

邮箱
一个Actor对象的作用是用来处理消息。这些消息能够由一个actor发给另外的actor对象(也能够来自外部actor)。

而用来连接发送者和接受者的部件就是邮箱。每一个Actor都有且仅仅有一个邮箱,全部发送者都将消息发送到这个消息队列,不同的发送者发送消息的顺序可能是随机发生的。而对于同一个发送者来说。发送消息的顺序和到达邮箱的顺序是一致的。

能够选择不同的邮箱实现,缺省为FIFO(先进先出队列).这对于通常情况来说是非常有利的,但对于某些情况,比方须要处理一些高优先级的消息,此时使用FIFO就不太合适了。
AKKa系统和其他Actor模型实现不同的一点是。当前的Actor行为必须处理下一个队列中的消息。没有办法能够扫描队列中匹配的消息。缺省情况下,假设某个消息没有处理将作为出错处理,除非你又一次定义这样的行为。
子Actor
每一个Actor都能够成为一个管理者(supervisor)。假设它创建用来处理子任务的子Actor对象。该Actor将自己主动管理子Actor。Actor的Context保存了其创建的一组子Actor对象并能够訪问他们。这个列表的改动能够通过创建(context.actorOf),停止(context.stop(child))等来完毕。

实际的创建和终止时异步发生的,因此创建和终止子Actor不会堵塞管理员Actor。

管理员策略
管理员策略用来处理子Actor出错时的情况。这些错误情况的处理由Akka依据定义的管理员策略来自己主动完毕。因为这些策略对于一个Actor系统的组成是最主要的,因此在Actor创建之后,管理员策略不能改动。
因为一个Actor仅仅能定义一个管理员策略,这意味着假设一个Actor的子对象须要不同的管理员策略时。那么须要一些中间层Actor来对这些子Actor进行分组。
终止Actor
当一个Actor中止(比方重新启动没有成功,自行终止,或者其管理员终止其执行),其占用的资源会被释放。并把其尚未处理的消息加入到系统的“死信邮箱”中。这些死消息会作为DeadLetter转发给EventSystem。其邮箱被替换成一个系统邮箱,将新收到的消息作为DeadLetter转发到EventSystem。

Akka 编程: 什么是Actor的更多相关文章

  1. Akka系列---什么是Actor

    本文已.Net语法为主,同时写有Scala及Java实现代码 严肃的说,演员是一个广泛的概念,作为外行人我对Actor 模型的定义: Actor是一个系统中参与者的虚拟人物,Actor与Actor之间 ...

  2. Scala 深入浅出实战经典 第68讲:Scala并发编程原生线程Actor、Cass Class下的消息传递和偏函数实战解析

    王家林亲授<DT大数据梦工厂>大数据实战视频 Scala 深入浅出实战经典(1-87讲)完整视频.PPT.代码下载: 百度云盘:http://pan.baidu.com/s/1c0noOt ...

  3. Akka源码分析-Actor&ActorContext&ActorRef&ActorCell

    分析源码的过程中我们发现,Akka出现了Actor.ActorRef.ActorCell.ActorContext等几个相似的概念,它们之间究竟有什么区别和联系呢? /** * Actor base ...

  4. Akka源码分析-Actor发消息(续)

    上一篇博客我们分析道mailbox同时也是一个forkjointask,run方法中,调用了processMailbox处理一定数量的消息,然后最终调用dispatcher的registerForEx ...

  5. akka设计模式系列(Actor模型)

    谈到Akka就必须介绍Actor并发模型,而谈到Actor就必须看一篇叫做<A Universal Modular Actor Formalism for Artificial Intellig ...

  6. Akka源码分析-Actor创建(续)

    在上一遍博客中,我们已经分析了actor创建的大致过程,但只是涉及到了Dipatcher/Mailbox/ActorCell/InternalActorRef等对象的创建,并没有介绍我们自定义的继承A ...

  7. Akka源码分析-Actor发消息

    前面两篇文章简单介绍了ActorSystem.actor以及dispatcher和mailbox的创建,下面我们就来看一下actor发消息的内部机制. val system = ActorSystem ...

  8. Akka源码分析-Actor创建

    上一篇博客我们介绍了ActorSystem的创建过程,下面我们就研究一下actor的创建过程. val system = ActorSystem("firstActorSystem" ...

  9. scala并发编程原生线程Actor、Case Class下的消息传递和偏函数实战

    參考代码: import scala.actors._ case class Person(name:String,age:Int) class HelloActor extends Actor{ d ...

随机推荐

  1. XML编辑器之XMLSpy2005

    http://baike.baidu.com/link?url=79rnCuCnvoYJZHmQUBdc9INRvBTsWO_RYjWXgWI2sP1thb2WV5_6j_ygzInE7bdE7zaC ...

  2. 移动对meta的定义(转)

    以下是meta每个属性详解 尤其要注意的是content里多个属性的设置一定要用分号+空格来隔开,如果不规范将不会起作用. 一.<meta http-equiv="Content-Ty ...

  3. Android Fragment之间传递List数据

    要说的是在两个Fragment之间传递List数据,比如有个List<User>,以及传递字符串数据,比如testId,该如何从FragmentA传递到FragmentB呢? 下面这个例子 ...

  4. python学习笔记——多进程间通信——Linux信号基础

    1 信号的基本描述 Signal信号(其全程为软中断信号)是Linux系统编程中非常重要的概念,信号是异步进程中通信的一种方式. 作用是通知进程发生了异步事件.进程之间可以调用系统来传递信号, 本身内 ...

  5. VS报:"dll标记为系统必备组件,必须对其进行强签名"错误

    问题: VS生成程序时,报“要将程序集“XX.dll”标记为系统必备组件,必须对其进行强签名.”错误. 解决方法: 1)在报错的解决方案中找到一个可以发布的项目(引用该XX.dll的项目未必可以发布) ...

  6. 在QML应用中实现threading多任务

    在这个样例中,我们将介绍怎样在QML应用中使用QML语言提供的threading功能,实现多任务. 很多其它的阅读在:http://doc.qt.io/qt-5/qtquick-threading-e ...

  7. GDI+ 怎样将图片绘制成圆形的图片

    大概意思就是不生成新的图片,而是将图片转换为圆形图片. 实现代码例如以下: private Image CutEllipse(Image img, Rectangle rec, Size size) ...

  8. DNS与NS、NS记录

    DNS:人们习惯记忆域名,但机器间互相只认IP地址,域名与IP地址之间是一一对应的,它们之间的转换工作称为域名解析,域名解析需要由专门的域名解析服务器来完成,整个过程是自动进行的. 当你的网站制作完成 ...

  9. Mac - 使用php环境

    按下shift + Command + G  ,输入以下php(www)路径 /Library/WebServer/Documents 打开终端,输入以下命令打开环境 sudo apachectl s ...

  10. python map 详解

    python中的map函数应用于每一个可迭代的项,返回的是一个结果list.如果有其他的可迭代参数传进来,map函数则会把每一个参数都以相应的处理函数进行迭代处理.map()函数接收两个参数,一个是函 ...