写点什么

Aaron Stannard 谈 Akka.NET 1.1

  • 2016-07-28
  • 本文字数:2237 字

    阅读完需:约 7 分钟

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 网站提供了详细的文档

查看英文原文 Q&A on Akka.NET 1.1 with Aaron Stannard

2016-07-28 19:002650
用户头像

发布了 1008 篇内容, 共 422.7 次阅读, 收获喜欢 346 次。

关注

评论

发布
暂无评论
发现更多内容

如何写 Go 代码

Rayjun

Go 语言

该不该签竞业协议?

石云升

程序员 话题讨论 28天写作 职场经验 3月日更

《不看后悔》38个JVM精选问答,让你变成专家

Java 架构 面试 JVM虚拟机原理

Elasticsearch Index Types and Mappings

escray

elastic 七日更 28天写作 死磕Elasticsearch 60天通过Elastic认证考试 3月日更

Git 常用记录

Leo

git 大前端

互联网信贷风险与大数据 风险管理&信贷准入

张老蔫

28天写作

Flutter 2 来了

SamGo

flutter

总结近期腾讯+阿里+百度Java岗高频面试题,提问率高达98%,看到这篇文章基本offer稳了

Java架构之路

Java 程序员 架构 面试 编程语言

阿里面经最新分享:Java面试指南/成长笔记(金三银四程序员必备)

比伯

Java 编程 程序员 架构 面试

该死的端口占用!教你用 Shell 脚本一键干掉它!

星安果

Shell 脚本 shell脚本编写 端口 端口占用

架构大作业1

J

区块链电子合同应用平台-助力企业数字化转型

13530558032

【回溯算法】借助最后一道「组合总和」问题来总结一下回溯算法 ...

宫水三叶的刷题日记

面试 LeetCode 数据结构与算法

麻木得那么快应不应该——韦伯-费希纳定律

Justin

心理学 28天写作 游戏设计

LARAVEL SMTP 服务泄露,laravel env暴露

kaer

laravel 信息安全 漏洞 ENV SMTP

两会热词“区块链”,打开传统溯源的一扇大门!

源中瑞-龙先生

区块链 两会

【LeetCode】下一个更大元素 II Java题解

Albert

算法 LeetCode 28天写作

聊聊交易中台系统设计与思考

架构精进之路

中台 七日更

5个身份和访问管理的最佳实践

龙归科技

数字身份 身份认证 身份安全 统一身份认证

说完列表说字典,说完字典说集合,滚雪球学 Python

梦想橡皮擦

28天写作 3月日更

饿了么刚给我确认了p7的职位,对自己的经历,做一个面试总结。

Java架构之路

Java 程序员 架构 面试 编程语言

2021年阿里巴巴Java百亿级并发系统设计笔记(全彩版)

Java架构追梦

Java 阿里巴巴 面试 架构师 百亿级并发

智慧党建系统开发,智慧组工平台建设

13530558032

【金三银四】这才是打开Java面试的正确方式,吃透这份【Java面试手册】offer稳了

Java 编程 面试

微信团队分享:微信直播聊天室单房间1500万在线的消息架构演进之路

JackJiang

微信 架构设计 即时通讯

区块链药品溯源解决方案-区块链技术监管医药溯源

13530558032

正则表达式.01 - 元字符

insight

正则表达式 3月日更

进程调度算法

鲁米

算法

Spark性能调优-RDD算子调优篇(深度好文,面试常问,建议收藏)

五分钟学大数据

大数据 spark 28天写作 3月日更

程序员之禅(四)

每天读本书

读书笔记 每天读本书

架构大作业2

J

Aaron Stannard谈Akka.NET 1.1_.NET_Pierre-Luc Maheu_InfoQ精选文章