Paulo Motta created CASSANDRA-12935:
---------------------------------------

             Summary: Use saved tokens when setting local tokens on 
StorageService.joinRing()
                 Key: CASSANDRA-12935
                 URL: https://issues.apache.org/jira/browse/CASSANDRA-12935
             Project: Cassandra
          Issue Type: Bug
          Components: Coordination
            Reporter: Paulo Motta
            Assignee: Paulo Motta
            Priority: Minor


The introduction of {{StorageService.finishJoiningRing()}} on CASSANDRA-8523:
{code:java}
@@ -885,17 +896,14 @@ public class StorageService extends 
NotificationBroadcasterSupport implements IE
         {
             if (dataAvailable)
             {
-                // start participating in the ring.
-                
SystemKeyspace.setBootstrapState(SystemKeyspace.BootstrapState.COMPLETED);
-                setTokens(bootstrapTokens);
+                finishJoiningRing();
+
                 // remove the existing info about the replaced node.
                 if (!current.isEmpty())
                 {
                     for (InetAddress existing : current)
                         Gossiper.instance.replacedEndpoint(existing);
                 }
-                assert tokenMetadata.sortedTokens().size() > 0;
-                doAuthSetup();
             }
             else
             {
@@ -908,6 +916,11 @@ public class StorageService extends 
NotificationBroadcasterSupport implements IE
         else if (isSurveyMode)
         {
-            setTokens(SystemKeyspace.getSavedTokens());
-            
SystemKeyspace.setBootstrapState(SystemKeyspace.BootstrapState.COMPLETED);
             isSurveyMode = false;
             logger.info("Leaving write survey mode and joining ring at 
operator request");
-            assert tokenMetadata.sortedTokens().size() > 0;
-
-            doAuthSetup();
+            finishJoiningRing();
         }
     }
 
+    private void finishJoiningRing()
+    {
+        // start participating in the ring.
+        
SystemKeyspace.setBootstrapState(SystemKeyspace.BootstrapState.COMPLETED);
+        setTokens(bootstrapTokens);
+
+        assert tokenMetadata.sortedTokens().size() > 0;
+        doAuthSetup();
+    }
+
{code}

slightly changed the way tokens are set on {{StorageService.joinRing()}} when 
{{cassandra.write_survey=true}} from 
{{setTokens(SystemKeyspace.getSavedTokens())}}
to {{setTokens(bootstrapTokens)}}.



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

Reply via email to