加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程开发 > Java > 正文

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)更适合分布式计算.

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

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读