Details
-
Improvement
-
Status: Closed
-
Major
-
Resolution: Won't Fix
-
5.11.2
-
None
-
None
-
Windows x64 7,8; Oracle Java 8 (u60)
Description
With a single AMQ 5.11.2 instance, Java8u60 and Windows 7+ we can produce LevelDB corruption by putting the system to sleep (sometimes by simply closing a notebook).
BTW: The LevelDB auto-recovery on the corrupted LevelDBStore works perfectly on a Linux or MacOS system, but unfortunately this is not an option in some customer infrastructure.
Irrespective of whether this bug should have been recovered by the LevelDB store automatically or not, how can this situation be recovered (more or less manually) without losing the persistent queue content? The KahaDB recovery docs were enough in most situations, and something near it with LevelDB could help not to switch back to KahaDB or other Persistence Adapters.
The above mentioned scenario produces the following log output, how can this be fixed reliably with a minimum of data loss?
jvm 1 | ERROR: org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'org.apache.activemq.xbean.XBeanBrokerService#0' defined in class path resource [activemq.xml]: Invocation of init method failed; nested exception is org.iq80.leveldb.impl.DbImpl$BackgroundProcessingException: java.lang.RuntimeException: Could not open table 11 jvm 1 | org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'org.apache.activemq.xbean.XBeanBrokerService#0' defined in class path resource [activemq.xml]: Invocation of init method failed; nested exception is org.iq80.leveldb.impl.DbImpl$BackgroundProcessingException: java.lang.RuntimeException: Could not open table 11 jvm 1 | at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.initializeBean(AbstractAutowireCapableBeanFactory.java:1514) jvm 1 | at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:521) jvm 1 | at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:458) jvm 1 | at org.springframework.beans.factory.support.AbstractBeanFactory$1.getObject(AbstractBeanFactory.java:293) jvm 1 | at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:223) jvm 1 | at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:290) jvm 1 | at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:191) jvm 1 | at org.springframework.beans.factory.support.DefaultListableBeanFactory.preInstantiateSingletons(DefaultListableBeanFactory.java:636) jvm 1 | at org.springframework.context.support.AbstractApplicationContext.finishBeanFactoryInitialization(AbstractApplicationContext.java:934) jvm 1 | at org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:479) jvm 1 | at org.apache.xbean.spring.context.ResourceXmlApplicationContext.<init>(ResourceXmlApplicationContext.java:64) jvm 1 | at org.apache.xbean.spring.context.ResourceXmlApplicationContext.<init>(ResourceXmlApplicationContext.java:52) jvm 1 | at org.apache.activemq.xbean.XBeanBrokerFactory$1.<init>(XBeanBrokerFactory.java:104) jvm 1 | at org.apache.activemq.xbean.XBeanBrokerFactory.createApplicationContext(XBeanBrokerFactory.java:104) jvm 1 | at org.apache.activemq.xbean.XBeanBrokerFactory.createBroker(XBeanBrokerFactory.java:67) jvm 1 | at org.apache.activemq.broker.BrokerFactory.createBroker(BrokerFactory.java:71) jvm 1 | at org.apache.activemq.broker.BrokerFactory.createBroker(BrokerFactory.java:54) jvm 1 | at org.apache.activemq.console.command.StartCommand.runTask(StartCommand.java:87) jvm 1 | at org.apache.activemq.console.command.AbstractCommand.execute(AbstractCommand.java:57) jvm 1 | at org.apache.activemq.console.command.ShellCommand.runTask(ShellCommand.java:150) jvm 1 | at org.apache.activemq.console.command.AbstractCommand.execute(AbstractCommand.java:57) jvm 1 | at org.apache.activemq.console.command.ShellCommand.main(ShellCommand.java:104) jvm 1 | at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) jvm 1 | at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source) jvm 1 | at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source) jvm 1 | at java.lang.reflect.Method.invoke(Unknown Source) jvm 1 | at org.apache.activemq.console.Main.runTaskClass(Main.java:262) jvm 1 | at org.apache.activemq.console.Main.main(Main.java:115) jvm 1 | at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) jvm 1 | at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source) jvm 1 | at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source) jvm 1 | at java.lang.reflect.Method.invoke(Unknown Source) jvm 1 | at org.tanukisoftware.wrapper.WrapperSimpleApp.run(WrapperSimpleApp.java:240) jvm 1 | at java.lang.Thread.run(Unknown Source) jvm 1 | Caused by: org.iq80.leveldb.impl.DbImpl$BackgroundProcessingException: java.lang.RuntimeException: Could not open table 11 jvm 1 | at org.iq80.leveldb.impl.DbImpl.checkBackgroundException(DbImpl.java:411) jvm 1 | at org.iq80.leveldb.impl.DbImpl.createWriteBatch(DbImpl.java:707) jvm 1 | at org.apache.activemq.leveldb.LevelDBClient.replay_from(LevelDBClient.scala:704) jvm 1 | at org.apache.activemq.leveldb.LevelDBClient.start(LevelDBClient.scala:572) jvm 1 | at org.apache.activemq.leveldb.DBManager.start(DBManager.scala:648) jvm 1 | at org.apache.activemq.leveldb.LevelDBStore.doStart(LevelDBStore.scala:312) jvm 1 | at org.apache.activemq.util.ServiceSupport.start(ServiceSupport.java:55) jvm 1 | at org.apache.activemq.broker.BrokerService.doStartPersistenceAdapter(BrokerService.java:653) jvm 1 | at org.apache.activemq.broker.BrokerService.startPersistenceAdapter(BrokerService.java:642) jvm 1 | at org.apache.activemq.broker.BrokerService.start(BrokerService.java:607) jvm 1 | at org.apache.activemq.xbean.XBeanBrokerService.afterPropertiesSet(XBeanBrokerService.java:73) jvm 1 | at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) jvm 1 | at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source) jvm 1 | at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source) jvm 1 | at java.lang.reflect.Method.invoke(Unknown Source) jvm 1 | at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.invokeCustomInitMethod(AbstractAutowireCapableBeanFactory.java:1640) jvm 1 | at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.invokeInitMethods(AbstractAutowireCapableBeanFactory.java:1581) jvm 1 | at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.initializeBean(AbstractAutowireCapableBeanFactory.java:1511) jvm 1 | ... 33 more jvm 1 | Caused by: java.lang.RuntimeException: Could not open table 11 jvm 1 | at org.iq80.leveldb.impl.TableCache.getTable(TableCache.java:87) jvm 1 | at org.iq80.leveldb.impl.TableCache.newIterator(TableCache.java:69) jvm 1 | at org.iq80.leveldb.impl.TableCache.newIterator(TableCache.java:64) jvm 1 | at org.iq80.leveldb.util.Level0Iterator.<init>(Level0Iterator.java:29) jvm 1 | at org.iq80.leveldb.impl.VersionSet.makeInputIterator(VersionSet.java:205) jvm 1 | at org.iq80.leveldb.impl.DbImpl.doCompactionWork(DbImpl.java:1009) jvm 1 | at org.iq80.leveldb.impl.DbImpl.backgroundCompaction(DbImpl.java:478) jvm 1 | at org.iq80.leveldb.impl.DbImpl.backgroundCall(DbImpl.java:426) jvm 1 | at org.iq80.leveldb.impl.DbImpl.access$100(DbImpl.java:83) jvm 1 | at org.iq80.leveldb.impl.DbImpl$2.call(DbImpl.java:396) jvm 1 | at org.iq80.leveldb.impl.DbImpl$2.call(DbImpl.java:390) jvm 1 | at java.util.concurrent.FutureTask.run(Unknown Source) jvm 1 | at java.util.concurrent.ThreadPoolExecutor.runWorker(Unknown Source) jvm 1 | at java.util.concurrent.ThreadPoolExecutor$Worker.run(Unknown Source) jvm 1 | ... 1 more jvm 1 | Caused by: java.io.FileNotFoundException: ..\data\leveldb\dirty.index\000011.sst (Das System kann die angegebene Datei nicht finden) jvm 1 | at java.io.FileInputStream.open0(Native Method) jvm 1 | at java.io.FileInputStream.open(Unknown Source) jvm 1 | at java.io.FileInputStream.<init>(Unknown Source) jvm 1 | at org.iq80.leveldb.impl.TableCache$TableAndFile.<init>(TableCache.java:112) jvm 1 | at org.iq80.leveldb.impl.TableCache$TableAndFile.<init>(TableCache.java:102) jvm 1 | at org.iq80.leveldb.impl.TableCache$1.load(TableCache.java:57) jvm 1 | at org.iq80.leveldb.impl.TableCache$1.load(TableCache.java:54) jvm 1 | at com.google.common.cache.LocalCache$LoadingValueReference.loadFuture(LocalCache.java:3579) jvm 1 | at com.google.common.cache.LocalCache$Segment.loadSync(LocalCache.java:2372) jvm 1 | at com.google.common.cache.LocalCache$Segment.lockedGetOrLoad(LocalCache.java:2335) jvm 1 | at com.google.common.cache.LocalCache$Segment.get(LocalCache.java:2250) jvm 1 | at com.google.common.cache.LocalCache.get(LocalCache.java:3980) jvm 1 | at com.google.common.cache.LocalCache.getOrLoad(LocalCache.java:3984) jvm 1 | at com.google.common.cache.LocalCache$LocalLoadingCache.get(LocalCache.java:4868) jvm 1 | at org.iq80.leveldb.impl.TableCache.getTable(TableCache.java:80) jvm 1 | ... 14 more