कैसेंड्रा - कीस्पेस बनाएँ

Cqlsh का उपयोग करके एक कीस्पेस बनाएँ

कैसेंड्रा में एक कुंजीस्पेस एक नाम स्थान है जो नोड्स पर डेटा प्रतिकृति को परिभाषित करता है। क्लस्टर में प्रति नोड एक कुंजी क्षेत्र होता है। नीचे दिए गए कथन का उपयोग करके एक कीस्पेस बनाने के लिए सिंटैक्स हैCREATE KEYSPACE

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

CREATE KEYSPACE <identifier> WITH <properties>

अर्थात

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

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

AND durable_writes = ‘Boolean value’;

क्रीज कुंजी कथन के दो गुण हैं: replication तथा durable_writes

प्रतिकृति

प्रतिकृति विकल्प को निर्दिष्ट करना है Replica Placement strategyऔर प्रतिकृतियों की संख्या चाहता था। निम्न तालिका सभी प्रतिकृति प्लेसमेंट रणनीतियों को सूचीबद्ध करती है।

रणनीति का नाम विवरण
Simple Strategy' क्लस्टर के लिए एक सरल प्रतिकृति कारक निर्दिष्ट करता है।
Network Topology Strategy इस विकल्प का उपयोग करके, आप प्रत्येक डेटा-सेंटर के लिए स्वतंत्र रूप से प्रतिकृति कारक सेट कर सकते हैं।
Old Network Topology Strategy यह एक विरासत प्रतिकृति रणनीति है।

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

उदाहरण

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

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

  • हम पहली प्रतिकृति प्लेसमेंट रणनीति का उपयोग कर रहे हैं, यानी। Simple Strategy

  • और हम प्रतिकृति कारक को चुन रहे हैं 1 replica

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

सत्यापन

आप यह सत्यापित कर सकते हैं कि कमांड का उपयोग करके तालिका बनाई गई है या नहीं Describe। यदि आप इस आदेश का उपयोग कीस्पेस पर करते हैं, तो यह नीचे दिखाए गए अनुसार बनाए गए सभी कीस्पेस प्रदर्शित करेगा।

cqlsh> DESCRIBE keyspaces;

tutorialspoint system system_traces

यहां आप नए बनाए गए KeySpace का अवलोकन कर सकते हैं tutorialspoint.

Durable_writes

डिफ़ॉल्ट रूप से, किसी तालिका के टिकाऊ_ राइट्स गुण सेट किए जाते हैं true,हालाँकि इसे झूठे के लिए सेट किया जा सकता है। आप इस संपत्ति को सेट नहीं कर सकते हैंsimplex strategy.

उदाहरण

नीचे दिया गया उदाहरण टिकाऊ लेखन संपत्ति के उपयोग को प्रदर्शित करता है।

cqlsh> CREATE KEYSPACE test
... WITH REPLICATION = { 'class' : 'NetworkTopologyStrategy', 'datacenter1' : 3 }
... AND DURABLE_WRITES = false;

सत्यापन

आप यह सत्यापित कर सकते हैं कि सिस्टम Keyspace की क्वेरी के द्वारा KeySpace परीक्षण की टिकाऊ_ राइट्स संपत्ति को गलत पर सेट किया गया था या नहीं। यह क्वेरी आपको उनके गुणों के साथ सभी KeySpaces देता है।

cqlsh> 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)

यहां आप परीक्षण के टिकाऊ_लेखों का निरीक्षण कर सकते हैं किस्पेस की संपत्ति गलत पर सेट की गई थी।

एक Keyspace का उपयोग करना

आप कीवर्ड का उपयोग करके बनाए गए कीस्पेस का उपयोग कर सकते हैं USE। इसका सिंटैक्स इस प्रकार है -

Syntax:USE <identifier>

उदाहरण

निम्नलिखित उदाहरण में, हम कीस्पेस का उपयोग कर रहे हैं tutorialspoint.

cqlsh> USE tutorialspoint;
cqlsh:tutorialspoint>

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

आप का उपयोग कर एक Keyspace बना सकते हैं 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 का उपयोग कर प्रश्न execute() उसकि विधि Sessionकक्षा। क्वेरी को या तो स्ट्रिंग प्रारूप में या एक के रूप में पास करेंStatement वर्ग वस्तु के लिए execute()तरीका। आप स्ट्रिंग प्रारूप में इस पद्धति से जो भी पास करेंगे, उस पर अमल किया जाएगाcqlsh

इस उदाहरण में, हम एक KeySpace नाम बना रहे हैं tp. हम पहली प्रतिकृति प्लेसमेंट रणनीति का उपयोग कर रहे हैं, अर्थात, सरल रणनीति, और हम प्रतिकृति कारक को 1 प्रतिकृति के लिए चुन रहे हैं।

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

String query = "CREATE KEYSPACE tp WITH replication "
   + "= {'class':'SimpleStrategy', 'replication_factor':1}; ";
session.execute(query);

Step4: कीस्पेस का उपयोग करें

आप नीचे दिखाए गए अनुसार निष्पादित () विधि का उपयोग करके एक बनाया कीस्पेस का उपयोग कर सकते हैं।

execute(“ USE tp ” );

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

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

public class Create_KeySpace {

   public static void main(String args[]){

      //Query
      String query = "CREATE KEYSPACE tp WITH replication "
         + "= {'class':'SimpleStrategy', 'replication_factor':1};";
                    
      //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);
     
      //using the KeySpace
      session.execute("USE tp");
      System.out.println("Keyspace created"); 
   }
}

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

$javac Create_KeySpace.java
$java Create_KeySpace

सामान्य परिस्थितियों में, यह निम्नलिखित उत्पादन करेगा -

Keyspace created