上一篇我们简介了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. [转]MegCup2015初赛题

    原文链接 门票题:数独有多少种对解线上没有1的填法? 这道"门票题"虽说只是"热身",但还是有一定难度的.共有245名选手通过各种方法拿到了门票.下面,我们就为 ...

  2. CSS:使用CSS3将一个div水平和垂直居中显示

    使用css3将一个div水平和垂直居中显示 方案一: div绝对定位水平垂直居中[margin:auto实现绝对定位元素的居中], 代码两个关键点:1.上下左右均0位置定位: 2.margin: au ...

  3. VMware workstation 与 VMware GSX Server 的区别

    http://xsagaplus.iteye.com/blog/358917VMware是提供一套虚拟机解决方案的软件,主要产品分为如下三个. VMware-ESX-Server  这个版本并不需要操 ...

  4. WebApi和MVC的区别

    使用上区分,mvc主要用于建站,web api主要用于构建http服务,当然你非要用mvc来构建Uri式的Api也行,不过显然是没有这个必要的,一个不恰当的比喻就像是你也可以玩破解版的单机游戏,也可以 ...

  5. Fix-Mapped Addresses

    一.前言 某天,wowo同学突然来了一句:如果要在start_kernel中点LED,ioremap在什么时间点才能调用呢?我想他应该是想通过点LED灯来调试start_kernel之后的初始化的代码 ...

  6. winform dataGridView DataGridViewComboBoxColumn 下拉框事件

    有一个dataGridView ,有一列是DataGridViewComboBoxColumn .用动态绑定,在绑定数据的时候.我们也给这一列绑定数据 在dataGridView的RowsAdded事 ...

  7. python标准库介绍——5 re模块详解

    == re 模块== "Some people, when confronted with a problem, think 'I know, I'll use regular expres ...

  8. 禁止用户使用密码的方式登录服务器,让其使用key的方式登录

    这里我的远程登录工具xshell 所以这里我要做的是 第一步是在xshell中配置公私钥 密钥类型选择为rsa,长度为2048,并点击下一步,如下所示: 继续下一步 如果给密钥设置了密码,那么在使用这 ...

  9. angularJS双向绑定和依赖反转

    一.双向绑定: UI<-->数据 数据->UI (数据改变UI跟着变) UI->数据 (UI改变数据跟着变) 数据改变->UI改变原理: 监听数据是否改变,如果改变更新U ...

  10. Mysql 操作命令 详解

    目的:1. 掌握mysql的安装,建库.建表.表的三种基本操作.查询.多表查询.数据库的备份与恢复2. MYSQL 服务器的简单维护3. mysql+apache+php的环境搭建 一.如何安装mys ...