上一篇我们简介了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. Windows下面安装和配置Solr 4.9(二)

    将Solr和Tomcat结合: 1.在D盘下创建目录 D:\Demos\Solr 2.解压solr-4.9.0文件,我这里下载的是这个4.9版本,将example文件夹下的solr文件夹中的所有文件( ...

  2. oc 调用c语言方法和oc的方法调用

    //c语方的方法 void sayHello(){ printf("Hello OC"); } int main(int argc, char * argv[]) { sayHel ...

  3. linux内存回收机制

    无论计算机上有多少内存都是不够的,因而linux kernel需要回收一些很少使用的内存页面来保证系统持续有内存使用.页面回收的方式有页回写.页交换和页丢弃三种方式:如果一个很少使用的页的后备存储器是 ...

  4. explore your hadoop data and get real-time results

    deep api integration makes getting value from your big data easy 深度api集成使你大数据訪问更加easy Elasticsearch ...

  5. Python hypot() 函数

    描述 hypot() 返回欧几里德范数 sqrt(x*x + y*y). 语法 以下是 hypot() 方法的语法: import math math.hypot(x, y) 注意:hypot()是不 ...

  6. JAVA-day08 下午-总结、測试

    继承总结: class { public static void main(String[] args) { System.out.println("Hello World!"); ...

  7. CTPN - 训练

    源码地址:https://github.com/eragonruan/text-detection-ctpn 该地址提供了 CTPN 的 tf 版本的实现,代码文档写得很详细,issue 里面也帮助解 ...

  8. [swift]初始化方法自己主动继承

    子类默认不会继承父类的初始化方法,然而,假设某种条件满足的话.父类的初始化方法还是能够继承给子类.在通常情况下,这意味着你不必复写父类的初始化方法.在安全的前提下能够以最低的代价继承父类的初始化方法. ...

  9. js replace 与replaceall实例用法详解

    这篇文章介绍了js replace 与replaceall实例用法详解,有需要的朋友可以参考一下stringObj.replace(rgExp, replaceText) 参数 stringObj 必 ...

  10. [gj]HK一行所见闻

    香港一行 20多年来,未未去过HK,前段时间由于工作关系去了趟HK.感触良多. 一清早,福田过关,做火车,做地铁,一通到了目的地. 总结对那边的印象: 1,所有人都是粤语,包括工作交流.而且他们不怎么 ...