HBASE-27463 Reset sizeOfLogQueue when refresh replication source (#4863)

Co-authored-by: huiruan <huiruan@tencent.com>
Signed-off-by: Duo Zhang <zhangduo@apache.org>
Reviewed-by: Rushabh Shah <shahrs87@gmail.com>
(cherry picked from commit bb9f43c6f9)
This commit is contained in:
Ruanhui 2022-11-27 23:07:40 +08:00 committed by Duo Zhang
parent b68dcf46e9
commit cf5527be97
1 changed files with 10 additions and 18 deletions

View File

@ -97,15 +97,11 @@ import org.apache.hbase.thirdparty.com.google.common.util.concurrent.ThreadFacto
* case need synchronized is {@link #cleanOldLogs(NavigableSet, String, boolean, String)} and * case need synchronized is {@link #cleanOldLogs(NavigableSet, String, boolean, String)} and
* {@link #preLogRoll(Path)}.</li> * {@link #preLogRoll(Path)}.</li>
* <li>No need synchronized on {@link #walsByIdRecoveredQueues}. There are three methods which * <li>No need synchronized on {@link #walsByIdRecoveredQueues}. There are three methods which
* modify it, {@link #removePeer(String)} , <<<<<<< HEAD * modify it, {@link #removePeer(String)},
* {@link #cleanOldLogs(NavigableSet, String, boolean, String)} and * {@link #cleanOldLogs(NavigableSet, String, boolean, String)} and
* {@link ReplicationSourceManager.NodeFailoverWorker#run()}.
* {@link #cleanOldLogs(NavigableSet, String, boolean, String)} is called by =======
* {@link #cleanOldLogs(String, boolean, ReplicationSourceInterface)} and
* {@link ReplicationSourceManager#claimQueue(ServerName, String)}. * {@link ReplicationSourceManager#claimQueue(ServerName, String)}.
* {@link #cleanOldLogs(String, boolean, ReplicationSourceInterface)} is called by >>>>>>> * {@link #cleanOldLogs(NavigableSet, String, boolean, String)} is called by
* 51893b9ba3... HBASE-26029 It is not reliable to use nodeDeleted event to track region server's * {@link ReplicationSourceInterface}. {@link #removePeer(String)} will terminate the
* death (#3430) {@link ReplicationSourceInterface}. {@link #removePeer(String)} will terminate the
* {@link ReplicationSourceInterface} firstly, then remove the wals from * {@link ReplicationSourceInterface} firstly, then remove the wals from
* {@link #walsByIdRecoveredQueues}. And * {@link #walsByIdRecoveredQueues}. And
* {@link ReplicationSourceManager#claimQueue(ServerName, String)} will add the wals to * {@link ReplicationSourceManager#claimQueue(ServerName, String)} will add the wals to
@ -368,22 +364,18 @@ public class ReplicationSourceManager {
String terminateMessage = "Peer " + peerId String terminateMessage = "Peer " + peerId
+ " state or config changed. Will close the previous replication source and open a new one"; + " state or config changed. Will close the previous replication source and open a new one";
ReplicationPeer peer = replicationPeers.getPeer(peerId); ReplicationPeer peer = replicationPeers.getPeer(peerId);
ReplicationSourceInterface src = createSource(peerId, peer); ReplicationSourceInterface src;
// synchronized on latestPaths to avoid missing the new log // synchronized on latestPaths to avoid missing the new log
synchronized (this.latestPaths) { synchronized (this.latestPaths) {
ReplicationSourceInterface toRemove = this.sources.put(peerId, src); ReplicationSourceInterface toRemove = this.sources.remove(peerId);
if (toRemove != null) { if (toRemove != null) {
LOG.info("Terminate replication source for " + toRemove.getPeerId()); LOG.info("Terminate replication source for " + toRemove.getPeerId());
// Do not clear metrics toRemove.terminate(terminateMessage, null, true);
toRemove.terminate(terminateMessage, null, false);
} }
for (SortedSet<String> walsByGroup : walsById.get(peerId).values()) { src = createSource(peerId, peer);
walsByGroup.forEach(wal -> { this.sources.put(peerId, src);
Path walPath = new Path(this.logDir, wal); for (NavigableSet<String> walsByGroup : walsById.get(peerId).values()) {
src.enqueueLog(walPath); walsByGroup.forEach(wal -> src.enqueueLog(new Path(this.logDir, wal)));
LOG.trace("Enqueued {} to source {} during source creation.", walPath, src.getQueueId());
});
} }
} }
LOG.info("Startup replication source for " + src.getPeerId()); LOG.info("Startup replication source for " + src.getPeerId());