कैसेंड्रा - कीस्पेस बनाएँ
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