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

Zub*_*air 6 clojure

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

Art*_*ldt 6

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

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

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

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

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

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


Joo*_*aat 5

并不是的.我的意思是,可以使它工作; 像Terracotta这样的东西声称能够在多个节点上分配逻辑JVM,但是clojure的STM /集合语义非常强烈地依赖于线程间内存共享,以便在空间和时间上高效.

您最好使用消息传递或面向批处理的体系结构来处理系统的多节点部分.