HBASE-24211: Create table is slow in large cluster when AccessController is enabled. (#1546)
Signed-off-by: Viraj Jasani <vjasani@apache.org> Signed-off-by: Pankaj <pankajkumar@apache.org>
This commit is contained in:
parent
b2e9321d97
commit
66e90dece2
|
@ -185,25 +185,28 @@ public class ZKPermissionWatcher extends ZKListener implements Closeable {
|
|||
public void nodeChildrenChanged(final String path) {
|
||||
waitUntilStarted();
|
||||
if (path.equals(aclZNode)) {
|
||||
try {
|
||||
final List<ZKUtil.NodeAndData> nodeList =
|
||||
ZKUtil.getChildDataAndWatchForNewChildren(watcher, aclZNode);
|
||||
// preempt any existing nodeChildrenChanged event processing
|
||||
if (childrenChangedFuture != null && !childrenChangedFuture.isDone()) {
|
||||
boolean cancelled = childrenChangedFuture.cancel(true);
|
||||
if (!cancelled) {
|
||||
// task may have finished between our check and attempted cancel, this is fine.
|
||||
if (! childrenChangedFuture.isDone()) {
|
||||
LOG.warn("Could not cancel processing node children changed event, " +
|
||||
"please file a JIRA and attach logs if possible.");
|
||||
if (!childrenChangedFuture.isDone()) {
|
||||
LOG.warn("Could not cancel processing node children changed event, "
|
||||
+ "please file a JIRA and attach logs if possible.");
|
||||
}
|
||||
}
|
||||
}
|
||||
childrenChangedFuture = asyncProcessNodeUpdate(() -> refreshNodes(nodeList));
|
||||
childrenChangedFuture = asyncProcessNodeUpdate(() -> {
|
||||
try {
|
||||
final List<ZKUtil.NodeAndData> nodeList =
|
||||
ZKUtil.getChildDataAndWatchForNewChildren(watcher, aclZNode);
|
||||
refreshNodes(nodeList);
|
||||
} catch (KeeperException ke) {
|
||||
LOG.error("Error reading data from zookeeper for path "+path, ke);
|
||||
watcher.abort("ZooKeeper error get node children for path "+path, ke);
|
||||
String msg = "ZooKeeper error while reading node children data for path " + path;
|
||||
LOG.error(msg, ke);
|
||||
watcher.abort(msg, ke);
|
||||
}
|
||||
});
|
||||
}
|
||||
}
|
||||
|
||||
|
|
|
@ -742,6 +742,10 @@ public final class ZKUtil {
|
|||
if (nodes != null) {
|
||||
List<NodeAndData> newNodes = new ArrayList<>();
|
||||
for (String node : nodes) {
|
||||
if (Thread.interrupted()) {
|
||||
// Partial data should not be processed. Cancel processing by sending empty list.
|
||||
return Collections.emptyList();
|
||||
}
|
||||
String nodePath = ZNodePaths.joinZNode(baseNode, node);
|
||||
byte[] data = ZKUtil.getDataAndWatch(zkw, nodePath);
|
||||
newNodes.add(new NodeAndData(nodePath, data));
|
||||
|
|
Loading…
Reference in New Issue