HBASE-25981 JVM crash when displaying RegionServer UI (#3364)

Signed-off-by: Duo Zhang <zhangduo@apache.org>
This commit is contained in:
Xiaolin Ha 2021-06-09 18:11:18 +08:00 committed by haxiaolin
parent 39a577fbbf
commit 7436a345be
1 changed files with 6 additions and 2 deletions

View File

@ -159,6 +159,7 @@ public class CallRunner {
sucessful = true; sucessful = true;
} }
} }
this.status.markComplete("To send response");
// return back the RPC request read BB we can do here. It is done by now. // return back the RPC request read BB we can do here. It is done by now.
call.cleanup(); call.cleanup();
// Set the response // Set the response
@ -166,8 +167,6 @@ public class CallRunner {
CellScanner cells = resultPair != null ? resultPair.getSecond() : null; CellScanner cells = resultPair != null ? resultPair.getSecond() : null;
call.setResponse(param, cells, errorThrowable, error); call.setResponse(param, cells, errorThrowable, error);
call.sendResponseIfReady(); call.sendResponseIfReady();
this.status.markComplete("Sent response");
this.status.pause("Waiting for a call");
} catch (OutOfMemoryError e) { } catch (OutOfMemoryError e) {
if (this.rpcServer.getErrorHandler() != null) { if (this.rpcServer.getErrorHandler() != null) {
if (this.rpcServer.getErrorHandler().checkOOME(e)) { if (this.rpcServer.getErrorHandler().checkOOME(e)) {
@ -191,6 +190,11 @@ public class CallRunner {
if (!sucessful) { if (!sucessful) {
this.rpcServer.addCallSize(call.getSize() * -1); this.rpcServer.addCallSize(call.getSize() * -1);
} }
if (this.status.isRPCRunning()) {
this.status.markComplete("Call error");
}
this.status.pause("Waiting for a call");
cleanup(); cleanup();
} }
} }