Uploaded image for project: 'ActiveMQ'
  1. ActiveMQ
  2. AMQ-6011

create a how-to about repair/recover corrupt LevelDB

    XMLWordPrintableJSON

    Details

    • Type: Improvement
    • Status: Closed
    • Priority: Major
    • Resolution: Won't Fix
    • Affects Version/s: 5.11.2
    • Fix Version/s: None
    • Component/s: Message Store
    • Labels:
      None
    • Environment:

      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
      

        Attachments

          Activity

            People

            • Assignee:
              Unassigned
              Reporter:
              jforge Klaus Pittig
            • Votes:
              0 Vote for this issue
              Watchers:
              3 Start watching this issue

              Dates

              • Created:
                Updated:
                Resolved: