BT

如何利用碎片时间提升技术认知与能力? 点击获取答案

Vaughn Vernon论Actor 模型和领域驱动设计

| 作者 Jan Stenberg 关注 34 他的粉丝 ,译者 赵震一 关注 0 他的粉丝 发布于 2013年6月19日. 估计阅读时间: 3 分钟 | QCon上海2018 关注大数据平台技术选型、搭建、系统迁移和优化的经验。

为了更好地把握新型多核机器带给我们的超大并发能力的机会,我们应该使用一种能帮助我们达成该目的的编程模型,而Actor模型带给了我们大量的工具来实现这一点。Implementing Domain-Driven Design一书的作者Vaughn Vernon在今年伦敦的DDD Exchange Day大会上对此进行了阐述

Actor模型之所以还没有流行起来的一个原因也许就是因为我们从未真正有过拥有超强并发计算能力机器的机会。而现在,我们的机器都拥有着大量的核。因为这些改变,我们对并发的规模和使用都将与从前截然不同。因此,Vaughn认为我们应该着眼于Actor模型,它可以给与我们大量的工具来达成我们的目的。

直接异步消息传递

由于Actor的消息是异步发送的,所以当一个actor向其他actor发送完消息后可以马上继续工作。唯一需要的便是消息接收者的地址,消息发送者可以通过创建actor或从已收到的消息中获取地址。

无锁并发(Lock Free Concurrency)

为了避免加锁,Actor模型通过加强队列来实现并发,这意味着一个actor同一时间只能处理一个消息,但是这无法确保消息接收的顺序。

无共享(Share nothing)

Actor是计算的主要单元,因此每个独立的actor将自己的状态完全封装,没有状态是共享的。Actor只能以不可变的方式返回数据。

Future与承诺

当查询以异步的方式传递后,结果将在将来的某个时间被异步返回。当消息被发送后,一个Future对象将立即返回,它代表了对结果的承诺。

Actor模型和领域驱动设计

Actor模型非常适合领域驱动设计,消息代表了通用语言(ubiquitous language)这一概念,并且使用aggregate来作为actor。消息可以直接发送到aggregate,而业务规则将适用于aggregate,而实体也将持久化在aggregate。这样也自然适用于在一个事务中应该只有一个aggregate被修改这一原则。Vaughn认为通过去除当今典型事件驱动架构中的部分复杂性将可以简化我们的实现。

Actor模型

在Actor模型中,每个对象都是一个具有邮箱(mailbox)和行为的actor,消息将通过邮箱在actor之间交换。Actor之间的通信都是异步执行的,并且没有状态共享。

今年早些时候,Eric Meijer 、Actor 模型的创造者Carl Hewitt以及Clemens Szyperski在白板前的一个站立交流中讨论并解释了Actor模型。

查看英文原文:Vaughn Vernon on the Actor Model and Domain-Driven Design

评价本文

专业度
风格

您好,朋友!

您需要 注册一个InfoQ账号 或者 才能进行评论。在您完成注册后还需要进行一些设置。

获得来自InfoQ的更多体验。

告诉我们您的想法

允许的HTML标签: a,b,br,blockquote,i,li,pre,u,ul,p

当有人回复此评论时请E-mail通知我
社区评论

允许的HTML标签: a,b,br,blockquote,i,li,pre,u,ul,p

当有人回复此评论时请E-mail通知我

允许的HTML标签: a,b,br,blockquote,i,li,pre,u,ul,p

当有人回复此评论时请E-mail通知我

讨论

登陆InfoQ,与你最关心的话题互动。


找回密码....

Follow

关注你最喜爱的话题和作者

快速浏览网站内你所感兴趣话题的精选内容。

Like

内容自由定制

选择想要阅读的主题和喜爱的作者定制自己的新闻源。

Notifications

获取更新

设置通知机制以获取内容更新对您而言是否重要

BT