Skip to content

Troubleshooting

xamry edited this page Dec 9, 2011 · 20 revisions

1. I get the following exception while starting Cassandra. (Applicable for version prior to 2.0.4)

ERROR 12:29:45,253 Exception encountered during startup. java.lang.RuntimeException: Could not inflate CFMetaData for {"keyspace": "L", "name": "TI", "column_type": "Standard", "comparator_type": "lucandra.VIntType", "subcomparator type": null, "comment": "Stores term information with indexName/field/term as composit e key", "row_cache_size": 0.0, "key_cache_size": 0.0, "read_repair_chance": 1.0, "gc_gr ace_seconds": 864000, "default_validation_class": "org.apache.cassandra.db.marshal.Byte sType", "min_compaction_threshold": 4, "max_compaction_threshold": 32, "row_cache_save period_in_seconds": 0, "key_cache_save_period_in_seconds": 14400, "memtable_flush_after _mins": 1440, "memtable_throughput_in_mb": 15, "memtable_operations_in_millions": 0.070 3125, "id": 1004, "column_metadata": []} at org.apache.cassandra.config.CFMetaData.inflate(CFMetaData.java:404) at org.apache.cassandra.config.KSMetaData.inflate(KSMetaData.java:137) at org.apache.cassandra.db.DefsTable.loadFromStorage(DefsTable.java:99) at org.apache.cassandra.config.DatabaseDescriptor.loadSchemas(DatabaseDescripto r.java:462) at org.apache.cassandra.service.AbstractCassandraDaemon.setup(AbstractCassandra Daemon.java:140) at org.apache.cassandra.service.AbstractCassandraDaemon.activate(AbstractCassan draDaemon.java:317) at org.apache.cassandra.thrift.CassandraDaemon.main(CassandraDaemon.java:79) Caused by: org.apache.cassandra.config.ConfigurationException: Unable to find abstract- type class 'lucandra.VIntType' at org.apache.cassandra.utils.FBUtilities.classForName(FBUtilities.java:508) at org.apache.cassandra.utils.FBUtilities.getComparator(FBUtilities.java:474) at org.apache.cassandra.config.DatabaseDescriptor.getComparator(DatabaseDescrip tor.java:681) at org.apache.cassandra.config.CFMetaData.inflate(CFMetaData.java:395) ... 6 more Exception encountered during startup. java.lang.RuntimeException: Could not inflate CFMetaData for {"keyspace": "L", "name": "TI", "column_type": "Standard", "comparator_type": "lucandra.VIntType", "subcomparator type": null, "comment": "Stores term information with indexName/field/term as composit e key", "row_cache_size": 0.0, "key_cache_size": 0.0, "read_repair_chance": 1.0, "gc_gr ace_seconds": 864000, "default_validation_class": "org.apache.cassandra.db.marshal.Byte sType", "min_compaction_threshold": 4, "max_compaction_threshold": 32, "row_cache_save period_in_seconds": 0, "key_cache_save_period_in_seconds": 14400, "memtable_flush_after _mins": 1440, "memtable_throughput_in_mb": 15, "memtable_operations_in_millions": 0.070 3125, "id": 1004, "column_metadata": []} at org.apache.cassandra.config.CFMetaData.inflate(CFMetaData.java:404) at org.apache.cassandra.config.KSMetaData.inflate(KSMetaData.java:137) at org.apache.cassandra.db.DefsTable.loadFromStorage(DefsTable.java:99) at org.apache.cassandra.config.DatabaseDescriptor.loadSchemas(DatabaseDescripto r.java:462) at org.apache.cassandra.service.AbstractCassandraDaemon.setup(AbstractCassandra Daemon.java:140) at org.apache.cassandra.service.AbstractCassandraDaemon.activate(AbstractCassan draDaemon.java:317) at org.apache.cassandra.thrift.CassandraDaemon.main(CassandraDaemon.java:79) Caused by: org.apache.cassandra.config.ConfigurationException: Unable to find abstract- type class 'lucandra.VIntType' at org.apache.cassandra.utils.FBUtilities.classForName(FBUtilities.java:508) at org.apache.cassandra.utils.FBUtilities.getComparator(FBUtilities.java:474) at org.apache.cassandra.config.DatabaseDescriptor.getComparator(DatabaseDescrip tor.java:681) at org.apache.cassandra.config.CFMetaData.inflate(CFMetaData.java:395) ... 6 more

Solution: Kundera uses Solandra for indexing entity fields. If you are using standalone Cassandra server, solandra requires that you put solandra Jar into Cassandra lib folder. So, you have to put solandra-UNKNOWN.jar file (found in Kundera dependency) into /lib folder.

2. I get the following exception while starting Cassandra. (Applicable for version prior to 2.0.4)

ERROR 12:33:57,365 Exception encountered during startup. java.lang.NoClassDefFoundError: org/xerial/snappy/SnappyException at lucandra.VIntType.getString(VIntType.java:35) at org.apache.cassandra.db.Column.getString(Column.java:223) at org.apache.cassandra.db.marshal.AbstractType.getColumnsString(AbstractType.j ava:135) at org.apache.cassandra.db.ColumnFamily.toString(ColumnFamily.java:359) at org.apache.commons.lang.ObjectUtils.toString(ObjectUtils.java:241) at org.apache.commons.lang.StringUtils.join(StringUtils.java:3073) at org.apache.commons.lang.StringUtils.join(StringUtils.java:3133) at org.apache.cassandra.db.commitlog.CommitLog.recover(CommitLog.java:269) at org.apache.cassandra.db.commitlog.CommitLog.recover(CommitLog.java:156) at org.apache.cassandra.service.AbstractCassandraDaemon.setup(AbstractCassandra Daemon.java:175) at org.apache.cassandra.service.AbstractCassandraDaemon.activate(AbstractCassan draDaemon.java:317) at org.apache.cassandra.thrift.CassandraDaemon.main(CassandraDaemon.java:79) Caused by: java.lang.ClassNotFoundException: org.xerial.snappy.SnappyException at java.net.URLClassLoader$1.run(URLClassLoader.java:202) at java.security.AccessController.doPrivileged(Native Method) at java.net.URLClassLoader.findClass(URLClassLoader.java:190) at java.lang.ClassLoader.loadClass(ClassLoader.java:307) at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:301) at java.lang.ClassLoader.loadClass(ClassLoader.java:248) ... 12 more Exception encountered during startup. java.lang.NoClassDefFoundError: org/xerial/snappy/SnappyException at lucandra.VIntType.getString(VIntType.java:35) at org.apache.cassandra.db.Column.getString(Column.java:223) at org.apache.cassandra.db.marshal.AbstractType.getColumnsString(AbstractType.j ava:135) at org.apache.cassandra.db.ColumnFamily.toString(ColumnFamily.java:359) at org.apache.commons.lang.ObjectUtils.toString(ObjectUtils.java:241) at org.apache.commons.lang.StringUtils.join(StringUtils.java:3073) at org.apache.commons.lang.StringUtils.join(StringUtils.java:3133) at org.apache.cassandra.db.commitlog.CommitLog.recover(CommitLog.java:269) at org.apache.cassandra.db.commitlog.CommitLog.recover(CommitLog.java:156) at org.apache.cassandra.service.AbstractCassandraDaemon.setup(AbstractCassandra Daemon.java:175) at org.apache.cassandra.service.AbstractCassandraDaemon.activate(AbstractCassan draDaemon.java:317) at org.apache.cassandra.thrift.CassandraDaemon.main(CassandraDaemon.java:79) Caused by: java.lang.ClassNotFoundException: org.xerial.snappy.SnappyException at java.net.URLClassLoader$1.run(URLClassLoader.java:202) at java.security.AccessController.doPrivileged(Native Method) at java.net.URLClassLoader.findClass(URLClassLoader.java:190) at java.lang.ClassLoader.loadClass(ClassLoader.java:307) at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:301) at java.lang.ClassLoader.loadClass(ClassLoader.java:248) ... 12 more

Solution: If you are using cassandra as standalone server, solandra requires snappy-1.0.1-rc4.jar for integration with cassandra. Put snappy-1.0.1-rc4.jar into /lib folder and restart cassandra.

3. I get the following exception while starting Cassandra. (Applicable for version prior to 2.0.4)

ERROR 12:35:26,804 Exception encountered during startup. java.lang.ExceptionInInitializerError at lucandra.VIntType.getString(VIntType.java:35) at org.apache.cassandra.db.Column.getString(Column.java:223) at org.apache.cassandra.db.marshal.AbstractType.getColumnsString(AbstractType.j ava:135) at org.apache.cassandra.db.ColumnFamily.toString(ColumnFamily.java:359) at org.apache.commons.lang.ObjectUtils.toString(ObjectUtils.java:241) at org.apache.commons.lang.StringUtils.join(StringUtils.java:3073) at org.apache.commons.lang.StringUtils.join(StringUtils.java:3133) at org.apache.cassandra.db.commitlog.CommitLog.recover(CommitLog.java:269) at org.apache.cassandra.db.commitlog.CommitLog.recover(CommitLog.java:156) at org.apache.cassandra.service.AbstractCassandraDaemon.setup(AbstractCassandra Daemon.java:175) at org.apache.cassandra.service.AbstractCassandraDaemon.activate(AbstractCassan draDaemon.java:317) at org.apache.cassandra.thrift.CassandraDaemon.main(CassandraDaemon.java:79) Caused by: java.lang.NullPointerException at java.util.Properties$LineReader.readLine(Properties.java:418) at java.util.Properties.load0(Properties.java:337) at java.util.Properties.load(Properties.java:325) at lucandra.CassandraUtils.(CassandraUtils.java:78) ... 12 more Exception encountered during startup. java.lang.ExceptionInInitializerError at lucandra.VIntType.getString(VIntType.java:35) at org.apache.cassandra.db.Column.getString(Column.java:223) at org.apache.cassandra.db.marshal.AbstractType.getColumnsString(AbstractType.j ava:135) at org.apache.cassandra.db.ColumnFamily.toString(ColumnFamily.java:359) at org.apache.commons.lang.ObjectUtils.toString(ObjectUtils.java:241) at org.apache.commons.lang.StringUtils.join(StringUtils.java:3073) at org.apache.commons.lang.StringUtils.join(StringUtils.java:3133) at org.apache.cassandra.db.commitlog.CommitLog.recover(CommitLog.java:269) at org.apache.cassandra.db.commitlog.CommitLog.recover(CommitLog.java:156) at org.apache.cassandra.service.AbstractCassandraDaemon.setup(AbstractCassandra Daemon.java:175) at org.apache.cassandra.service.AbstractCassandraDaemon.activate(AbstractCassan draDaemon.java:317) at org.apache.cassandra.thrift.CassandraDaemon.main(CassandraDaemon.java:79) Caused by: java.lang.NullPointerException at java.util.Properties$LineReader.readLine(Properties.java:418) at java.util.Properties.load0(Properties.java:337) at java.util.Properties.load(Properties.java:325) at lucandra.CassandraUtils.(CassandraUtils.java:78) ... 12 more

Solution: This happens when solandra is not able to read solandra.properties file. To overcome this problem, copy solandra.properties shipped with Kundera source to /conf and restart Cassandra.

4. I get the following exception while starting Cassandra. (Applicable for version prior to 2.0.4)

ERROR 15:30:45,401 Exception encountered during startup. java.lang.NoClassDefFoundError: org/apache/lucene/search/FieldCache at lucandra.CassandraUtils.(CassandraUtils.java:95) at lucandra.VIntType.getString(VIntType.java:35) at org.apache.cassandra.db.Column.getString(Column.java:223) at org.apache.cassandra.db.marshal.AbstractType.getColumnsString(AbstractType.j ava:135) at org.apache.cassandra.db.ColumnFamily.toString(ColumnFamily.java:359) at org.apache.commons.lang.ObjectUtils.toString(ObjectUtils.java:241) at org.apache.commons.lang.StringUtils.join(StringUtils.java:3073) at org.apache.commons.lang.StringUtils.join(StringUtils.java:3133) at org.apache.cassandra.db.commitlog.CommitLog.recover(CommitLog.java:269) at org.apache.cassandra.db.commitlog.CommitLog.recover(CommitLog.java:156) at org.apache.cassandra.service.AbstractCassandraDaemon.setup(AbstractCassandra Daemon.java:175) at org.apache.cassandra.service.AbstractCassandraDaemon.activate(AbstractCassan draDaemon.java:317) at org.apache.cassandra.thrift.CassandraDaemon.main(CassandraDaemon.java:79) Caused by: java.lang.ClassNotFoundException: org.apache.lucene.search.FieldCache at java.net.URLClassLoader$1.run(URLClassLoader.java:202) at java.security.AccessController.doPrivileged(Native Method) at java.net.URLClassLoader.findClass(URLClassLoader.java:190) at java.lang.ClassLoader.loadClass(ClassLoader.java:307) at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:301) at java.lang.ClassLoader.loadClass(ClassLoader.java:248) ... 13 more Exception encountered during startup. java.lang.NoClassDefFoundError: org/apache/lucene/search/FieldCache at lucandra.CassandraUtils.(CassandraUtils.java:95) at lucandra.VIntType.getString(VIntType.java:35) at org.apache.cassandra.db.Column.getString(Column.java:223) at org.apache.cassandra.db.marshal.AbstractType.getColumnsString(AbstractType.j ava:135) at org.apache.cassandra.db.ColumnFamily.toString(ColumnFamily.java:359) at org.apache.commons.lang.ObjectUtils.toString(ObjectUtils.java:241) at org.apache.commons.lang.StringUtils.join(StringUtils.java:3073) at org.apache.commons.lang.StringUtils.join(StringUtils.java:3133) at org.apache.cassandra.db.commitlog.CommitLog.recover(CommitLog.java:269) at org.apache.cassandra.db.commitlog.CommitLog.recover(CommitLog.java:156) at org.apache.cassandra.service.AbstractCassandraDaemon.setup(AbstractCassandra Daemon.java:175) at org.apache.cassandra.service.AbstractCassandraDaemon.activate(AbstractCassan draDaemon.java:317) at org.apache.cassandra.thrift.CassandraDaemon.main(CassandraDaemon.java:79) Caused by: java.lang.ClassNotFoundException: org.apache.lucene.search.FieldCache at java.net.URLClassLoader$1.run(URLClassLoader.java:202) at java.security.AccessController.doPrivileged(Native Method) at java.net.URLClassLoader.findClass(URLClassLoader.java:190) at java.lang.ClassLoader.loadClass(ClassLoader.java:307) at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:301) at java.lang.ClassLoader.loadClass(ClassLoader.java:248) ... 13 more

Solution: Solandra internally uses lucene core library and complains while starting cassandra if it can't find one. Copy lucene-core-3.2.0.jar distributed as dependency with Kundera into /lib to overcome the issue

5. I get below error while persisting data:

org.scale7.cassandra.pelops.exceptions.InvalidRequestException at org.scale7.cassandra.pelops.exceptions.IExceptionTranslator$ExceptionTranslator.translate(IExceptionTranslator.java:47) at org.scale7.cassandra.pelops.Operand.tryOperation(Operand.java:109) at org.scale7.cassandra.pelops.Mutator.execute(Mutator.java:72) at com.impetus.kundera.cassandra.client.pelops.PelopsClient.writeData(PelopsClient.java:191) at com.impetus.kundera.cassandra.ColumnFamilyDataAccessor.write(ColumnFamilyDataAccessor.java:100) at com.impetus.kundera.db.DataManager.persist(DataManager.java:79) at com.impetus.kundera.ejb.EntityManagerImpl.persist(EntityManagerImpl.java:346) at com.impetus.kundera.examples.twitter.dao.TwitterService.addUser(TwitterService.java:64) at com.impetus.kundera.examples.twitter.TwitterTestSuite.addUsers(TwitterTestSuite.java:93) at com.impetus.kundera.examples.twitter.TwitterTestSuite.executeTestSuite(TwitterTestSuite.java:80) at com.impetus.kundera.examples.twitter.TwissandraTest.testOnExecute(TwissandraTest.java:88) at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source) at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source) at java.lang.reflect.Method.invoke(Unknown Source) at junit.framework.TestCase.runTest(TestCase.java:154) at junit.framework.TestCase.runBare(TestCase.java:127) at junit.framework.TestResult$1.protect(TestResult.java:106) at junit.framework.TestResult.runProtected(TestResult.java:124) at junit.framework.TestResult.run(TestResult.java:109) at junit.framework.TestCase.run(TestCase.java:118) at junit.framework.TestSuite.runTest(TestSuite.java:208) at junit.framework.TestSuite.run(TestSuite.java:203) at org.eclipse.jdt.internal.junit.runner.junit3.JUnit3TestReference.run(JUnit3TestReference.java:130) at org.eclipse.jdt.internal.junit.runner.TestExecution.run(TestExecution.java:38) at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:467) at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:683) at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.run(RemoteTestRunner.java:390) at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.main(RemoteTestRunner.java:197) Caused by: InvalidRequestException(why:no keyspace has been specified) at org.apache.cassandra.thrift.Cassandra$batch_mutate_result.read(Cassandra.java:19045) at org.apache.cassandra.thrift.Cassandra$Client.recv_batch_mutate(Cassandra.java:1035) at org.apache.cassandra.thrift.Cassandra$Client.batch_mutate(Cassandra.java:1009) at org.scale7.cassandra.pelops.Mutator$1.execute(Mutator.java:67) at org.scale7.cassandra.pelops.Mutator$1.execute(Mutator.java:63) at org.scale7.cassandra.pelops.Operand.tryOperation(Operand.java:82) ... 27 more

Solution: If you are using Cassandra as standalone server, you need to create your keyspaces and column families before persisting/ accessing data.

Home

Clone this wiki locally