You are viewing a plain text version of this content. The canonical link for it is here.
Posted to oak-commits@jackrabbit.apache.org by md...@apache.org on 2017/03/30 08:44:04 UTC
svn commit: r1789459 -
/jackrabbit/oak/trunk/oak-segment-tar/src/main/java/org/apache/jackrabbit/oak/segment/file/FileStore.java
Author: mduerig
Date: Thu Mar 30 08:44:04 2017
New Revision: 1789459
URL: http://svn.apache.org/viewvc?rev=1789459&view=rev
Log:
OAK-6009: Simplify cancellation of compaction by timeout
Add timeout functionality to CancelCompactionSupplier
Modified:
jackrabbit/oak/trunk/oak-segment-tar/src/main/java/org/apache/jackrabbit/oak/segment/file/FileStore.java
Modified: jackrabbit/oak/trunk/oak-segment-tar/src/main/java/org/apache/jackrabbit/oak/segment/file/FileStore.java
URL: http://svn.apache.org/viewvc/jackrabbit/oak/trunk/oak-segment-tar/src/main/java/org/apache/jackrabbit/oak/segment/file/FileStore.java?rev=1789459&r1=1789458&r2=1789459&view=diff
==============================================================================
--- jackrabbit/oak/trunk/oak-segment-tar/src/main/java/org/apache/jackrabbit/oak/segment/file/FileStore.java (original)
+++ jackrabbit/oak/trunk/oak-segment-tar/src/main/java/org/apache/jackrabbit/oak/segment/file/FileStore.java Thu Mar 30 08:44:04 2017
@@ -796,7 +796,7 @@ public class FileStore extends AbstractF
compactionMonitor.init(GC_COUNT.get(), gcEntry.getRepoSize(), gcEntry.getNodes(), initialSize);
SegmentNodeState before = getHead();
- Supplier<Boolean> cancel = new CancelCompactionSupplier(FileStore.this);
+ CancelCompactionSupplier cancel = new CancelCompactionSupplier(FileStore.this);
SegmentWriter writer = segmentWriterBuilder("c")
.with(cacheManager)
.withGeneration(newGeneration)
@@ -852,7 +852,8 @@ public class FileStore extends AbstractF
Stopwatch forceWatch = Stopwatch.createStarted();
cycles++;
- after = forceCompact(writer, or(cancel, timeOut(forceTimeout, SECONDS)));
+ cancel.timeOutAfter(forceTimeout, SECONDS);
+ after = forceCompact(writer, cancel);
success = after != null;
if (success) {
gcListener.info("TarMK GC #{}: compaction succeeded to force compact remaining commits " +
@@ -892,38 +893,6 @@ public class FileStore extends AbstractF
}
}
- /**
- * @param duration
- * @param unit
- * @return {@code Supplier} instance which returns true once the time specified in
- * {@code duration} and {@code unit} has passed.
- */
- private Supplier<Boolean> timeOut(final long duration, @Nonnull final TimeUnit unit) {
- return new Supplier<Boolean>() {
- final long deadline = currentTimeMillis() + MILLISECONDS.convert(duration, unit);
- @Override
- public Boolean get() {
- return currentTimeMillis() > deadline;
- }
- };
- }
-
- /**
- * @param supplier1
- * @param supplier2
- * @return {@code Supplier} instance that returns {@code true} iff {@code supplier1} returns
- * {@code true} or otherwise {@code supplier2} returns {@code true}.
- */
- private Supplier<Boolean> or(
- @Nonnull Supplier<Boolean> supplier1,
- @Nonnull Supplier<Boolean> supplier2) {
- if (supplier1.get()) {
- return Suppliers.ofInstance(true);
- } else {
- return supplier2;
- }
- }
-
private SegmentNodeState compact(NodeState head, SegmentWriter writer, Supplier<Boolean> cancel)
throws IOException {
if (gcOptions.isOffline()) {
@@ -1137,17 +1106,29 @@ public class FileStore extends AbstractF
* the space was never sufficient to begin with), compaction is considered
* canceled. Furthermore when the file store is shutting down, compaction is
* considered canceled.
+ * Finally the cancellation can be triggered by a timeout that can be set
+ * at any time.
*/
private class CancelCompactionSupplier implements Supplier<Boolean> {
private final FileStore store;
private String reason;
+ private volatile long deadline;
public CancelCompactionSupplier(@Nonnull FileStore store) {
cancelled = false;
this.store = store;
}
+ /**
+ * Set a timeout for cancellation. Setting a different timeout cancels
+ * a previous one that did not yet elapse. Setting a timeout after
+ * cancellation took place has no effect.
+ */
+ public void timeOutAfter(final long duration, @Nonnull final TimeUnit unit) {
+ deadline = currentTimeMillis() + MILLISECONDS.convert(duration, unit);
+ }
+
@Override
public Boolean get() {
// The outOfDiskSpace and shutdown flags can only transition from
@@ -1169,6 +1150,10 @@ public class FileStore extends AbstractF
reason = "Cancelled by user";
return true;
}
+ if (deadline > 0 && currentTimeMillis() > deadline) {
+ reason = "Timeout after " + deadline/1000 + " seconds";
+ return true;
+ }
return false;
}