You are viewing a plain text version of this content. The canonical link for it is here.
Posted to commits@cassandra.apache.org by "Tyler Hobbs (JIRA)" <ji...@apache.org> on 2014/01/03 23:39:50 UTC

[jira] [Updated] (CASSANDRA-5930) Offline scrubs can choke on broken files

     [ https://issues.apache.org/jira/browse/CASSANDRA-5930?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel ]

Tyler Hobbs updated CASSANDRA-5930:
-----------------------------------

    Attachment: 5930-v1.patch

Thanks, [~jeffpotter].  It looks like you also had a Counter table, in this case.

5930-v1.patch (and [branch|https://github.com/thobbs/cassandra/tree/CASSANDRA-5930-2.0]) clarifies the error message for counter tables.

> Offline scrubs can choke on broken files
> ----------------------------------------
>
>                 Key: CASSANDRA-5930
>                 URL: https://issues.apache.org/jira/browse/CASSANDRA-5930
>             Project: Cassandra
>          Issue Type: Bug
>            Reporter: Jeremiah Jordan
>            Assignee: Tyler Hobbs
>            Priority: Minor
>         Attachments: 5930-v1.patch
>
>
> There are cases where offline scrub can hit an exception and die, like:
> {noformat}
> WARNING: Non-fatal error reading row (stacktrace follows)
> Exception in thread "main" java.io.IOError: java.io.IOError: java.io.EOFException
> 	at org.apache.cassandra.db.compaction.Scrubber.scrub(Scrubber.java:242)
> 	at org.apache.cassandra.tools.StandaloneScrubber.main(StandaloneScrubber.java:121)
> Caused by: java.io.IOError: java.io.EOFException
> 	at org.apache.cassandra.db.compaction.PrecompactedRow.merge(PrecompactedRow.java:116)
> 	at org.apache.cassandra.db.compaction.PrecompactedRow.<init>(PrecompactedRow.java:99)
> 	at org.apache.cassandra.db.compaction.CompactionController.getCompactedRow(CompactionController.java:176)
> 	at org.apache.cassandra.db.compaction.CompactionController.getCompactedRow(CompactionController.java:182)
> 	at org.apache.cassandra.db.compaction.Scrubber.scrub(Scrubber.java:171)
> 	... 1 more
> Caused by: java.io.EOFException
> 	at java.io.RandomAccessFile.readFully(RandomAccessFile.java:399)
> 	at java.io.RandomAccessFile.readFully(RandomAccessFile.java:377)
> 	at org.apache.cassandra.utils.BytesReadTracker.readFully(BytesReadTracker.java:95)
> 	at org.apache.cassandra.utils.ByteBufferUtil.read(ByteBufferUtil.java:401)
> 	at org.apache.cassandra.utils.ByteBufferUtil.readWithLength(ByteBufferUtil.java:363)
> 	at org.apache.cassandra.db.ColumnSerializer.deserialize(ColumnSerializer.java:120)
> 	at org.apache.cassandra.db.ColumnSerializer.deserialize(ColumnSerializer.java:37)
> 	at org.apache.cassandra.db.ColumnFamilySerializer.deserializeColumns(ColumnFamilySerializer.java:144)
> 	at org.apache.cassandra.io.sstable.SSTableIdentityIterator.getColumnFamilyWithColumns(SSTableIdentityIterator.java:234)
> 	at org.apache.cassandra.db.compaction.PrecompactedRow.merge(PrecompactedRow.java:112)
> 	... 5 more
> {noformat}
> Since the purpose of offline scrub is to fix broken stuff, it should be more resilient to broken stuff...



--
This message was sent by Atlassian JIRA
(v6.1.5#6160)