微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

Clojure的STM模型可以在多个JVM上运行吗?

我知道Clojure在多核计算机上运行良好,但我想知道它是否适用于在多台计算机上分布的JVM集群?

解决方法

@L_502_0@考虑使用Terracotta,最终将 swarmiji作为分布式代理库发布.

SMP系统和群集之间的真正区别之一是共享内存.在集群中,代码必须要求数据,而在SMP中,它可以直接读取数据.这有一些很好的优点和一些(缩放)缺点.

Clojure的STM与其他许多STM系统相差很大,它建立在相对时间的概念之上,这个概念是由每个事务的生成计数器测量的.如果没有对这一代计数器的共同访问,它就不能给事件一个订单,也不能完成它的工作(请原谅这个过于简单的解释).

STM的主要动机之一是创建一个真正利用共享内存并发性的系统,例如,确保读者永远不会等待作者和读者始终看到有效数据.因为这是为了利用共享内存而构建的,所以它在没有共享内存的情况下会失去很大的吸引力.

actor模型(ala Erlang)更适合分布式计算.

或者,换句话说:也许我们不应该试图在分布式并发洞中放置方形钉.

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。

相关推荐