[ 
https://issues.apache.org/jira/browse/CASSANDRA-13004?page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel&focusedCommentId=15733064#comment-15733064
 ] 

Tyler Hobbs edited comment on CASSANDRA-13004 at 12/8/16 8:00 PM:
------------------------------------------------------------------

I haven't had any luck reproducing this locally yet.  I looked into the 
response that the driver had trouble decoding, and this is the breakdown:

{noformat}
\x84\x00\x00\x1b\x08\x00\x00\x03w\x00\x00\x00\x02\x00\x00\x00\x01\x00\x00\x00\x0f\x00\x10discord_channels\x00\x08channels
  # flags and metadata

\x00\x02id\x00\x02                                 # col 0
\x00\x0eapplication_id\x00\x02                     # col 1
\x00\x07bitrate\x00\t                              # col 2
\x00\x08guild_id\x00\x02                           # col 3
\x00\ticon_hash\x00\r                              # col 4
\x00\x0flast_message_id\x00\x02                    # col 5
\x00\x12last_pin_timestamp\x00\x0b                 # col 6
\x00\x04name\x00\r                                 # col 7
\x00\x08owner_id\x00\x02                           # col 8
\x00\x15permission_overwrites\x00!                 # col 9
  \x00\x02\x000\x00\x10discord_channels\x00\x1c
  channel_permission_overwrite\x00\x04
    \x00\x02id\x00\x02
    \x00\x04type\x00\t
    \x00\x06allow_\x00\t
    \x00\x04deny\x00\t
\x00\x08position\x00\t                             # col 10
\x00\nrecipients\x00!                              # col 11
  \x00\x02\x000\x00\x10discord_channels\x00\x11channel_recipient\x00\x01
  \x00\x04nick\x00\r
\x00\x05topic\x00\r                                # col 12
\x00\x04type\x00\x14                               # col 13
\x00\nuser_limit\x00\t                             # col 14

\x00\x00\x00\x01                                   # row count

\x00\x00\x00\x08 \x03\x8a\x19\x8e\xf8\x82\x00\x01  # value 0, id 
(255044430745174017)

\xff\xff\xff\xff                                   # value 1, application_id 
(null)

\x00\x00\x00\x04 \x00\x00\xfa\x00                  # value 2, bitrate (16384000)

\x00\x00\x00\x08 \x00\x00\xfa\x00\x00\xf8G\xc5     # value 3, guild_id 
(274877923215301)

\x00\x00\x00\x00                                   # value 4 icon_hash (empty 
string)

\x00\x00\x00\x08 \x03\x8b\xc0\xb5nB\x00\x02        # value 5 last_message_id 
(255509689347997698)

\x00\x00\x00\x08 G\xc5\xffI\x98\xc4\xb4(           # value 6 last_pin_timestamp 
(5171820438665606184)

\x00\x00\x00\x03 \x8b\xc0\xa8                      # value 7 (non-UTF8 
compliant string)

\xff\xff\xff\xff                                   # value 8, owner_id (null)

\x00\x00\x01<                                      # value 9, (length 316 user 
type)

\x00\x00\x00\x06\x00\x00\x00\x08\x03\x81L\xea\xfc\x82\x00\n\x00\x00\x00$\x00\x00\x00\x08\x03\x81L\xea\xfc\x82\x00\n\x00\x00\x00\x04\x00\x00\x00\x01\x00\x00\x00\x04\x00\x00\x08\x00\x00\x00\x00\x04\x00\x00\x00\x00\x00\x00\x00\x08\x03\x8a\x1e\xe6\x8b\x80\x00\n\x00\x00\x00$\x00\x00\x00\x08\x03\x8a\x1e\xe6\x8b\x80\x00\n\x00\x00\x00\x04\x00\x00\x00\x00\x00\x00\x00\x040\x07\xf8Q\x00\x00\x00\x04\x00\x00\x00\x00\x00\x00\x00\x08\x03\x8a\x1f\x1b{\x82\x00\x00\x00\x00\x00$\x00\x00\x00\x08\x03\x8a\x1f\x1b{\x82\x00\x00\x00\x00\x00\x04\x00\x00\x00\x00\x00\x00\x00\x04\x00\x07\xf8Q\x00\x00\x00\x04\x10\x00\x00\x00\x00\x00\x00\x08\x03\x8a\x1fH6\x82\x00\x01\x00\x00\x00$\x00\x00\x00\x08\x03\x8a\x1fH6\x82\x00\x01\x00\x00\x00\x04\x00\x00\x00\x00\x00\x00\x00\x04\x00\x05\xe8A\x00\x00\x00\x04\x10\x02\x00\x00\x00\x00\x00\x08\x03\x8a+=\xca\xc0\x00\n\x00\x00\x00$\x00\x00\x00\x08\x03\x8a+=\xca\xc0\x00\n\x00\x00\x00\x04\x00\x00\x00\x00\x00\x00\x00\x04\x00\x00\x08\x00\x00\x00\x00\x04\x00\x00\x00\x00\x00\x00\x00\x08\x03\x8a\x8f\x979\x80\x00\n\x00\x00\x00$\x00\x00\x00\x08\x03\x8a\x8f\x979\x80\x00\n\x00\x00\x00\x04\x00\x00\x00\x00\x00\x00\x00\x04\x00\x00\x00\x00\x00\x00\x00\x04\x00
 \x08\x01

\x00\x00\x00\x04 \xc4\xb4(\x00                     # value 10, position 
(3300141056)
\xff\xff\xff\xff                                   # value 11, recipients (null)
\x00\x00\x00O                                      # value 12, topic (79 char 
string)
[f\x80Q\x07general\x05\xf8G\xc5\xffI\x98\xc4\xb4(\x00\xf8O[f\x80Q\x00\x00\x00\x02\x04\xf8O[f\x80Q\x00\xf8G\xc5\xffI\x98\x01\x00\x00\xf8O[f\x80Q\x00\x00\x00\x00\xf8G\xc5\xffI\x97\xc4\xb4(\x06\x00\xf8O\x7fe\x1fm\x08\x03
\x00\x00\x00\x01 \x00                              # value 13, type (0)
\x00\x00\x00\x04 \x00\x00\x00\x00                  # value 14, user_limit (0)
{noformat}

Do any of the other column values look incorrect to you?


was (Author: thobbs):
I haven't had any luck reproducing this locally yet.  I looked into the 
response that the driver had trouble decoding, and this is the breakdown:

{noformat}
\x84\x00\x00\x1b\x08\x00\x00\x03w\x00\x00\x00\x02\x00\x00\x00\x01\x00\x00\x00\x0f\x00\x10discord_channels\x00\x08channels
  # flags and metadata

\x00\x02id\x00\x02                                 # col 0
\x00\x0eapplication_id\x00\x02                     # col 1
\x00\x07bitrate\x00\t                              # col 2
\x00\x08guild_id\x00\x02                           # col 3
\x00\ticon_hash\x00\r                              # col 4
\x00\x0flast_message_id\x00\x02                    # col 5
\x00\x12last_pin_timestamp\x00\x0b                 # col 6
\x00\x04name\x00\r                                 # col 7
\x00\x08owner_id\x00\x02                           # col 8
\x00\x15permission_overwrites\x00!                 # col 9
  \x00\x02\x000\x00\x10discord_channels\x00\x1c
  channel_permission_overwrite\x00\x04
    \x00\x02id\x00\x02
    \x00\x04type\x00\t
    \x00\x06allow_\x00\t
    \x00\x04deny\x00\t
\x00\x08position\x00\t                             # col 10
\x00\nrecipients\x00!                              # col 11
  \x00\x02\x000\x00\x10discord_channels\x00\x11channel_recipient\x00\x01
  \x00\x04nick\x00\r
\x00\x05topic\x00\r                                # col 12
\x00\x04type\x00\x14                               # col 13
\x00\nuser_limit\x00\t                             # col 14

\x00\x00\x00\x01                                   # row count

\x00\x00\x00\x08 \x03\x8a\x19\x8e\xf8\x82\x00\x01  # value 0, id 
(72201598085466627)

\xff\xff\xff\xff                                   # value 1, application_id 
(null)

\x00\x00\x00\x04 \x00\x00\xfa\x00                  # value 2, bitrate (16384000)

\x00\x00\x00\x08 \x00\x00\xfa\x00\x00\xf8G\xc5     # value 3, guild_id 
(14215603427718332416)

\x00\x00\x00\x00                                   # value 4 icon_hash (empty 
string)

\x00\x00\x00\x08 \x03\x8b\xc0\xb5nB\x00\x02        # value 5 last_message_id 
(144188231338986243)

\x00\x00\x00\x08 G\xc5\xffI\x98\xc4\xb4(           # value 6 last_pin_timestamp 
(2933185415680607559)

\x00\x00\x00\x03 \x8b\xc0\xa8                      # value 7 (non-UTF8 
compliant string)

\xff\xff\xff\xff                                   # value 8, owner_id (null)

\x00\x00\x01<                                      # value 9, (length 316 user 
type)

\x00\x00\x00\x06\x00\x00\x00\x08\x03\x81L\xea\xfc\x82\x00\n\x00\x00\x00$\x00\x00\x00\x08\x03\x81L\xea\xfc\x82\x00\n\x00\x00\x00\x04\x00\x00\x00\x01\x00\x00\x00\x04\x00\x00\x08\x00\x00\x00\x00\x04\x00\x00\x00\x00\x00\x00\x00\x08\x03\x8a\x1e\xe6\x8b\x80\x00\n\x00\x00\x00$\x00\x00\x00\x08\x03\x8a\x1e\xe6\x8b\x80\x00\n\x00\x00\x00\x04\x00\x00\x00\x00\x00\x00\x00\x040\x07\xf8Q\x00\x00\x00\x04\x00\x00\x00\x00\x00\x00\x00\x08\x03\x8a\x1f\x1b{\x82\x00\x00\x00\x00\x00$\x00\x00\x00\x08\x03\x8a\x1f\x1b{\x82\x00\x00\x00\x00\x00\x04\x00\x00\x00\x00\x00\x00\x00\x04\x00\x07\xf8Q\x00\x00\x00\x04\x10\x00\x00\x00\x00\x00\x00\x08\x03\x8a\x1fH6\x82\x00\x01\x00\x00\x00$\x00\x00\x00\x08\x03\x8a\x1fH6\x82\x00\x01\x00\x00\x00\x04\x00\x00\x00\x00\x00\x00\x00\x04\x00\x05\xe8A\x00\x00\x00\x04\x10\x02\x00\x00\x00\x00\x00\x08\x03\x8a+=\xca\xc0\x00\n\x00\x00\x00$\x00\x00\x00\x08\x03\x8a+=\xca\xc0\x00\n\x00\x00\x00\x04\x00\x00\x00\x00\x00\x00\x00\x04\x00\x00\x08\x00\x00\x00\x00\x04\x00\x00\x00\x00\x00\x00\x00\x08\x03\x8a\x8f\x979\x80\x00\n\x00\x00\x00$\x00\x00\x00\x08\x03\x8a\x8f\x979\x80\x00\n\x00\x00\x00\x04\x00\x00\x00\x00\x00\x00\x00\x04\x00\x00\x00\x00\x00\x00\x00\x04\x00
 \x08\x01

\x00\x00\x00\x04 \xc4\xb4(\x00                     # value 10, position 
(3300141056)
\xff\xff\xff\xff                                   # value 11, recipients (null)
\x00\x00\x00O                                      # value 12, nick (79 char 
string)
[f\x80Q\x07general\x05\xf8G\xc5\xffI\x98\xc4\xb4(\x00\xf8O[f\x80Q\x00\x00\x00\x02\x04\xf8O[f\x80Q\x00\xf8G\xc5\xffI\x98\x01\x00\x00\xf8O[f\x80Q\x00\x00\x00\x00\xf8G\xc5\xffI\x97\xc4\xb4(\x06\x00\xf8O\x7fe\x1fm\x08\x03
\x00\x00\x00\x01 \x00                              # value 13, topic (0)
\x00\x00\x00\x04 \x00\x00\x00\x00                  # value 14, type (0)
{noformat}

Do any of the other column values look incorrect to you?

> Corruption while adding a column to a table
> -------------------------------------------
>
>                 Key: CASSANDRA-13004
>                 URL: https://issues.apache.org/jira/browse/CASSANDRA-13004
>             Project: Cassandra
>          Issue Type: Bug
>            Reporter: Stanislav Vishnevskiy
>
> We had the following schema in production. 
> {code:none}
> CREATE TYPE IF NOT EXISTS discord_channels.channel_recipient (
>     nick text
> );
> CREATE TYPE IF NOT EXISTS discord_channels.channel_permission_overwrite (
>     id bigint,
>     type int,
>     allow_ int,
>     deny int
> );
> CREATE TABLE IF NOT EXISTS discord_channels.channels (
>     id bigint,
>     guild_id bigint,
>     type tinyint,
>     name text,
>     topic text,
>     position int,
>     owner_id bigint,
>     icon_hash text,
>     recipients map<bigint, frozen<channel_recipient>>,
>     permission_overwrites map<bigint, frozen<channel_permission_overwrite>>,
>     bitrate int,
>     user_limit int,
>     last_pin_timestamp timestamp,
>     last_message_id bigint,
>     PRIMARY KEY (id)
> );
> {code}
> And then we executed the following alter.
> {code:none}
> ALTER TABLE discord_channels.channels ADD application_id bigint;
> {code}
> And one row (that we can tell) got corrupted at the same time and could no 
> longer be read from the Python driver. 
> {code:none}
> [E 161206 01:56:58 geventreactor:141] Error decoding response from Cassandra. 
> ver(4); flags(0000); stream(27); op(8); offset(9); len(887); buffer: 
> '\x84\x00\x00\x1b\x08\x00\x00\x03w\x00\x00\x00\x02\x00\x00\x00\x01\x00\x00\x00\x0f\x00\x10discord_channels\x00\x08channels\x00\x02id\x00\x02\x00\x0eapplication_id\x00\x02\x00\x07bitrate\x00\t\x00\x08guild_id\x00\x02\x00\ticon_hash\x00\r\x00\x0flast_message_id\x00\x02\x00\x12last_pin_timestamp\x00\x0b\x00\x04name\x00\r\x00\x08owner_id\x00\x02\x00\x15permission_overwrites\x00!\x00\x02\x000\x00\x10discord_channels\x00\x1cchannel_permission_overwrite\x00\x04\x00\x02id\x00\x02\x00\x04type\x00\t\x00\x06allow_\x00\t\x00\x04deny\x00\t\x00\x08position\x00\t\x00\nrecipients\x00!\x00\x02\x000\x00\x10discord_channels\x00\x11channel_recipient\x00\x01\x00\x04nick\x00\r\x00\x05topic\x00\r\x00\x04type\x00\x14\x00\nuser_limit\x00\t\x00\x00\x00\x01\x00\x00\x00\x08\x03\x8a\x19\x8e\xf8\x82\x00\x01\xff\xff\xff\xff\x00\x00\x00\x04\x00\x00\xfa\x00\x00\x00\x00\x08\x00\x00\xfa\x00\x00\xf8G\xc5\x00\x00\x00\x00\x00\x00\x00\x08\x03\x8b\xc0\xb5nB\x00\x02\x00\x00\x00\x08G\xc5\xffI\x98\xc4\xb4(\x00\x00\x00\x03\x8b\xc0\xa8\xff\xff\xff\xff\x00\x00\x01<\x00\x00\x00\x06\x00\x00\x00\x08\x03\x81L\xea\xfc\x82\x00\n\x00\x00\x00$\x00\x00\x00\x08\x03\x81L\xea\xfc\x82\x00\n\x00\x00\x00\x04\x00\x00\x00\x01\x00\x00\x00\x04\x00\x00\x08\x00\x00\x00\x00\x04\x00\x00\x00\x00\x00\x00\x00\x08\x03\x8a\x1e\xe6\x8b\x80\x00\n\x00\x00\x00$\x00\x00\x00\x08\x03\x8a\x1e\xe6\x8b\x80\x00\n\x00\x00\x00\x04\x00\x00\x00\x00\x00\x00\x00\x040\x07\xf8Q\x00\x00\x00\x04\x00\x00\x00\x00\x00\x00\x00\x08\x03\x8a\x1f\x1b{\x82\x00\x00\x00\x00\x00$\x00\x00\x00\x08\x03\x8a\x1f\x1b{\x82\x00\x00\x00\x00\x00\x04\x00\x00\x00\x00\x00\x00\x00\x04\x00\x07\xf8Q\x00\x00\x00\x04\x10\x00\x00\x00\x00\x00\x00\x08\x03\x8a\x1fH6\x82\x00\x01\x00\x00\x00$\x00\x00\x00\x08\x03\x8a\x1fH6\x82\x00\x01\x00\x00\x00\x04\x00\x00\x00\x00\x00\x00\x00\x04\x00\x05\xe8A\x00\x00\x00\x04\x10\x02\x00\x00\x00\x00\x00\x08\x03\x8a+=\xca\xc0\x00\n\x00\x00\x00$\x00\x00\x00\x08\x03\x8a+=\xca\xc0\x00\n\x00\x00\x00\x04\x00\x00\x00\x00\x00\x00\x00\x04\x00\x00\x08\x00\x00\x00\x00\x04\x00\x00\x00\x00\x00\x00\x00\x08\x03\x8a\x8f\x979\x80\x00\n\x00\x00\x00$\x00\x00\x00\x08\x03\x8a\x8f\x979\x80\x00\n\x00\x00\x00\x04\x00\x00\x00\x00\x00\x00\x00\x04\x00\x00\x00\x00\x00\x00\x00\x04\x00
>  
> \x08\x01\x00\x00\x00\x04\xc4\xb4(\x00\xff\xff\xff\xff\x00\x00\x00O[f\x80Q\x07general\x05\xf8G\xc5\xffI\x98\xc4\xb4(\x00\xf8O[f\x80Q\x00\x00\x00\x02\x04\xf8O[f\x80Q\x00\xf8G\xc5\xffI\x98\x01\x00\x00\xf8O[f\x80Q\x00\x00\x00\x00\xf8G\xc5\xffI\x97\xc4\xb4(\x06\x00\xf8O\x7fe\x1fm\x08\x03\x00\x00\x00\x01\x00\x00\x00\x00\x04\x00\x00\x00\x00'
> {code}
> And then in cqlsh when trying to read the row we got this. 
> {code:none}
> /usr/bin/cqlsh.py:632: DateOverFlowWarning: Some timestamps are larger than 
> Python datetime can represent. Timestamps are displayed in milliseconds from 
> epoch.
> Traceback (most recent call last):
>   File "/usr/bin/cqlsh.py", line 1301, in perform_simple_statement
>     result = future.result()
>   File 
> "/usr/share/cassandra/lib/cassandra-driver-internal-only-3.5.0.post0-d8d0456.zip/cassandra-driver-3.5.0.post0-d8d0456/cassandra/cluster.py",
>  line 3650, in result
>     raise self._final_exception
> UnicodeDecodeError: 'utf8' codec can't decode byte 0x80 in position 2: 
> invalid start byte
> {code}
> We tried to read the data and it would refuse to read the name column (the 
> UTF8 error) and the last_pin_timestamp column had an absurdly large value.
> We ended up rewriting the whole row as we had the data in another place and 
> it fixed the problem. However there is clearly a race condition in the schema 
> change sub-system.
> Any ideas?



--
This message was sent by Atlassian JIRA
(v6.3.4#6332)

Reply via email to