Skip to content

Commit

Permalink
Add some log for table and db transaction manager's lock
Browse files Browse the repository at this point in the history
  • Loading branch information
liulijia committed Sep 12, 2024
1 parent 172bf4e commit c8b9a6a
Show file tree
Hide file tree
Showing 2 changed files with 57 additions and 4 deletions.
46 changes: 46 additions & 0 deletions fe/fe-core/src/main/java/org/apache/doris/catalog/Table.java
Original file line number Diff line number Diff line change
Expand Up @@ -19,6 +19,7 @@

import org.apache.doris.alter.AlterCancelException;
import org.apache.doris.analysis.CreateTableStmt;
import org.apache.doris.common.Config;
import org.apache.doris.common.DdlException;
import org.apache.doris.common.MetaNotFoundException;
import org.apache.doris.common.io.Text;
Expand Down Expand Up @@ -73,6 +74,8 @@ public abstract class Table extends MetaObject implements Writable, TableIf {
protected TableType type;
protected long createTime;
protected QueryableReentrantReadWriteLock rwLock;
private final ThreadLocal<Long> lockReadStart = new ThreadLocal<>();
private long lockWriteStart;

/*
* fullSchema and nameToColumn should contains all columns, both visible and shadow.
Expand Down Expand Up @@ -146,6 +149,7 @@ public void unmarkDropped() {

public void readLock() {
this.rwLock.readLock().lock();
lockReadStart.set(System.currentTimeMillis());
}

public boolean tryReadLock(long timeout, TimeUnit unit) {
Expand All @@ -155,6 +159,9 @@ public boolean tryReadLock(long timeout, TimeUnit unit) {
LOG.warn("Failed to try table {}'s read lock. timeout {} {}. Current owner: {}",
name, timeout, unit.name(), rwLock.getOwner());
}
if (res) {
lockReadStart.set(System.currentTimeMillis());
}
return res;
} catch (InterruptedException e) {
LOG.warn("failed to try read lock at table[" + name + "]", e);
Expand All @@ -163,11 +170,16 @@ public boolean tryReadLock(long timeout, TimeUnit unit) {
}

public void readUnlock() {
if (lockReadStart.get() != null) {
checkAndLogLockDuration("read", lockReadStart.get(), System.currentTimeMillis());
lockReadStart.remove();
}
this.rwLock.readLock().unlock();
}

public void writeLock() {
this.rwLock.writeLock().lock();
lockWriteStart = System.currentTimeMillis();
}

public boolean writeLockIfExist() {
Expand All @@ -176,16 +188,49 @@ public boolean writeLockIfExist() {
this.rwLock.writeLock().unlock();
return false;
}
lockWriteStart = System.currentTimeMillis();
return true;
}

private void checkAndLogLockDuration(String type, long lockStart, long lockEnd) {
long duration = lockEnd - lockStart;
if (duration > Config.lock_reporting_threshold_ms) {
StringBuilder msgBuilder = new StringBuilder();
msgBuilder.append(getId())
.append(" ")
.append(getName())
.append(" ")
.append(type)
.append(" lock is held at ")
.append(lockStart)
.append(".And release after ")
.append(duration)
.append(" ms.")
.append("Call stack is :\n")
.append(getStackTrace(Thread.currentThread()));
LOG.info(msgBuilder.toString());
}
}

private static String getStackTrace(Thread t) {
final StackTraceElement[] stackTrace = t.getStackTrace();
StringBuilder msgBuilder = new StringBuilder();
for (StackTraceElement e : stackTrace) {
msgBuilder.append(e.toString()).append("\n");
}
return msgBuilder.toString();
}

public boolean tryWriteLock(long timeout, TimeUnit unit) {
try {
boolean res = this.rwLock.writeLock().tryLock(timeout, unit);
if (!res && unit.toSeconds(timeout) >= 1) {
LOG.warn("Failed to try table {}'s write lock. timeout {} {}. Current owner: {}",
name, timeout, unit.name(), rwLock.getOwner());
}
if (res) {
lockWriteStart = System.currentTimeMillis();
}
return res;
} catch (InterruptedException e) {
LOG.warn("failed to try write lock at table[" + name + "]", e);
Expand All @@ -194,6 +239,7 @@ public boolean tryWriteLock(long timeout, TimeUnit unit) {
}

public void writeUnlock() {
checkAndLogLockDuration("write", lockWriteStart, System.currentTimeMillis());
this.rwLock.writeLock().unlock();
}

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -165,14 +165,20 @@ private enum PublishResult {
private volatile long usedQuotaDataBytes = -1;

private long lockWriteStart;
private final ThreadLocal<Long> lockReadStart = new ThreadLocal<>();

private long lockReportingThresholdMs = Config.lock_reporting_threshold_ms;
private final long lockReportingThresholdMs = Config.lock_reporting_threshold_ms;

protected void readLock() {
this.transactionLock.readLock().lock();
lockReadStart.set(System.currentTimeMillis());
}

protected void readUnlock() {
if (lockReadStart.get() != null) {
checkAndLogLockDuration("read", lockReadStart.get(), System.currentTimeMillis());
lockReadStart.remove();
}
this.transactionLock.readLock().unlock();
}

Expand All @@ -182,7 +188,7 @@ protected void writeLock() {
}

protected void writeUnlock() {
checkAndLogWriteLockDuration(lockWriteStart, System.currentTimeMillis());
checkAndLogLockDuration("write", lockWriteStart, System.currentTimeMillis());
this.transactionLock.writeLock().unlock();
}

Expand Down Expand Up @@ -2211,11 +2217,12 @@ public long getTxnNumByStatus(TransactionStatus status) {
* @param lockStart holing lock start time.
* @param lockEnd release lock time.
*/
private void checkAndLogWriteLockDuration(long lockStart, long lockEnd) {
private void checkAndLogLockDuration(String type, long lockStart, long lockEnd) {
long duration = lockEnd - lockStart;
if (duration > lockReportingThresholdMs) {
StringBuilder msgBuilder = new StringBuilder();
msgBuilder.append("lock is held at ")
msgBuilder.append(type)
.append(" lock is held at ")
.append(lockStart)
.append(".And release after ")
.append(duration)
Expand Down

0 comments on commit c8b9a6a

Please sign in to comment.