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

Adam Holmberg commented on CASSANDRA-9310:
------------------------------------------

{quote}Actually, just realized that is v3 of the protocol, so this won't have 
the target.{quote}
I'm not sure what you mean. This is only observed in C* 2.0 and 1.2.

Here is the problem as I see it (testing in this case with C* 2.0.14):
When CREATE INDEX DDL is executed, we always get back a SCHEMA_CHANGE response 
that contains the pertinent 'table'.
{noformat}
EVENT {'keyspace': u'index_map_tests', 'change_type': u'UPDATED', 'table': 
u'test_index_updates'}
RESPONSE {'keyspace': u'index_map_tests', 'change_type': u'UPDATED', 'table': 
u'test_index_updates'}
{noformat}

When we DROP INDEX that same thing, the SCHEMA_CHANGE response is missing the 
'table'. It is still present (as expected) in the async event.
{noformat}
EVENT {'keyspace': u'index_map_tests', 'change_type': u'UPDATED', 'table': 
u'test_index_updates'}
RESPONSE {'keyspace': u'index_map_tests', 'change_type': u'UPDATED', 'table': 
u''}
{noformat}

> Table change response returns as keyspace change response
> ---------------------------------------------------------
>
>                 Key: CASSANDRA-9310
>                 URL: https://issues.apache.org/jira/browse/CASSANDRA-9310
>             Project: Cassandra
>          Issue Type: Bug
>         Environment: C* 1.2.19 and 2.0.14 | python-driver master (upcoming v. 
> 2.6)
>            Reporter: Kishan Karunaratne
>            Assignee: Carl Yeksigian
>
> When an index is dropped, its existence is still persisted across the 
> keyspace metadata. This happens because the response to drop the index from 
> the metadata is never received, as a keyspace change response is 
> (incorrectly) received by the driver instead of a table change response. 
> Related to PYTHON-241: https://datastax-oss.atlassian.net/browse/PYTHON-241
> Test:
> {noformat}
> self.session.execute("CREATE TABLE %s (k int PRIMARY KEY, a int)" % 
> self.table_name)
> ks_meta = self.cluster.metadata.keyspaces[self.keyspace_name]
> table_meta = ks_meta.tables[self.table_name]
> self.assertNotIn('a_idx', ks_meta.indexes)
> self.assertNotIn('b_idx', ks_meta.indexes)
> self.assertNotIn('a_idx', table_meta.indexes)
> self.assertNotIn('b_idx', table_meta.indexes)
> self.session.execute("CREATE INDEX a_idx ON %s (a)" % self.table_name)
> self.session.execute("ALTER TABLE %s ADD b int" % self.table_name)
> self.session.execute("CREATE INDEX b_idx ON %s (b)" % self.table_name)
> ks_meta = self.cluster.metadata.keyspaces[self.keyspace_name]
> table_meta = ks_meta.tables[self.table_name]
> self.assertIsInstance(ks_meta.indexes['a_idx'], IndexMetadata)
> self.assertIsInstance(ks_meta.indexes['b_idx'], IndexMetadata)
> self.assertIsInstance(table_meta.indexes['a_idx'], IndexMetadata)
> self.assertIsInstance(table_meta.indexes['b_idx'], IndexMetadata)
> # both indexes updated when index dropped
> self.session.execute("DROP INDEX a_idx")
> ks_meta = self.cluster.metadata.keyspaces[self.keyspace_name]
> table_meta = ks_meta.tables[self.table_name]
> self.assertNotIn('a_idx', ks_meta.indexes)
> {noformat}
> Output:
> {noformat}
> AssertionError: 'a_idx' unexpectedly found in {u'b_idx': 
> <cassandra.metadata.IndexMetadata object at 0x7f2dd87d4590>, u'a_idx': 
> <cassandra.metadata.IndexMetadata object at 0x7f2dd87d4a10>}
> {noformat}
> Debug log:
> {noformat}
> cassandra.connection: DEBUG: Message pushed from server: 
> <EventMessage(stream_id=-1, event_type=u'SCHEMA_CHANGE', 
> event_args={'keyspace': u'index_map_tests', 'change_type': u'CREATED', 
> 'table': u''}, trace_id=None)>
> cassandra.cluster: DEBUG: Refreshing schema in response to schema change. 
> Keyspace: index_map_tests; Table: , Type: None
> cassandra.cluster: DEBUG: [control connection] Waiting for schema agreement
> cassandra.cluster: DEBUG: [control connection] Schemas mismatched, trying 
> again
> cassandra.cluster: DEBUG: [control connection] Schemas mismatched, trying 
> again
> cassandra.cluster: DEBUG: [control connection] Schemas mismatched, trying 
> again
> cassandra.cluster: DEBUG: [control connection] Schemas match
> cassandra.cluster: DEBUG: [control connection] Waiting for schema agreement
> cassandra.cluster: DEBUG: [control connection] Fetched keyspace info for 
> index_map_tests, rebuilding metadata
> cassandra.cluster: DEBUG: [control connection] Schemas match
> cassandra.cluster: DEBUG: [control connection] Fetched keyspace info for 
> index_map_tests, rebuilding metadata
> cassandra.connection: DEBUG: Message pushed from server: 
> <EventMessage(stream_id=-1, event_type=u'SCHEMA_CHANGE', 
> event_args={'keyspace': u'index_map_tests', 'change_type': u'CREATED', 
> 'table': u'test_index_updates'}, trace_id=None)>
> cassandra.cluster: DEBUG: Refreshing schema in response to schema change. 
> Keyspace: index_map_tests; Table: test_index_updates, Type: None
> cassandra.cluster: DEBUG: [control connection] Waiting for schema agreement
> cassandra.cluster: DEBUG: [control connection] Schemas mismatched, trying 
> again
> cassandra.cluster: DEBUG: [control connection] Schemas mismatched, trying 
> again
> cassandra.cluster: DEBUG: [control connection] Schemas match
> cassandra.cluster: DEBUG: [control connection] Fetched table info for 
> index_map_tests.test_index_updates, rebuilding metadata
> cassandra.connection: DEBUG: Message pushed from server: 
> <EventMessage(stream_id=-1, event_type=u'SCHEMA_CHANGE', 
> event_args={'keyspace': u'index_map_tests', 'change_type': u'UPDATED', 
> 'table': u'test_index_updates'}, trace_id=None)>
> cassandra.cluster: DEBUG: Ignoring schedule_unique for already-scheduled 
> task: (<bound method ControlConnection.refresh_schema of 
> <cassandra.cluster.ControlConnection object at 0x7f9c6864fc90>>, 
> (u'index_map_tests', u'test_index_updates', None))
> cassandra.cluster: DEBUG: Refreshing schema in response to schema change. 
> Keyspace: index_map_tests; Table: test_index_updates, Type: None
> cassandra.cluster: DEBUG: [control connection] Waiting for schema agreement
> cassandra.cluster: DEBUG: [control connection] Schemas mismatched, trying 
> again
> cassandra.cluster: DEBUG: [control connection] Schemas mismatched, trying 
> again
> cassandra.cluster: DEBUG: [control connection] Schemas match
> cassandra.cluster: DEBUG: [control connection] Fetched table info for 
> index_map_tests.test_index_updates, rebuilding metadata
> cassandra.cluster: DEBUG: [control connection] Waiting for schema agreement
> cassandra.cluster: DEBUG: [control connection] Schemas match
> cassandra.cluster: DEBUG: [control connection] Fetched table info for 
> index_map_tests.test_index_updates, rebuilding metadata
> cassandra.connection: DEBUG: Message pushed from server: 
> <EventMessage(stream_id=-1, event_type=u'SCHEMA_CHANGE', 
> event_args={'keyspace': u'index_map_tests', 'change_type': u'UPDATED', 
> 'table': u'test_index_updates'}, trace_id=None)>
> cassandra.cluster: DEBUG: Refreshing schema in response to schema change. 
> Keyspace: index_map_tests; Table: test_index_updates, Type: None
> cassandra.cluster: DEBUG: [control connection] Waiting for schema agreement
> cassandra.cluster: DEBUG: [control connection] Schemas mismatched, trying 
> again
> cassandra.cluster: DEBUG: [control connection] Schemas mismatched, trying 
> again
> cassandra.cluster: DEBUG: [control connection] Schemas match
> cassandra.cluster: DEBUG: [control connection] Fetched table info for 
> index_map_tests.test_index_updates, rebuilding metadata
> cassandra.cluster: DEBUG: [control connection] Waiting for schema agreement
> cassandra.cluster: DEBUG: [control connection] Schemas match
> cassandra.cluster: DEBUG: [control connection] Fetched table info for 
> index_map_tests.test_index_updates, rebuilding metadata
> cassandra.cluster: DEBUG: Refreshing schema in response to schema change. 
> Keyspace: index_map_tests; Table: test_index_updates, Type: None
> cassandra.cluster: DEBUG: [control connection] Waiting for schema agreement
> cassandra.connection: DEBUG: Message pushed from server: 
> <EventMessage(stream_id=-1, event_type=u'SCHEMA_CHANGE', 
> event_args={'keyspace': u'index_map_tests', 'change_type': u'UPDATED', 
> 'table': u'test_index_updates'}, trace_id=None)>
> cassandra.cluster: DEBUG: [control connection] Schemas mismatched, trying 
> again
> cassandra.cluster: DEBUG: [control connection] Schemas mismatched, trying 
> again
> cassandra.cluster: DEBUG: [control connection] Schemas match
> cassandra.cluster: DEBUG: [control connection] Waiting for schema agreement
> cassandra.cluster: DEBUG: [control connection] Schemas match
> cassandra.cluster: DEBUG: [control connection] Fetched table info for 
> index_map_tests.test_index_updates, rebuilding metadata
> cassandra.cluster: DEBUG: [control connection] Fetched table info for 
> index_map_tests.test_index_updates, rebuilding metadata
> cassandra.connection: DEBUG: Message pushed from server: 
> <EventMessage(stream_id=-1, event_type=u'SCHEMA_CHANGE', 
> event_args={'keyspace': u'index_map_tests', 'change_type': u'UPDATED', 
> 'table': u'test_index_updates'}, trace_id=None)>
> cassandra.cluster: DEBUG: Refreshing schema in response to schema change. 
> Keyspace: index_map_tests; Table: , Type: None
> cassandra.cluster: DEBUG: [control connection] Waiting for schema agreement
> cassandra.cluster: DEBUG: [control connection] Schemas mismatched, trying 
> again
> cassandra.cluster: DEBUG: [control connection] Schemas match
> cassandra.cluster: DEBUG: [control connection] Fetched keyspace info for 
> index_map_tests, rebuilding metadata
> {noformat}



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

Reply via email to