Skip to content

Commit

Permalink
TEZ-4250: Optimise TaskImpl::getCounters.
Browse files Browse the repository at this point in the history
Change-Id: I7db4db3a4d2cb70f2e1d96fbaa2f853524fbce8a
  • Loading branch information
ayushtkn committed Jun 21, 2023
1 parent d20f334 commit 3056107
Show file tree
Hide file tree
Showing 4 changed files with 32 additions and 6 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -108,6 +108,10 @@ public default void aggrAllCounters(CounterGroupBase<T> rightGroup) {
incrAllCounters(rightGroup);
}

public default void setAllCounters(CounterGroupBase<T> rightGroup) {
incrAllCounters(rightGroup);
}

@Private
/**
* Exposes the underlying group type if a facade.
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -21,6 +21,7 @@
import java.util.List;
import java.util.concurrent.atomic.AtomicBoolean;

import com.google.common.annotations.VisibleForTesting;
import org.apache.hadoop.yarn.api.records.Container;
import org.apache.hadoop.yarn.api.records.ContainerId;
import org.apache.hadoop.yarn.api.records.NodeId;
Expand Down Expand Up @@ -63,13 +64,20 @@ public void setLocalityCounter(DAGCounter localityCounter) {
}
}
}

@VisibleForTesting
public void setCounters(TezCounters counters) {
this.counters = counters;
}
}

Task getTask();
TaskAttemptReport getReport();
List<String> getDiagnostics();
TaskAttemptTerminationCause getTerminationCause();
TezCounters getCounters();
@VisibleForTesting
void setCounters(TezCounters counters);
float getProgress();
TaskAttemptState getState();
TaskAttemptState getStateNoLock();
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -654,6 +654,17 @@ public TezCounters getCounters() {
readLock.unlock();
}
}

@VisibleForTesting
@Override
public void setCounters(TezCounters counters) {
writeLock.lock();
try {
reportedStatus.setCounters(counters);
} finally {
writeLock.unlock();
}
}

TaskStatistics getStatistics() {
return this.statistics;
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -465,15 +465,19 @@ public TaskReport getReport() {

@Override
public TezCounters getCounters() {
TezCounters counters = new TezCounters();
counters.incrAllCounters(this.counters);
TezCounters counters = null;
if (getVertex().isSpeculationEnabled()) {
counters = new TezCounters();
counters.incrAllCounters(this.counters);
}
readLock.lock();
try {
TaskAttempt bestAttempt = selectBestAttempt();
if (bestAttempt != null) {
if (bestAttempt != null && counters != null) {
counters.incrAllCounters(bestAttempt.getCounters());
return counters;
}
return counters;
return (bestAttempt != null) ? bestAttempt.getCounters() : TaskAttemptImpl.EMPTY_COUNTERS;
} finally {
readLock.unlock();
}
Expand Down Expand Up @@ -1522,10 +1526,9 @@ public void transition(TaskImpl task, TaskEvent event) {
void setCounters(TezCounters counters) {
try {
writeLock.lock();
this.counters = counters;
selectBestAttempt().setCounters(counters);
} finally {
writeLock.unlock();
}
}

}

0 comments on commit 3056107

Please sign in to comment.