gpt4 book ai didi

java - 在 Hazelcast 中面对客户端-服务器的性能问题

转载 作者:行者123 更新时间:2023-12-02 11:42:29 24 4
gpt4 key购买 nike

我面临配置为客户端-服务器的 hazelcast 的性能问题。
我有一个由 5 个节点和 1 个主节点组成的 K8S 集群。每个节点有 64 GB 的 RAM 和 16 核(Hazelcast 版本 3.12.4)
Hazelcast 服务器部署在 K8S 上,在集群中可用的节点之一上有一个 POD
我的客户端部署在 K8S 上,它通过智能客户端连接到 Hazelcast 之上(为 K8S 启用了 Hazelcast 发现)。我的应用程序总共有 10 个 POD,每个节点由我的应用程序的 2 个 POD 组成。

我正在运行不同的 API 并对我的应用程序执行负载测试(一次大约 110 个线程在所有 10 个 POD 之间共享)

我的应用程序中有以下代码来获取缓存。

public Map<Object, Object> get(String cacheId, Long lTenantId) {
String strMethodName="get";
long t1 = System.currentTimeMillis();
Map<Object,Object> cacheDataMap=hazelcastInstance.getMap(cacheId);
long totalTimeTaken = (System.currentTimeMillis()-t1);
if(totalTimeTaken > 10){
logger.warnLog(CLASSNAME, strMethodName,"Total time taken by "+cacheId+" identifier for get operation is : "+totalTimeTaken+" ms");
}
return cacheDataMap;
}

我的应用程序使用此 map 的方式各不相同

1)
map.get(key);

2)
Set keys = map.keySet();
Iterator iterator = keys.iterator(); //I changed to keyset iterator because entryset was causing lot of performance issues
while (iterator.hasNext()) {
// doing stuff
}

当我的所有 API 都为 Load 启动时,我将这些日志打印在应用程序中(所花费的总时间......),其中每个缓存访问时间 > 10 毫秒,这会导致性能问题,因此我无法实现我想要的所有 API 的 TPS。

缓存中存储了大约 300 个 map ,缓存的总大小为 4.22 MB

我正在使用近缓存配置,并且在管理中心上它显示为 100% 的有效性。 (这是在启用 hazelcast.client.statistics.enabled 时拍摄的)。

我还尝试在 Hazelcast 服务器的 4 个节点和 1 个专用节点上部署 8 个 POD,但问题仍然存在。当我将 Hazelcast 连接为嵌入式时没有观察到任何问题,并且我能够为所有 API 实现我想要的 TPS。

我是否缺少导致此问题的任何配置或任何其他内容?

这是我的 hazelcast-client.xml
<hazelcast-client
xmlns="http://www.hazelcast.com/schema/client-config"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://www.hazelcast.com/schema/client-config
http://hazelcast.com/schema/client-config/hazelcast-client-config-3.11.xsd">

<group>
<name>dev</name>
</group>
<instance-name>hazelcast</instance-name>
<properties>
<property name="hazelcast.client.shuffle.member.list">true</property>
<property name="hazelcast.client.heartbeat.timeout">600000</property>
<property name="hazelcast.client.heartbeat.interval">180000</property>
<property name="hazelcast.client.event.queue.capacity">1000000</property>
<property name="hazelcast.client.invocation.timeout.seconds">120</property>
<property name="hazelcast.client.statistics.enabled">false</property>
<property name="hazelcast.discovery.enabled">true</property>
<property name="hazelcast.map.invalidation.batch.enabled">false</property>
</properties>

<network>
<discovery-strategies>
<discovery-strategy enabled="true"
class="com.hazelcast.kubernetes.HazelcastKubernetesDiscoveryStrategy">
<properties>
<property name="service-name"><service-name></property>
<property name="namespace"><namespace></property>
</properties>
</discovery-strategy>
</discovery-strategies>
<smart-routing>true</smart-routing>
<redo-operation>true</redo-operation>
<connection-timeout>90000</connection-timeout>
<connection-attempt-period>100</connection-attempt-period>
<connection-attempt-limit>0</connection-attempt-limit>

</network>

<near-cache name="default">
<in-memory-format>OBJECT</in-memory-format>
<serialize-keys>true</serialize-keys>
<invalidate-on-change>true</invalidate-on-change>
<eviction eviction-policy="NONE" max-size-policy="ENTRY_COUNT"/>
</near-cache>
</hazelcast-client>

这是我的 hazelcast.xml
<?xml version="1.0" encoding="UTF-8"?>

<hazelcast xsi:schemaLocation="http://www.hazelcast.com/schema/config hazelcast-config-3.11.xsd"
xmlns="http://www.hazelcast.com/schema/config"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">

<management-center enabled="${hazelcast.mancenter.enabled}">${hazelcast.mancenter.url}</management-center>

</hazelcast>

最佳答案

缓存的目标是尽可能快地从键中获取值。通常,您已经拥有 key ,并请求该值。这意味着您向任何节点发送请求,这会在分区表中查找键所属的分区,并将查询转发到相关节点。

在您的第二个用例中,您尝试从所有节点获取所有 key :

Set keys = map.keySet();
Iterator iterator = keys.iterator();
while (iterator.hasNext()) {
// doing stuff
}

为了尽快返回,Hazelcast 将返回 Iterator 的惰性实现。 .每次调用 next() ,首先需要按照上述过程检索 key 。另外,我假设 // doing stuff代码实际上从键加载值。

总之,请不惜一切代价避免使用 map.keySet() .除非我对您的上下文和用例有更多了解,否则很遗憾,我无法提供相关的替代方案。

关于java - 在 Hazelcast 中面对客户端-服务器的性能问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/61870419/

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