akka的介绍_Akka笔记–演员介绍

akka的介绍

过去做过多线程的任何人都不会否认管理多线程应用程序有多么艰辛和痛苦。 我说管理是因为它开始很简单,一旦您开始看到性能改进,它就会变得非常有趣。 但是,当您发现没有一种简单的方法可以从子任务中的错误或难以发现的僵尸错误中恢复时,或者当您的探查器显示您的线程花费大量时间阻塞时,它会感到疼痛在写入共享状态之前浪费时间。

我不想谈论Java并发API及其集合如何使其变得越来越好,因为我确定如果您在这里,您可能需要对子任务进行更多控制,或者仅仅是因为您不喜欢编写锁和同步块,并希望更高层次的抽象。

在本系列的Akka Notes中,我们将通过简单的Akka示例来探索工具包中的各种功能。

什么是演员?

Akka的演员遵循演员模型 (duh!)。

像演员一样对待演员。 不亲自交谈的人。 他们只是通过邮件交谈。

让我们对此进行扩展。

1.消息传递

考虑两个人–一个明智的老师和学生。 学生每天早上都会向老师发送一封邮件,而明智的老师会发回明智的报价。

注意事项:

  1. 学生发送邮件。 一旦发送,邮件将无法编辑。 谈论自然不变性。
  2. 老师在需要时检查他的邮箱。
  3. 教师还会发回邮件(再次不变)。
  4. 学生可以自己检查邮箱。
  5. 学生不用等待答复。 (无阻塞)

这几乎总结了Actor模型的基本组成部分-传递消息。

Akka消息

2.并发

现在,假设有3位明智的老师和3位学生–每个学生都会向其他老师发送笔记。 那会发生什么呢? 实际上没有任何变化。 每个人都有自己的邮箱。 这里需要注意的一个细微之处是:

默认情况下,邮箱中的邮件按照到达的顺序进行读取/处理。

在内部,默认情况下是ConcurrentLinkedQueue 。 而且由于没有人等待邮件被提取,因此它只是一个无阻塞的消息。 (有多种内置邮箱,包括有界邮箱和基于优先级的邮箱 。实际上,我们也可以自己构建邮箱 )

Akka并发

3.故障转移

想象一下,这3名老师来自历史,地理和哲学三个部门。

历史老师回覆过去的事件记录,地理老师则寄给我一个有趣的地方,哲学老师则引述一段话。 每个学生向每个老师发送消息并获得答复。 学生不在乎该部门的哪个老师将答复发回。 如果有一天老师生病怎么办? 必须至少有一位老师来处理部门的邮件。 在这种情况下,该部门的另一位老师会加强工作。

Akka故障转移

注意事项:

  1. 可能会有一群演员在做不同的事情。
  2. 演员可能会做一些导致异常的事情。 它无法自行恢复。 在这种情况下,可以created一个新的Actor来代替旧的Actor。 或者,Actor可以忽略该一条特定消息,然后继续处理其余消息。 这些称为指令,我们将在后面讨论。

4.多任务

有所不同的是,假设学生要求的话,这些老师中的每一个也都会通过邮件发送考试成绩。 同样,演员可以舒适地处理多种type的消息。

5.链接

如果学生只想收到一封最终的综合琐事邮件而不是三封怎么办?

我们也可以通过Actors做到这一点。 我们可以将教师链接为一个层次结构。 稍后我们将讨论主管,然后再回到有关期货的话题上来。

根据Mohan的要求,让我们尝试将类比组件与Actor模型中的组件进行映射。

AkkaComponentMatching

学生和老师成为我们的Actors 。 电子邮件收件箱将成为Mailbox组件。 请求和响应无法修改。 它们是immutable对象。 最后,Actor中的MessageDispatcher组件管理邮箱并将消息路由到相应的Mailbox

聊够了,让我们编写一些代码…。

翻译自: https://www.javacodegeeks.com/2014/09/akka-notes-introducing-actors.html

akka的介绍

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/339915.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

使用模拟进行测试

如果使用正确的方法,模拟对象将非常有用。 我在需要驱动软件开发使用的帖子中分享了一些使用Mock Objects的经验。 在这篇文章中,我分享了两件事 –使用模拟进行基于合同的测试。 –用于组织模拟代码的模式。 基于合同的测试 让我们以正在构建汇款服…

aws s3 獲取所有文件_AWS SA associate 证书考试学习记录-EBS,S3,EFS比较

我们的目标,就是花最少的时间,学到最多的东西:-)在AWS中,可以选择的存储服务很多,纷繁复杂,新手根本弄不清楚选择哪个。因为做为一个云架构师,你并不是让你的产品能用就够了&#xf…

html设置顶部对齐,HTML / CSS文本从div顶部对齐

首先,你需要修复你的CSS选择器 .你可以通过这种方式t write all those id .#content #main #services只需选择1个元素和他的孩子 .例如,如果你测试它,它将适用于你:#services .langelis .txt {width: 440px;height: auto;float: l…

hot编码 字符one_One Hot编码是什么?为什么要用它,什么时候用它?

作者:Rakshith Vasudev编译:ronghuaiyang导读当你在玩ML模型的时候,你会在任何地方遇到这个“One hot encoding”的术语。当你在玩ML模型的时候,你会在任何地方遇到这个“One hot encoding”术语。你可以看到一个one hot编码器的s…

CUBA 7.2 –有什么新功能?

CUBA平台的第七版向前迈出了一大步。 内部体系结构的改进和新的IDE为进一步改进奠定了良好的基础。 我们将继续添加新功能,以使开发人员的生活更轻松,并使他们的工作更加高效。 在7.2版中,我们引入了许多可能看起来像是主要更新的更改&#…

postgresql 分区视图_PostgreSQL架构集中式到分布式主流架构总结

文章目录一、PG未来主流架构为什么是分布式二、PostgreSQL集中式到分布式架构总结一、PG未来主流架构为什么是分布式如果说5年前DB的分布式还只是一种趋势,如今分布式数据库正逐渐从趋势变成主流。说到分布式,我想我们不能不提一下集中式和分库分表。01集…

html5 上传图片模板,HTML5实现图片文件异步上传

,过现前个能文使近记接的端问对字用近记接  利用HTML5的新特点做文件异步上传非常简单方便,本文主要展示JS部分,html结构。下面的代码并未使用第三发库,如果有参照,请注意一些未展现出来的代码片段。我这边的效果预览…

html中可以有两个h1,在一个HTML中h1标签能出现几次?h1标签和标题标签

首页 > web前端 > html教程 > 正文 在一个HTML中h1标签能出现几次?h1标签和标题标签的差别是什么? 2018-08-29 10:57:28本篇文章主要介绍了关于HTML h1标签的一些解释,有html h1标签和html title标签的区别,还有网页中h1…

Java中的记录类型

2020年3月发布的JDK 14引入了记录 (预览语言功能),这些记录提供了一种紧凑的语法来声明主要用于保存数据的类。 在记录中 ,所有低级,重复且容易出错的代码都类似于构造函数,访问器和通用方法,例…

山东省102021年普通高考成绩查询,山东高考成绩今日发布!成绩查询看这里!

原标题:山东高考成绩今日发布!成绩查询看这里!山东高考生注意啦~今天16:20举行山东2020年夏季高考第二次新闻发布会届时将会公布高考录取政策、分数线情况等今天17:00公布2020夏季高考与等级考成绩发布会怎么看?高考成绩怎样查&am…

使用SoapUI调用不同的安全WCF SOAP服务-基本身份验证,第二部分

在本系列的第一篇文章中,我们创建了一个基本的身份验证服务,以使用SoapUI进行调用。 因此,在第二篇文章中,我们将逐步演示如何使用此工具成功调用这种服务。 使用SoapUI的1-Basic WCF SOAP –创建新的SOAP项目 首先,我…

html table nei边框线,GitHub - meichuanneiku/TableCell: 在TableBank的基础上,进一步标注到单元格精度,利用目标检测/分割实现单元格定位。...

项目说明本项目是我2019年7月份的实习工作的**展示与记录**:把倾斜的表格旋转水平;制作5000张表格数据集,需要标注每一个单元格,并实现单元格检测第一项比较简单,仿射变换、透视变换已经很成熟了,关键是第二…

前缀命名

如果您是第一次查看Takes或Cactoos的源代码,则很可能会像其他名称一样被命名约定触发,这意味着大多数类名称都有两个字母的前缀: BkSafe , RqFake , RsWithStatus , TkGzip等。 老实说,我还没有…

再访PMML

嗨伙计! 从今年年初开始,就有了重新设计Drools PMML模块的计划。 在这篇文章中,我将描述我们将如何处理它,目前的状态,未来发展的想法等,等等……敬请期待! 背景 PMML是一个标准,旨…

用计算机怎么弹离人愁数字,拇指琴新手入门曲谱——离人愁

喜欢古风的朋友赶快凑过来啦,最近抖音上超火的离人愁拇指琴教学,喜欢离人愁的小姐姐小哥哥赶快学起来啦!以下琴谱适用于Hugh Tracey G调17键。南非琴出厂调音是G调排列,习惯了C调音阶排列的朋友可能对G调排列不是很适应。因为两者…

jvm7 jvm8_JVM PermGen –您在哪里?

jvm7 jvm8这篇文章介绍了JVM内存结构的一些基础知识,并快速窥视了PermGen,以了解自Java SE 8出现以来它已消失的地方。 裸基础 JVM只是系统上运行的另一个进程,魔术始于java命令。 像任何OS进程一样,它需要内存才能运行。 请记住…

C++类与对象(中)第二篇

前言: C语言中使用运算符是对内置类型的数据进行操作,但是在C中有了对象,导致对象无法通过运算符进行运算,故引入了运算符重载即需要重新定义这些运算符,赋予已有运算符新的功能,使它能够用于特定类型执行特…

ETL万岁

提取转换负载是用于从一个数据系统中提取数据并加载到另一个数据系统中的过程。 涉及的数据系统称为源系统和目标系统。 来自源系统的数据形状与目标系统不匹配,因此需要进行一些转换以使其兼容,该过程称为Transformation 。 转换是由map / filter / re…

云计算机内存不足怎么办,网易云音乐提示内存不足,电脑提示内存不足-

在有些时候我们的手机百度云提示内存不足了,这该怎么办呢?那么下面就由学习啦小编来给你们说说手机百度云提示内存不足的解决方法吧,希望可以帮到你们哦!手机百度云提示内存不足的解决方法一:手机用久了,需要安装杀毒软件&#x…

getter/setter_Getters / Setters。 邪恶。 期。

getter/setter从2003年开始,艾伦霍鲁布(Allen Holub)讨论了为什么吸气和塞特方法是邪恶的著名文章,关于吸气/塞特方法是否是反模式,应该避免使用,还是我们在面向对象中不可避免地需要它,这是一个…