José Andrés Cordero Benítez created OAK-10758:
-------------------------------------------------

             Summary: Avoid or mitigate Cursor Timeout in Mongo when running 
detailedGC
                 Key: OAK-10758
                 URL: https://issues.apache.org/jira/browse/OAK-10758
             Project: Jackrabbit Oak
          Issue Type: Improvement
          Components: documentmk, oak-run
            Reporter: José Andrés Cordero Benítez
            Assignee: José Andrés Cordero Benítez


When running oak-run revisions detailedGC command, if the cleanup is too big 
the processing time can exceed the Mongo cursor timeout, which defaults to 30 
minutes:
{code:java}
java.io.IOException: com.mongodb.MongoCursorNotFoundException: Query failed 
with error code -5 and error message 'Cursor 1007212049743349339 not found on 
server mongohost' on server mongohost:27017
    at 
org.apache.jackrabbit.oak.run.RevisionsCommand.collectOnce(RevisionsCommand.java:427)
    at 
org.apache.jackrabbit.oak.run.RevisionsCommand.collect(RevisionsCommand.java:377)
    at 
org.apache.jackrabbit.oak.run.RevisionsCommand.execute(RevisionsCommand.java:245)
    at org.apache.jackrabbit.oak.run.Main.main(Main.java:49)
Caused by: com.mongodb.MongoCursorNotFoundException: Query failed with error 
code -5 and error message 'Cursor 1007212049743349339 not found on server 
mongohost:27017' on server mongohost:27017
    at 
com.mongodb.operation.QueryHelper.translateCommandException(QueryHelper.java:27)
    at com.mongodb.operation.QueryBatchCursor.getMore(QueryBatchCursor.java:268)
    at com.mongodb.operation.QueryBatchCursor.hasNext(QueryBatchCursor.java:139)
    at 
com.mongodb.client.internal.MongoBatchCursorAdapter.hasNext(MongoBatchCursorAdapter.java:54)
    at 
org.apache.jackrabbit.guava.common.collect.TransformedIterator.hasNext(TransformedIterator.java:46)
    at 
org.apache.jackrabbit.guava.common.collect.Iterators$5.computeNext(Iterators.java:670)
    at 
org.apache.jackrabbit.guava.common.collect.AbstractIterator.tryToComputeNext(AbstractIterator.java:145)
    at 
org.apache.jackrabbit.guava.common.collect.AbstractIterator.hasNext(AbstractIterator.java:140)
    at 
org.apache.jackrabbit.guava.common.collect.Iterators$ConcatenatedIterator.hasNext(Iterators.java:1395)
    at 
org.apache.jackrabbit.oak.plugins.document.SplitDocumentCleanUp.disconnect(SplitDocumentCleanUp.java:63)
    at 
org.apache.jackrabbit.oak.plugins.document.VersionGCSupport.deleteSplitDocuments(VersionGCSupport.java:146)
    at 
org.apache.jackrabbit.oak.plugins.document.VersionGarbageCollector$GCJob.collectSplitDocuments(VersionGarbageCollector.java:842)
    at 
org.apache.jackrabbit.oak.plugins.document.VersionGarbageCollector$GCJob.gc(VersionGarbageCollector.java:686)
    at 
org.apache.jackrabbit.oak.plugins.document.VersionGarbageCollector$GCJob.run(VersionGarbageCollector.java:653)
    at 
org.apache.jackrabbit.oak.plugins.document.VersionGarbageCollector.gc(VersionGarbageCollector.java:221)
    at 
org.apache.jackrabbit.oak.run.RevisionsCommand$2.call(RevisionsCommand.java:401)
    at 
org.apache.jackrabbit.oak.run.RevisionsCommand$2.call(RevisionsCommand.java:398)
    at java.base/java.util.concurrent.FutureTask.run(FutureTask.java:264)
    at 
java.base/java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1128)
    at 
java.base/java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:628)
    at java.base/java.lang.Thread.run(Thread.java:834)
15:45:08.184 [DocumentNodeStore cluster update thread (0)] WARN  
o.a.j.o.p.document.DocumentNodeStore - Background operation failed: 
java.lang.reflect.UndeclaredThrowableException
java.lang.reflect.UndeclaredThrowableException: null
    at com.sun.proxy.$Proxy0.query(Unknown Source)
    at 
org.apache.jackrabbit.oak.plugins.document.ClusterNodeInfoDocument.all(ClusterNodeInfoDocument.java:154)
    at 
org.apache.jackrabbit.oak.plugins.document.DocumentNodeStore.updateClusterState(DocumentNodeStore.java:2480)
    at 
org.apache.jackrabbit.oak.plugins.document.DocumentNodeStore$BackgroundClusterUpdate.execute(DocumentNodeStore.java:3931)
    at 
org.apache.jackrabbit.oak.plugins.document.DocumentNodeStore$NodeStoreTask.run(DocumentNodeStore.java:3734)
    at java.base/java.lang.Thread.run(Thread.java:834)
Caused by: java.lang.reflect.InvocationTargetException: null
    at jdk.internal.reflect.GeneratedMethodAccessor3.invoke(Unknown Source)
    at 
java.base/jdk.internal.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
    at java.base/java.lang.reflect.Method.invoke(Method.java:566)
    at 
org.apache.jackrabbit.oak.plugins.document.util.ReadOnlyDocumentStoreWrapperFactory$1.invoke(ReadOnlyDocumentStoreWrapperFactory.java:41)
    ... 6 common frames omitted
Caused by: java.lang.IllegalStateException: The pool is closed
    at 
com.mongodb.internal.connection.ConcurrentPool.get(ConcurrentPool.java:137)
    at 
com.mongodb.internal.connection.ConcurrentPool.get(ConcurrentPool.java:123)
    at 
com.mongodb.internal.session.ServerSessionPool.get(ServerSessionPool.java:80)
    at 
com.mongodb.internal.session.BaseClientSessionImpl.<init>(BaseClientSessionImpl.java:44)
    at 
com.mongodb.client.internal.ClientSessionImpl.<init>(ClientSessionImpl.java:56)
    at 
com.mongodb.client.internal.MongoClientDelegate.createClientSession(MongoClientDelegate.java:120)
    at com.mongodb.Mongo.createClientSession(Mongo.java:837)
    at com.mongodb.MongoClient.startSession(MongoClient.java:582)
    at 
org.apache.jackrabbit.oak.plugins.document.mongo.MongoSessionFactory.createClientSession(MongoSessionFactory.java:55)
    at 
org.apache.jackrabbit.oak.plugins.document.mongo.MongoDBConnection.createClientSession(MongoDBConnection.java:115)
    at 
org.apache.jackrabbit.oak.plugins.document.mongo.MongoDocumentStore.createClientSession(MongoDocumentStore.java:2405)
    at 
org.apache.jackrabbit.oak.plugins.document.mongo.MongoDocumentStore.execute(MongoDocumentStore.java:2389)
    at 
org.apache.jackrabbit.oak.plugins.document.mongo.MongoDocumentStore.queryInternal(MongoDocumentStore.java:846)
    at 
org.apache.jackrabbit.oak.plugins.document.mongo.MongoDocumentStore.queryWithRetry(MongoDocumentStore.java:774)
    at 
org.apache.jackrabbit.oak.plugins.document.mongo.MongoDocumentStore.query(MongoDocumentStore.java:751)
    at 
org.apache.jackrabbit.oak.plugins.document.mongo.MongoDocumentStore.query(MongoDocumentStore.java:739)
    at 
org.apache.jackrabbit.oak.plugins.document.mongo.MongoDocumentStore.query(MongoDocumentStore.java:728)
    ... 10 common frames omitted {code}
Check if this needs mitigation or could happen as part of the internal 
repository detailedGC execution.



--
This message was sent by Atlassian Jira
(v8.20.10#820010)

Reply via email to