कैसेंड्रा - ऑल्टर कीस्पेस

कीस्पेस को बदलना

ALTER KEYSPACE का उपयोग संपत्तियों को बदलने के लिए किया जा सकता है जैसे प्रतिकृतियों की संख्या और एक KeySpace के टिकाऊ_लेख। नीचे दिए गए इस कमांड का सिंटैक्स है।

वाक्य - विन्यास

ALTER KEYSPACE <identifier> WITH <properties>

अर्थात

ALTER KEYSPACE “KeySpace Name”
WITH replication = {'class': ‘Strategy name’, 'replication_factor' : ‘No.Of  replicas’};

के गुण ALTER KEYSPACEक्रिएट कुंजी के समान हैं। इसके दो गुण हैं:replication तथा durable_writes

प्रतिकृति

प्रतिकृति विकल्प प्रतिकृति प्लेसमेंट रणनीति और प्रतिकृतियों की संख्या चाहता था।

Durable_writes

इस विकल्प का उपयोग करते हुए, आप कैसंड्रा को निर्देश दे सकते हैं कि वर्तमान KeySpace पर अद्यतनों के लिए आरेख का उपयोग करना है या नहीं। यह विकल्प अनिवार्य नहीं है और डिफ़ॉल्ट रूप से, यह सही पर सेट है।

उदाहरण

नीचे दिए गए कीस्पेस को बदलने का एक उदाहरण है।

  • यहां हम एक KeySpace नाम बदल रहे हैं TutorialsPoint

  • हम 1 से 3 तक प्रतिकृति कारक बदल रहे हैं।

cqlsh.> ALTER KEYSPACE tutorialspoint
WITH replication = {'class':'NetworkTopologyStrategy', 'replication_factor' : 3};

टिकाऊ_लेखों को बदलना

आप KeySpace की टिकाऊ_लेखी संपत्ति को भी बदल सकते हैं। नीचे दी गई टिकाऊ_लेखों की संपत्ति हैtest KeySpace।

SELECT * FROM system.schema_keyspaces;

  keyspace_name | durable_writes |                                       strategy_class | strategy_options
----------------+----------------+------------------------------------------------------+----------------------------
           test |          False | org.apache.cassandra.locator.NetworkTopologyStrategy | {"datacenter1":"3"}

 tutorialspoint |           True |          org.apache.cassandra.locator.SimpleStrategy | {"replication_factor":"4"}

         system |           True |           org.apache.cassandra.locator.LocalStrategy | { }

  system_traces |           True |          org.apache.cassandra.locator.SimpleStrategy | {"replication_factor":"2"}
(4 rows)

ALTER KEYSPACE test
WITH REPLICATION = {'class' : 'NetworkTopologyStrategy', 'datacenter1' : 3}
AND DURABLE_WRITES = true;

एक बार फिर, यदि आप KeySpaces के गुणों को सत्यापित करते हैं, तो यह निम्न आउटपुट का उत्पादन करेगा।

SELECT * FROM system.schema_keyspaces;
  keyspace_name | durable_writes |                                       strategy_class | strategy_options
----------------+----------------+------------------------------------------------------+----------------------------
           test |           True | org.apache.cassandra.locator.NetworkTopologyStrategy | {"datacenter1":"3"}

 tutorialspoint |           True |          org.apache.cassandra.locator.SimpleStrategy | {"replication_factor":"4"}

         system |           True |           org.apache.cassandra.locator.LocalStrategy | { }

  system_traces |           True |          org.apache.cassandra.locator.SimpleStrategy | {"replication_factor":"2"}

(4 rows)

जावा एपीआई का उपयोग करके एक कीस्पेस को बदलना

आप का उपयोग करके एक कीस्पेस को बदल सकते हैं execute() उसकि विधि Sessionकक्षा। जावा एपीआई का उपयोग करके एक कीस्पेस को बदलने के लिए नीचे दिए गए चरणों का पालन करें

Step1: एक क्लस्टर ऑब्जेक्ट बनाएँ

सबसे पहले, का एक उदाहरण बनाएँ Cluster.builder की कक्षा com.datastax.driver.core पैकेज के रूप में नीचे दिखाया गया है।

//Creating Cluster.Builder object
Cluster.Builder builder1 = Cluster.builder();

का उपयोग करके एक संपर्क बिंदु (नोड का आईपी पता) जोड़ें addContactPoint() उसकि विधि Cluster.Builderवस्तु। यह विधि लौटती हैCluster.Builder

//Adding contact point to the Cluster.Builder object
Cluster.Builder builder2 = build.addContactPoint( "127.0.0.1" );

नए बिल्डर ऑब्जेक्ट का उपयोग करके, क्लस्टर ऑब्जेक्ट बनाएँ। ऐसा करने के लिए, आपके पास एक विधि हैbuild() में Cluster.Builderकक्षा। निम्न कोड दिखाता है कि क्लस्टर ऑब्जेक्ट कैसे बनाया जाता है।

//Building a cluster

Cluster cluster = builder.build();

आप नीचे दिखाए गए अनुसार कोड की एक लाइन का उपयोग करके क्लस्टर ऑब्जेक्ट का निर्माण कर सकते हैं।

Cluster cluster = Cluster.builder().addContactPoint("127.0.0.1").build();

चरण 2: एक सत्र वस्तु बनाएँ

का एक उदाहरण बनाएँ Session का उपयोग कर वस्तु connect() उसकि विधि Clusterनीचे दिखाया गया है।

Session session = cluster.connect( );

यह विधि एक नया सत्र बनाती है और इसे आरंभ करती है। यदि आपके पास पहले से ही एक कीस्पेस है, तो आप इसे नीचे दिखाए गए अनुसार स्ट्रिंग मोड में की-स्पेस नाम से पास करके मौजूदा एक पर सेट कर सकते हैं।

Session session = cluster.connect(“ Your keyspace name ” );

चरण 3: क्वेरी को निष्पादित करें

आप सत्र वर्ग के निष्पादन () विधि का उपयोग करके CQL प्रश्नों को निष्पादित कर सकते हैं। क्वेरी को या तो स्ट्रिंग प्रारूप में या एक के रूप में पास करेंStatementनिष्पादन के लिए वर्ग वस्तु () विधि। आप स्ट्रिंग प्रारूप में इस पद्धति से जो भी पास करेंगे, उस पर अमल किया जाएगाcqlsh

इस उदाहरण में,

  • हम नाम के एक कीस्पेस को बदल रहे हैं tp। हम सरल रणनीति से नेटवर्क टोपोलॉजी रणनीति के प्रतिकृति विकल्प को बदल रहे हैं।

  • हम बदल रहे हैं durable_writes असत्य को

आपको क्वेरी को एक स्ट्रिंग चर में संग्रहीत करना होगा और इसे नीचे निष्पादित () विधि में दिखाया गया है।

//Query
String query = "ALTER KEYSPACE tp WITH replication " + "=   {'class':'NetworkTopologyStrategy', 'datacenter1':3}" +" AND DURABLE_WRITES = false;";
session.execute(query);

नीचे दिए गए जावा एपीआई का उपयोग करके कैसेंड्रा में एक कुंजीस्पेस बनाने और उपयोग करने के लिए पूरा कार्यक्रम है।

import com.datastax.driver.core.Cluster;
import com.datastax.driver.core.Session;

public class Alter_KeySpace {
   public static void main(String args[]){

      //Query
      String query = "ALTER KEYSPACE tp WITH replication " + "= {'class':'NetworkTopologyStrategy', 'datacenter1':3}"
         + "AND DURABLE_WRITES = false;";

      //Creating Cluster object
      Cluster cluster = Cluster.builder().addContactPoint("127.0.0.1").build();
   
      //Creating Session object
      Session session = cluster.connect();
 
      //Executing the query
      session.execute(query);
 
      System.out.println("Keyspace altered");
   }
}

उपरोक्त प्रोग्राम को .java के बाद वाले वर्ग नाम से सहेजें, उस स्थान पर ब्राउज़ करें जहाँ इसे सहेजा गया है। नीचे दिखाए अनुसार कार्यक्रम को संकलित और निष्पादित करें।

$javac Alter_KeySpace.java $java Alter_KeySpace

सामान्य परिस्थितियों में, यह निम्न आउटपुट का उत्पादन करता है -

Keyspace Altered