HDFS-16181. [SBN Read] Fix display of JournalNode metric RpcRequestCacheMissAmount (#3317)

Co-authored-by: wangzhaohui8 <wangzhaohui8@jd.com>

(cherry picked from commit 232fd7cae170de8c6b52c14841a47dca8735c6d2)
(cherry picked from commit 2f73ac1c14)
(cherry picked from commit 928dbac0a6)
This commit is contained in:
wangzhaohui 2021-09-16 00:56:51 +08:00 committed by Erik Krogen
parent f7ac747b6a
commit 9b63f601d3
2 changed files with 11 additions and 7 deletions

View File

@ -774,7 +774,7 @@ public class Journal implements Closeable {
.setEditLog(output.toByteString()) .setEditLog(output.toByteString())
.build(); .build();
} catch (JournaledEditsCache.CacheMissException cme) { } catch (JournaledEditsCache.CacheMissException cme) {
metrics.rpcRequestCacheMissAmount.add(cme.getCacheMissAmount()); metrics.addRpcRequestCacheMissAmount(cme.getCacheMissAmount());
throw cme; throw cme;
} }
} }

View File

@ -51,12 +51,7 @@ class JournalMetrics {
@Metric("Number of bytes served via RPC") @Metric("Number of bytes served via RPC")
MutableCounterLong bytesServedViaRpc; MutableCounterLong bytesServedViaRpc;
@Metric private MutableStat rpcRequestCacheMissAmount;
MutableStat rpcRequestCacheMissAmount = new MutableStat(
"RpcRequestCacheMissAmount", "Number of RPC requests unable to be " +
"served due to lack of availability in cache, and how many " +
"transactions away the request was from being in the cache.",
"Misses", "Txns");
@Metric("Number of RPC requests with zero edits returned") @Metric("Number of RPC requests with zero edits returned")
MutableCounterLong rpcEmptyResponses; MutableCounterLong rpcEmptyResponses;
@ -87,6 +82,11 @@ class JournalMetrics {
"syncs" + interval + "s", "syncs" + interval + "s",
"Journal sync time", "ops", "latencyMicros", interval); "Journal sync time", "ops", "latencyMicros", interval);
} }
rpcRequestCacheMissAmount = registry
.newStat("RpcRequestCacheMissAmount", "Number of RPC requests unable to be " +
"served due to lack of availability in cache, and how many " +
"transactions away the request was from being in the cache.",
"Misses", "Txns");
} }
public static JournalMetrics create(Journal j) { public static JournalMetrics create(Journal j) {
@ -149,4 +149,8 @@ class JournalMetrics {
public void incrNumEditLogsSynced() { public void incrNumEditLogsSynced() {
numEditLogsSynced.incr(); numEditLogsSynced.incr();
} }
public void addRpcRequestCacheMissAmount(long cacheMissAmount) {
rpcRequestCacheMissAmount.add(cacheMissAmount);
}
} }