什么是akka
akka是一个用scala编写的库,用于简化编写可容错的,可扩展的,高并发应用。akka使用actor模型来提升抽象能力,提供更好的平台来构建可扩展的,弹性的应用。对于比较难处理的错误,akka采用“let it crash”模型来处理,这种模式可以使得一个任务的处理失败不会导致整个应用的crash,使你的系统拥有强大的自愈能力,也不需要重启来恢复系统。同时akka的分布式部署更加简单透明。
akka使用的两种方式
作为库使用:在大多数的web系统中,你可能更倾向与把akka作为一个jar包来使用,你可以直接把jar包拷贝到你的系统中,也可以通过maven依赖把jar包拉到你的项目项目中。
作为微核使用:作为独立service来部署应用。
为什么使用akka
akka是一个可扩展性非常强的软件,这不仅不仅体现在性能上,而且还体现在它可适用的系统规模上。akka的核心包akka-actor非常小,对于已有的需要异步和无锁并发的系统而言,很容易就可以把akka融入进去。akka适用的前景非常广泛,可使用于金融系统,游戏,医疗,交通,仿真,数据分析等等场景,只要需要高吞吐量、低延迟的系统,akka就是一个可供选择的对象。下面是akka的几个主要特性:
actor模型
actor模型并非什么新鲜事务,它早在20世纪70年代就被提出了,主要目的是为了解决分布式编程中的一系统问题。actor模型具有以下优点:
1.更简单的、高度抽象的并发处理。
2.异步的,非阻塞的,高性能的事件驱动编程模型
3.非常轻量级的事件驱动处理。kaka处理任务的模式是一个任务一个actor,而不是一个任务一个线程。相比创建一个线程对象所需要的庞大字段而言,创建一个actor的代价非常小,基本在300字节左右。1GB内存可以创建几百万actor。
错误容忍
使用“let-it-crash”模型处理错误。前面说了kaka处理任务的模式是一个任务一个actor,而不是一个任务一个线程。所有的actor在线程上运行。如果一个actor出错了,就让这个actor销毁好了,而不会影响运行它的线程,该线程可以继续处理其他任务。而如果基于一个任务一个线程的模式,一个错误可能导致线程死锁,异常中断等,进而导致整个系统crash。
可以跨多个jvm处理错误
强大的系统自愈能力,不需要重启系统
位置透明性
akka中所有的东西处理都是在分布式环境中,所有的actors之间的交互都是通过message来完成的,所有的事件都是异步的。所以一个actor不需要知道其他的actor的内部状态,运行方式,所处节点等等。
持久性
当一个actor正在启动或重启时,它接收到的消息将会保持住或者重新发送。这个机制使得actor在jvm崩溃或者该actor迁移到其他节点之后,仍然可以恢复自己的状态。
与java项目兼容
scala是jvm上运行的,akka库可以直接作为jar包在java项目中使用,而java作为目前排行前三的热门语言之一,无疑为akka的使用提供了丰富的场景。对于广大java开发者而言,降低了学习成本,也减少了项目改造的成本。另外,akka相对于go,erlang等热门并发语言而言,应该各有各的优点。关于akka与erlang的优劣,大家可以参考下《并发需求下的Scala及Erlang语言的比较与使用》。