[ https://issues.apache.org/jira/browse/CASSANDRA-12942?page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel&focusedCommentId=17642528#comment-17642528 ]
Stefan Miklosovic edited comment on CASSANDRA-12942 at 12/2/22 2:24 PM: ------------------------------------------------------------------------ I was not able to reproduce this. 3 nodes, ByteOrderedPartitioner, I created a keyspace with SimpleStrategy, RF3, one table, inserted some data, flushed, called nodetool status 100x in a loop. No error. I tested 3.0.28, 3.11.14 as well as trunk (4.2-SNAPSHOT). was (Author: smiklosovic): I was not able to reproduce this. I created a keyspace with SimpleStrategy, RF3, one table, inserted some data, called nodetool status 100x in a loop. No error. I tested 3.11.14 as well as trunk (4.2-SNAPSHOT). > ClassCastException during Status > -------------------------------- > > Key: CASSANDRA-12942 > URL: https://issues.apache.org/jira/browse/CASSANDRA-12942 > Project: Cassandra > Issue Type: Bug > Components: Legacy/Tools > Environment: Cassandra 3.7 > OpenJDK 8 > Ubuntu 14.04 > Reporter: Chris Donati > Assignee: Stefan Miklosovic > Priority: Low > Fix For: 3.0.x, 3.11.x > > Attachments: 12942-3.0.txt > > > I often encounter a ClassCastException when trying to run `nodetool status` > on a particular cluster. Occasionally, the command will work on one of the > nodes (and report all of the nodes as 'UN'), but the majority of the time, > nodetool raises the following exception: > {noformat} > error: null > -- StackTrace -- > java.lang.ClassCastException > {noformat} > A couple of times, I've gotten lucky and nodetool has provided a more verbose > error message: > {noformat} > error: org.apache.cassandra.dht.LocalPartitioner$LocalToken cannot be cast to > org.apache.cassandra.dht.ByteOrderedPartitioner$BytesToken > -- StackTrace -- > java.lang.ClassCastException: > org.apache.cassandra.dht.LocalPartitioner$LocalToken cannot be cast to > org.apache.cassandra.dht.ByteOrderedPartitioner$BytesToken > at > org.apache.cassandra.dht.ByteOrderedPartitioner$BytesToken.compareTo(ByteOrderedPartitioner.java:79) > at > org.apache.cassandra.dht.ByteOrderedPartitioner$BytesToken.compareTo(ByteOrderedPartitioner.java:55) > at org.apache.cassandra.dht.Token$KeyBound.compareTo(Token.java:166) > at org.apache.cassandra.dht.Token$KeyBound.compareTo(Token.java:145) > at org.apache.cassandra.db.DecoratedKey.compareTo(DecoratedKey.java:93) > at > org.apache.cassandra.io.sstable.IndexSummary.binarySearch(IndexSummary.java:122) > at > org.apache.cassandra.io.sstable.format.SSTableReader.getSampleIndexesForRanges(SSTableReader.java:1345) > at > org.apache.cassandra.io.sstable.format.SSTableReader.getKeySamples(SSTableReader.java:1379) > at > org.apache.cassandra.db.ColumnFamilyStore.keySamples(ColumnFamilyStore.java:2058) > at > org.apache.cassandra.service.StorageService.keySamples(StorageService.java:3722) > at > org.apache.cassandra.service.StorageService.getSplits(StorageService.java:3678) > at > org.apache.cassandra.dht.ByteOrderedPartitioner.describeOwnership(ByteOrderedPartitioner.java:284) > at > org.apache.cassandra.service.StorageService.effectiveOwnership(StorageService.java:4460) > at > org.apache.cassandra.service.StorageService.effectiveOwnership(StorageService.java:184) > at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) > at > sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) > at > sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) > at java.lang.reflect.Method.invoke(Method.java:498) > at sun.reflect.misc.Trampoline.invoke(MethodUtil.java:71) > at sun.reflect.GeneratedMethodAccessor5.invoke(Unknown Source) > at > sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) > at java.lang.reflect.Method.invoke(Method.java:498) > at sun.reflect.misc.MethodUtil.invoke(MethodUtil.java:275) > at > com.sun.jmx.mbeanserver.StandardMBeanIntrospector.invokeM2(StandardMBeanIntrospector.java:112) > at > com.sun.jmx.mbeanserver.StandardMBeanIntrospector.invokeM2(StandardMBeanIntrospector.java:46) > at > com.sun.jmx.mbeanserver.MBeanIntrospector.invokeM(MBeanIntrospector.java:237) > at com.sun.jmx.mbeanserver.PerInterface.invoke(PerInterface.java:138) > at com.sun.jmx.mbeanserver.MBeanSupport.invoke(MBeanSupport.java:252) > at > com.sun.jmx.interceptor.DefaultMBeanServerInterceptor.invoke(DefaultMBeanServerInterceptor.java:819) > at > com.sun.jmx.mbeanserver.JmxMBeanServer.invoke(JmxMBeanServer.java:801) > at > javax.management.remote.rmi.RMIConnectionImpl.doOperation(RMIConnectionImpl.java:1468) > at > javax.management.remote.rmi.RMIConnectionImpl.access$300(RMIConnectionImpl.java:76) > at > javax.management.remote.rmi.RMIConnectionImpl$PrivilegedOperation.run(RMIConnectionImpl.java:1309) > at > javax.management.remote.rmi.RMIConnectionImpl.doPrivilegedOperation(RMIConnectionImpl.java:1401) > at > javax.management.remote.rmi.RMIConnectionImpl.invoke(RMIConnectionImpl.java:829) > at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) > at > sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) > at > sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) > at java.lang.reflect.Method.invoke(Method.java:498) > at sun.rmi.server.UnicastServerRef.dispatch(UnicastServerRef.java:324) > at sun.rmi.transport.Transport$1.run(Transport.java:200) > at sun.rmi.transport.Transport$1.run(Transport.java:197) > at java.security.AccessController.doPrivileged(Native Method) > at sun.rmi.transport.Transport.serviceCall(Transport.java:196) > at > sun.rmi.transport.tcp.TCPTransport.handleMessages(TCPTransport.java:568) > at > sun.rmi.transport.tcp.TCPTransport$ConnectionHandler.run0(TCPTransport.java:826) > at > sun.rmi.transport.tcp.TCPTransport$ConnectionHandler.lambda$run$0(TCPTransport.java:683) > at java.security.AccessController.doPrivileged(Native Method) > at > sun.rmi.transport.tcp.TCPTransport$ConnectionHandler.run(TCPTransport.java:682) > at > java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1142) > at > java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:617) > at java.lang.Thread.run(Thread.java:745) > {noformat} > There are 3 nodes in the cluster, and it's using the SimpleStrategy with a 3x > replication factor. It's using the ByteOrderedPartitioner (which I know is > frowned upon). -- This message was sent by Atlassian Jira (v8.20.10#820010) --------------------------------------------------------------------- To unsubscribe, e-mail: commits-unsubscr...@cassandra.apache.org For additional commands, e-mail: commits-h...@cassandra.apache.org