并发编程之akka简介

什么是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语言的比较与使用》

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值