EJB或Pojo旨在执行一项任务。 该模型将对象提升为无状态(尽管允许状态完整会话Bean),以便能够处理不断增加的负载(又称可伸缩应用程序)。 整个业务功能请求将细分为多个Bean(Ejbs或Pojos)来处理信息。 Bean的结果将被汇总并提供给请求者。 此模型允许应用程序扩展。
现在,当需要将相同的模型应用于不使用EJB或应用程序服务器容器的Java应用程序时,一种或多种技术的可用选择是使用多线程编程。
使用线程需要更高水平的编程技能,因为处理状态,锁,互斥等并非易事。 从Java EE 1.4开始,引入了关于ExecutionContext和Java 1.5起的并发数据结构库( java.util.concurrent )的较新API。 这使程序员可以编写可分解为较小任务并在基础线程上并行运行的程序。
对于普通的Java程序员来说,编写可以将大进程分解为较小的任务并并行运行这些任务以利用多个内核的多线程程序并不容易。 Akka团队使用Actor模型将整个概念抽象到另一架飞机上,在那里编写并行处理任务的程序成为灌篮。 Akka抽象模型允许程序员编写程序以利用多个内核并并行处理数百个任务。 Akka团队借鉴了ERlang的概念和技术来构建“让它崩溃”容错模型,以使应用程序快速失败并尽快从失败中恢复。
Akka提供了可扩展的实时事务处理库,该库使您的应用程序可以扩展,扩展和具有容错能力。
参考: 什么是Akka? 来自我们的JCG合作伙伴 Mukka K Gupta在Akka Essentials博客上。
翻译自: https://www.javacodegeeks.com/2012/03/what-is-akka.html