Aaron Stannard谈Akka.NET 1.1

Akka.NET 1.1近日发布,带来新特性和性能提升。InfoQ采访了Akka.net维护者Aaron Stannard,了解更多有关Akka.Streams和Akka.Cluster的信息。Aaron还阐述了与Akka for JVM实现有关的路线图计划。

InfoQ:这个版本有什么突出的特性?

Aaron Stannard:Akka.NET 1.1的主要目标是将Akka.Cluster由Beta测试版程序包变成最终版(RTM)程序包。该版本还提供了测试工具,对在生产环境里运行Akka.NET集群的过程中可能出现的大量各种不同的网络场景进行了测试。

不 要低估我们付出的巨大努力;Akka.Cluster Beta测试版最初发布于2014年8月。所以,我们大约花了两年的时间开发Akka.Cluster,收集生产用户的反馈。在1.1版本开发的最后阶 段,我们主要是提升可靠性和集群系统的速度,以便它可以用于高可用工作负载。已经有银行、医疗保健提供商、能源生产商、船队和车队管理企业、SaaS企业 及其他许多用户在生产环境中使用了Akka.NET。Akka.Cluster是他们最希望看到其发布的东西。

1.1版本的另外一个突出的 特性是Akka.Streams的第一个Beta版本;该模块引入了一种使用Akka.NET构建响应式应用程序的全新方法,允许开发人员将一系列的异步 操作表示成大量可以互联和重用的流处理图。你可以从我们的文档中看到Akka.Streams图可能的样子。

InfoQ:Akka.Net 1.1带来了什么性能提升?

Stannard:最显著的性能提升包括:

  • 将所有Actor的内存占用减少了34%;
  • 将每个Akka.Remote连接(支撑Akka.Cluster网络连接的子系统)的吞吐量提高了5倍;
  • 改正了多处内存过度使用的地方,最明显的是日志系统;

虽然我们一直在不断地度量、测试、提升Akka.NET的性能,但是性能不是这个版本的真正目的。性能的提升源于我们找到了更为健壮的方法实现Akka.NET使用的部分内部构件。

InfoQ:在这个版本中,您最喜欢的特性是什么?

Stannard:说来真奇怪,在1.1版本中,我最喜欢的部分是一个和我无关的部分:Akka.Streams。

关 于Akka.Streams,真正引人注目的是,它让用户仅仅使用几行代码就可以简洁地表达复杂的工作流,包括传统上非常困难的并发编程问题,比如退避和 节流。在没有经验的情况下,我昨天使用Akka.Streams在几个小时的时间里就重写了WebCrawler Akka.Cluster演示程序中处理繁重任务的部分。我还使用一些内置的缓冲流解决了那个代码库中存在多年的节流问题。和第一次使用Actor一样, 第一次使用Akka.Streams也让我很激动:我意识到,我使用了一种以前从未使用过的全新的编程方法。

InfoQ:你们是如何制定路线图的?

Stannard:Akka.NET当前的路线图是由多个因素促成的;与原先的Akka for JVM实现一致就是一个重要因素。我们受益于他们的经验和用户报告的Bug,因此,遵循他们的实现有巨大的好处。

InfoQ:遵循Akka for JVM的实现方式让你们获得了哪些好处?

Stannard: 开发人员永远不要忘记,“生产时间(time-in-production)”是度量代码库健康情况及其思想的最有价值的指标。和专有的单业务线应用程序 相比,一个有着几千名用户、在几千台服务器上7x24小时运行的大型开源项目,其在生产环境中累计运行的时间会更多。那意味着,更多的Bug、设计缺陷会 更快地被发现,生产力就可以获得更频繁地改进。这就可以解释,为什么在Daily WTF上有关可怕的代码炸弹的文章中,几乎所有多年未能发现的代码炸弹都是来自用途单一的专有代码或者应用不广泛的开源软件。这就是为什么我们要设法遵循 Akka for JVM的思路——他们的设计来源于在生产环境中长时间的运行。

InfoQ:你们的路线图和Akka for JVM有什么不同?

Stannard:Akka.NET 本身已经在生产环境中使用了很长时间了。我们已经从客户那里获得我们自己的生产力改进/Bug/不同的想法。.NET和JVM生态系统的巨大差别也是我们 制定路线图时必须考虑的。例如,.NET开发人员特别喜欢依赖注入框架,而那在Scala开发中往往并不多见。那种差别会对路线图的制定产生影响,将来, 我们可能会选择设计不同于JVM的东西,例如让DI支持成为一等特性,而不是一个插件。

也有一些Akka for JVM中有的模块,我们并没有多大的兴趣移植——比如Apache Camel集成。我还没有见过哪家.NET工场用它。还有Akka.HTTP,这是一个我们多年来一直在开发的怪物级模块。我们近期内不会移植,因为相对 于我们现在要提供给用户的一切,它的价值较低。

一般而言,我们的用户往往在服务器端应用程序中使用Akka.NET。他们真正想要的是我们 的高可用(HA)模块,像Akka.Cluster、Persistence、Streams和Sharding,全部运行在Linux上的.NET Core上。所以接下来,影响我们路线图的主要任务可能是,Akka.NET提供对.NET Core的初步支持。

InfoQ:Akka.NET主要是C#的,但也有F# API。您在实现中使用了F#?

Stannard: 就我个人而言,我并不怎么用F#,但我正要改变那种情况。我维护我们的构建系统。该系统用F#编写,使用了FAKE。我大部分的F#使用经验都来自那里。 我正计划在不久的将来构建一些供Petabridge内部使用的应用程序,我考虑在Windows Azure Service Fabric上使用Suave及Akka.Cluster来实现。无疑,Akka.NET让我爱上了函数式编程。许多FP的基础概念,如模式匹配和“流迭 代(stream iteration)”,是Actor系统的主要部分。在任何.NET开发人员的职业发展中,F#都会自然地成为Akka.NET的下一个步骤。

Akka.NET是一个托管在GitHub上的开源项目。Akka.NET网站提供了详细的文档

原文地址:http://www.infoq.com/cn/news/2016/07/akka-dotnet

时间: 2024-11-05 13:04:36

Aaron Stannard谈Akka.NET 1.1的相关文章

如何成为优秀的程序员

Aaron Stannard是新创公司MarkedUp的CEO,他最近花费大量时间雇佣.评估很多不同的程序员,并和他们一起协作.在这个过程中他发现并总结了十种程序员无法意识到自己潜力的原因,意在让更多程序员发掘出自己的潜力,从而成为强大的程序员. Aaron 提到,他的公司中所使用的技术非常复杂,某些大型企业都很难掌握,所以对于想要加入团队的程序员来说,入门门槛非常高.因此,尽管他们非常仔细地雇佣新 人,但还是很难找到足够天才的程序员.于是,他总结出十种阻碍程序员职业生涯发展的行为,并据此来帮助

如何成为强大的程序员(转)

add by zhj:我怎么总感觉在说我啊,最切我要害的两点:分析瘫痪.羞于请求帮助.看来这两个问题有普通性啊,并不是我独有的,哈哈,看来我没有必要为此而过分自责了. 转变总是需要一个过程的,要给自己时间,不要太苛求自己,欲速则不达,当对自己的要求超过了自己的能力时往往会导致压力和焦虑,人在成功前总是会犯很多错的. 原文:http://www.aaronstannard.com/post/2013/02/06/10-Reasons-Why-Youe28099re-Failing-to-Reali

谈一谈几种处理 JavaScript 异步操作的办法

本文标签:   JavaScript 原生JavaScript优势 JavaScript异步 js的异步操作 回调函数 TensorFlow REST   服务器 引言 js的异步操作,已经是一个老生常谈的话题,关于这个话题的文章随便google一下都可以看到一大堆.那么为什么我还要写这篇东西呢?在最近的工作中,为了编写一套相对比较复杂的插件,需要处理各种各样的异步操作.但是为了体积和兼容性,不打算引入任何的pollyfill,甚至连babel也不允许使用,这也意味着只能以es5的方式去处理.使

Akka.net开发第一个分布式应用

Akka.net开发第一个分布式应用 系列主题:基于消息的软件架构模型演变 既然这个系列的主题是”基于消息的架构模型演变“,少不了说说Actor模型.Akka.net是一个基于Actor模型的分布式框架.如果你对分布式应用还非常陌生,当别人在谈”分布式“.”云计算“等名词时你感到茫然,那么本篇文章将带你进行一次分布式开发之旅. 一.什么是Actor模型 Actor模型由Carl Hewitt于上世纪70年代早期提出并在Erlang语言中得到了广泛应用,目的是为了解决分布式编程中一系列问题.其主要

使用Akka.net开发第一个分布式应用

系列主题:基于消息的软件架构模型演变 既然这个系列的主题是”基于消息的架构模型演变“,少不了说说Actor模型.Akka.net是一个基于Actor模型的分布式框架.如果你对分布式应用还非常陌生,当别人在谈”分布式“.”云计算“等名词时你感到茫然,那么本篇文章将带你进行一次分布式开发之旅. 一.什么是Actor模型 Actor模型由Carl Hewitt于上世纪70年代早期提出并在Erlang语言中得到了广泛应用,目的是为了解决分布式编程中一系列问题.其主要特点如下: 系统由Actor构成 Ac

走进京东金融:听过来人谈经验及技术干货

以「金融科技」定位的京东金融集团成立于2013年10月,逐步构建了供应链金融.消费金融.财富管理.众筹.证券.保险.支付.金融科技以及农村金融九大业务板块. 京东金融CEO陈生强表示,京东金融以数据为基础,以技术为手段,借力京东的场景和用户资源来做金融业务,这是自营金融业务.现在乃至未来,京东金融要做的是:遵从金融本质,以数据为基础,以技术为手段,为金融行业服务,从而帮助金融行业提升效率.降低成本.增加收入.这个定位就是金融科技. 京东金融这三年多,从无到有,从有到精,一路走来,背后定有许多精彩

STL之父Stepanov谈泛型编程的发展史

这是一篇Dr. Dobb's Journal对STL之父stepanov的采访.文中数次提到STL的基本思想.语言的特性.编程的一些根本问题等,非常精彩.这篇文章让我想去拜读下stepanov的大作<Elements of Programming>了.原文链接: http://www.stepanovpapers.com/drdobbs-interview.html 我先对文章内容做下总结,并在最后附上原文,把一些认为重要又精彩的语句进行了标红. Stepanov讲到其关于“泛型编程”(gen

Akka(3): Actor监管 - 细述BackoffSupervisor

在上一篇讨论中我们谈到了监管:在Akka中就是一种直属父子监管树结构,父级Actor负责处理直属子级Actor产生的异常.当时我们把BackoffSupervisor作为父子监管方式的其中一种.实际上BackoffSupervisor与定义了supervisorStrategy的Actor有所不同.我们应该把BackoffSupervisor看作是一个一体化的Actor.当然,它的实现方式还是由一对父子Actor组成.监管策略(SupervisorStrategy)是在BackoffSuperv

akka设计模式系列-actor锚定

actor锚定模式是指使用actorSelection对acor进行锚定的设计模式,也可以说是一个对actor的引用技巧.在某些情况下,我们可能需要能够根据Actor的path锚定对应的实例.简单来说就是,无论actor是因为异常导致的restart还是用户主动stop,然后再重新actorOf,只要actor的路径和name相同,我们都希望把消息发送给改Actor的一个实例.那我们来看一下actorSelection和ActorRef的使用区别. class AnchorActor exten