Clojure的STM模型可以在多个JVM上运行吗?
发布时间:2020-12-15 02:49:47 所属栏目:Java 来源:网络整理
导读:我知道Clojure在多核计算机上运行良好,但我想知道它是否适用于在多台计算机上分布的JVM集群? 解决方法 Runa考虑使用Terracotta,最终将 swarmiji作为分布式代理库发布. SMP系统和群集之间的真正区别之一是共享内存.在集群中,代码必须要求数据,而在SMP中,它可
我知道Clojure在多核计算机上运行良好,但我想知道它是否适用于在多台计算机上分布的JVM集群?
解决方法
Runa考虑使用Terracotta,最终将
swarmiji作为分布式代理库发布.
SMP系统和群集之间的真正区别之一是共享内存.在集群中,代码必须要求数据,而在SMP中,它可以直接读取数据.这有一些很好的优点和一些(缩放)缺点. Clojure的STM与其他许多STM系统相差很大,它建立在相对时间的概念之上,这个概念是由每个事务的生成计数器测量的.如果没有对这一代计数器的共同访问,它就不能给事件一个订单,也不能完成它的工作(请原谅这个过于简单的解释). STM的主要动机之一是创建一个真正利用共享内存并发性的系统,例如,确保读者永远不会等待作者和读者始终看到有效数据.因为这是为了利用共享内存而构建的,所以它在没有共享内存的情况下会失去很大的吸引力. actor模型(ala Erlang)更适合分布式计算. 或者,换句话说:也许我们不应该试图在分布式并发洞中放置方形钉. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |