简介
什么是AKKA?
Akka是一个开发库和运行环境,可以用于 构建高并发、分布式、可容错、事件驱动的基于JVM的应用。 使构建高并发的分布式应用更加容易。Akka是把Actor Model模型进行了封装。可以理解为,异步,非阻塞的一个消息传递。
Akka 是一个用 Scala 编写的库,用于简化编写容错的、高可伸缩性的 Java 和 Scala 的 Actor 模型应用。它已经成功运用在电信行业。系统几乎不会宕机(高可用性 99.9999999 % 一年只有 31 ms 宕机)。
Actor模型并非什么新鲜事物,它由Carl Hewitt于上世纪70年代早期提出,目的是为了解决分布式编程中一系列的编程问题。其特点如下:
系统中的所有事物都可以扮演一个Actor
Actor之间完全独立
在收到消息时Actor所采取的所有动作都是并行的,在一个方法中的动作没有明确的顺序
Actor由标识和当前行为描述
Actor可能被分成原始(primitive)和非原始(non primitive)类别
非原始Actor有
由一个邮件地址表示的标识
当前行为由一组知识(acquaintances)(实例变量或本地状态)和定义Actor在收到消息时将采取的动作组成
消息传递是非阻塞和异步的,其机制是邮件队列(mail-queue)
所有消息发送都是并行的
AKKA
特性
- 1Simple Concurrency & Distribution单并发性&分布式
- 2Resilient by Design
- 3HighPerformance高效
- 4Elastic & Decentralized
- 5 Extensible可扩展
Hello AKKA Demo
Akka for JAVA
由于AKKA是使用Scala编写的,而Scala是一种基于JVM的语言.因此JAVA对AKKA的支持也是很不错的.Akka自身又是采用微内核的方式来实现的,这就意味着能很容易的在自己的项目中应用AKKA,只需要引入几个akka的Lib包即可.而官方直接就提供了Maven库供我们在JAVA中使用AKKA.
这些AKKA的依赖包主要有:
akka-actor:最核心的依赖包,里面实现了Actor模型的大部分东西
akka-agent:代理/整合了Scala中的一些STM特性
akka-camel:整合了Apache的Camel
akka-cluster:akka集群依赖,封装了集群成员的管理和路由
akka-kernel:akka的一个极简化的应用服务器,可以脱离项目单独运行.
akka-osgi:对OSGI容器的支持,有akka的最基本的Bundle
akka-remote:akka远程调用
akka-slf4j:Akka的日志事件监听
akka-testkit:Akka的各种测试工具
akka-zeromq:整合ZeroMQ
其中最总要的就是akka-actor,最简单的AKKA使用的话,只需要引入这个包就可以了.