com.alibaba.hologres.client.impl.binlog.Committer Maven / Gradle / Ivy
/*
* Copyright (c) 2022. Alibaba Group Holding Limited
*/
package com.alibaba.hologres.client.impl.binlog;
import com.alibaba.hologres.client.utils.Tuple;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import java.util.concurrent.BlockingQueue;
import java.util.concurrent.CompletableFuture;
import java.util.concurrent.TimeUnit;
import java.util.concurrent.TimeoutException;
/**
* 用来提交lsn的.
*/
public class Committer {
public static final Logger LOGGER = LoggerFactory.getLogger(Committer.class);
final BlockingQueue, Long>> queue;
long lastReadLsn = -1;
public Committer(BlockingQueue, Long>> queue) {
this.queue = queue;
}
public void updateLastReadLsn(long lastReadLsn) {
this.lastReadLsn = lastReadLsn;
}
public CompletableFuture commit(long timeout) throws InterruptedException, TimeoutException {
return commit(lastReadLsn, timeout);
}
public CompletableFuture commit(long lsn, long timeout) throws InterruptedException, TimeoutException {
CompletableFuture future = new CompletableFuture<>();
if (lsn < 0) {
LOGGER.info("last read lsn {} < 0, skip commit it", lsn);
future.complete(null);
return future;
}
boolean ret = queue.offer(new Tuple<>(future, lsn), timeout, TimeUnit.MILLISECONDS);
if (!ret) {
throw new TimeoutException();
} else {
return future;
}
}
public long getLastReadLsn() {
return lastReadLsn;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy