gpt4 book ai didi

java - Terracotta 在这种情况下如何工作?

转载 作者:塔克拉玛干 更新时间:2023-11-03 03:20:14 26 4
gpt4 key购买 nike

假设我有一个 N 大小的服务器阵列设置如下:

alt text http://www.terracotta.org/web/download/attachments/43909161/ServerArrayMirrorGroup.png

我有一个简单的 JavaBean/POJO:

package example;

public class Person {
private OtherObject obj;

public void setObj(OtherObject theObj) {
synchronized (this) {
obj = theObj;
}
}

public OtherObject getObj() {
synchronized (this) {
return obj;
}
}
}

现在,如果其中一个客户端在 TC 根(数据结构)中的 Person 对象上调用 Person.setObj(OtherObject),则同步块(synchronized block)(在 Person.setObj(OtherObject) 中)该客户持有:

1) 直到 N 大小的服务器阵列中的所有 N 服务器都已与该 Person.obj 属性同步/更新?

2) 在“Activity ”服务器与更新的 Person.obj 属性同步之前?那么阵列中的其他(N-1)台服务器是否尽可能同步?

3) 我忽略的其他方法?

最佳答案

答案实际上不是 1 或 2。对象跨服务器镜像组 strip 化。第一次设置此字段时,将创建一个事务,并且为第一个事务选择的镜像组将“拥有”此后的对象。

关于 1 和 2,并非所有 Activity 服务器组都需要更新,因此无需等待这些条件中的任何一个。

您可以在 Terracotta 文档中找到有关配置 Terracotta 服务器阵列的更多信息:

从锁定的角度来看,在执行对象修改时将持有此 Person 对象上的集群锁(跨集群互斥)。同步块(synchronized block)的作用域形成了上面提到的事务。在 getObj() 方法中,您可以将其配置为读锁,允许多个并发读取器跨集群。

关于java - Terracotta 在这种情况下如何工作?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/815243/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com