我知道Clojure在多核计算机上运行良好,但我想知道它是否适用于在多台计算机上分布的JVM集群?
解决方法
Runa考虑使用Terracotta,最终将
swarmiji作为分布式代理库发布.
SMP系统和群集之间的真正区别之一是共享内存.在集群中,代码必须要求数据,而在SMP中,它可以直接读取数据.这有一些很好的优点和一些(缩放)缺点.
Clojure的STM与其他许多STM系统相差很大,它建立在相对时间的概念之上,这个概念是由每个事务的生成计数器测量的.如果没有对这一代计数器的共同访问,它就不能给事件一个订单,也不能完成它的工作(请原谅这个过于简单的解释).
STM的主要动机之一是创建一个真正利用共享内存并发性的系统,例如,确保读者永远不会等待作者和读者始终看到有效数据.因为这是为了利用共享内存而构建的,所以它在没有共享内存的情况下会失去很大的吸引力.
actor模型(ala Erlang)更适合分布式计算.
或者,换句话说:也许我们不应该试图在分布式并发洞中放置方形钉.