HDFS-15892. Add metric for editPendingQ in FSEditLogAsync (#2770)
Signed-off-by: Takanobu Asanuma <tasanuma@apache.org>
(cherry picked from commit 4bd04126d6
)
This commit is contained in:
parent
5458ebf607
commit
d566e4e41d
|
@ -216,6 +216,7 @@ Each metrics record contains tags such as ProcessName, SessionId, and Hostname a
|
||||||
| `EditLogTailIntervalNumOps` | Total number of intervals between edit log tailings by standby NameNode |
|
| `EditLogTailIntervalNumOps` | Total number of intervals between edit log tailings by standby NameNode |
|
||||||
| `EditLogTailIntervalAvgTime` | Average time of intervals between edit log tailings by standby NameNode in milliseconds |
|
| `EditLogTailIntervalAvgTime` | Average time of intervals between edit log tailings by standby NameNode in milliseconds |
|
||||||
| `EditLogTailInterval`*num*`s(50/75/90/95/99)thPercentileLatency` | The 50/75/90/95/99th percentile of time between edit log tailings by standby NameNode in milliseconds (*num* seconds granularity). Percentile measurement is off by default, by watching no intervals. The intervals are specified by `dfs.metrics.percentiles.intervals`. |
|
| `EditLogTailInterval`*num*`s(50/75/90/95/99)thPercentileLatency` | The 50/75/90/95/99th percentile of time between edit log tailings by standby NameNode in milliseconds (*num* seconds granularity). Percentile measurement is off by default, by watching no intervals. The intervals are specified by `dfs.metrics.percentiles.intervals`. |
|
||||||
|
| `PendingEditsCount` | Current number of pending edits |
|
||||||
|
|
||||||
FSNamesystem
|
FSNamesystem
|
||||||
------------
|
------------
|
||||||
|
|
|
@ -28,6 +28,8 @@ import java.util.concurrent.Semaphore;
|
||||||
import java.util.concurrent.atomic.AtomicBoolean;
|
import java.util.concurrent.atomic.AtomicBoolean;
|
||||||
import java.util.concurrent.atomic.AtomicInteger;
|
import java.util.concurrent.atomic.AtomicInteger;
|
||||||
|
|
||||||
|
import org.apache.hadoop.hdfs.server.namenode.metrics.NameNodeMetrics;
|
||||||
|
import org.apache.hadoop.util.Time;
|
||||||
import org.slf4j.Logger;
|
import org.slf4j.Logger;
|
||||||
import org.slf4j.LoggerFactory;
|
import org.slf4j.LoggerFactory;
|
||||||
import org.apache.hadoop.conf.Configuration;
|
import org.apache.hadoop.conf.Configuration;
|
||||||
|
@ -53,6 +55,8 @@ class FSEditLogAsync extends FSEditLog implements Runnable {
|
||||||
// of the edit log buffer - ie. a sync will eventually be forced.
|
// of the edit log buffer - ie. a sync will eventually be forced.
|
||||||
private final Deque<Edit> syncWaitQ = new ArrayDeque<Edit>();
|
private final Deque<Edit> syncWaitQ = new ArrayDeque<Edit>();
|
||||||
|
|
||||||
|
private long lastFull = 0;
|
||||||
|
|
||||||
FSEditLogAsync(Configuration conf, NNStorage storage, List<URI> editsDirs) {
|
FSEditLogAsync(Configuration conf, NNStorage storage, List<URI> editsDirs) {
|
||||||
super(conf, storage, editsDirs);
|
super(conf, storage, editsDirs);
|
||||||
// op instances cannot be shared due to queuing for background thread.
|
// op instances cannot be shared due to queuing for background thread.
|
||||||
|
@ -188,6 +192,11 @@ class FSEditLogAsync extends FSEditLog implements Runnable {
|
||||||
if (!editPendingQ.offer(edit)) {
|
if (!editPendingQ.offer(edit)) {
|
||||||
Preconditions.checkState(
|
Preconditions.checkState(
|
||||||
isSyncThreadAlive(), "sync thread is not alive");
|
isSyncThreadAlive(), "sync thread is not alive");
|
||||||
|
long now = Time.monotonicNow();
|
||||||
|
if (now - lastFull > 4000) {
|
||||||
|
lastFull = now;
|
||||||
|
LOG.info("Edit pending queue is full");
|
||||||
|
}
|
||||||
if (Thread.holdsLock(this)) {
|
if (Thread.holdsLock(this)) {
|
||||||
// if queue is full, synchronized caller must immediately relinquish
|
// if queue is full, synchronized caller must immediately relinquish
|
||||||
// the monitor before re-offering to avoid deadlock with sync thread
|
// the monitor before re-offering to avoid deadlock with sync thread
|
||||||
|
@ -225,15 +234,18 @@ class FSEditLogAsync extends FSEditLog implements Runnable {
|
||||||
public void run() {
|
public void run() {
|
||||||
try {
|
try {
|
||||||
while (true) {
|
while (true) {
|
||||||
|
NameNodeMetrics metrics = NameNode.getNameNodeMetrics();
|
||||||
boolean doSync;
|
boolean doSync;
|
||||||
Edit edit = dequeueEdit();
|
Edit edit = dequeueEdit();
|
||||||
if (edit != null) {
|
if (edit != null) {
|
||||||
// sync if requested by edit log.
|
// sync if requested by edit log.
|
||||||
doSync = edit.logEdit();
|
doSync = edit.logEdit();
|
||||||
syncWaitQ.add(edit);
|
syncWaitQ.add(edit);
|
||||||
|
metrics.setPendingEditsCount(editPendingQ.size() + 1);
|
||||||
} else {
|
} else {
|
||||||
// sync when editq runs dry, but have edits pending a sync.
|
// sync when editq runs dry, but have edits pending a sync.
|
||||||
doSync = !syncWaitQ.isEmpty();
|
doSync = !syncWaitQ.isEmpty();
|
||||||
|
metrics.setPendingEditsCount(0);
|
||||||
}
|
}
|
||||||
if (doSync) {
|
if (doSync) {
|
||||||
// normally edit log exceptions cause the NN to terminate, but tests
|
// normally edit log exceptions cause the NN to terminate, but tests
|
||||||
|
|
|
@ -85,6 +85,8 @@ public class NameNodeMetrics {
|
||||||
MutableGaugeInt blockOpsQueued;
|
MutableGaugeInt blockOpsQueued;
|
||||||
@Metric("Number of blockReports and blockReceivedAndDeleted batch processed")
|
@Metric("Number of blockReports and blockReceivedAndDeleted batch processed")
|
||||||
MutableCounterLong blockOpsBatched;
|
MutableCounterLong blockOpsBatched;
|
||||||
|
@Metric("Number of pending edits")
|
||||||
|
MutableGaugeInt pendingEditsCount;
|
||||||
|
|
||||||
@Metric("Number of file system operations")
|
@Metric("Number of file system operations")
|
||||||
public long totalFileOps(){
|
public long totalFileOps(){
|
||||||
|
@ -334,6 +336,10 @@ public class NameNodeMetrics {
|
||||||
blockOpsBatched.incr(count);
|
blockOpsBatched.incr(count);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void setPendingEditsCount(int size) {
|
||||||
|
pendingEditsCount.set(size);
|
||||||
|
}
|
||||||
|
|
||||||
public void addTransaction(long latency) {
|
public void addTransaction(long latency) {
|
||||||
transactions.add(latency);
|
transactions.add(latency);
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue