Cassandra - Créer un espace clé
Création d'un Keyspace à l'aide de Cqlsh
Un espace de clés dans Cassandra est un espace de noms qui définit la réplication de données sur les nœuds. Un cluster contient un espace de clés par nœud. Vous trouverez ci-dessous la syntaxe pour créer un espace de clés à l'aide de l'instructionCREATE KEYSPACE.
Syntaxe
CREATE KEYSPACE <identifier> WITH <properties>
c'est à dire
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’;
L'instruction CREATE KEYSPACE a deux propriétés: replication et durable_writes.
Réplication
L'option de réplication consiste à spécifier le Replica Placement strategyet le nombre de répliques voulues. Le tableau suivant répertorie toutes les stratégies de placement de réplique.
Nom de la stratégie | La description |
---|---|
Simple Strategy' | Spécifie un facteur de réplication simple pour le cluster. |
Network Topology Strategy | En utilisant cette option, vous pouvez définir le facteur de réplication pour chaque centre de données indépendamment. |
Old Network Topology Strategy | Il s'agit d'une stratégie de réplication héritée. |
En utilisant cette option, vous pouvez indiquer à Cassandra s'il faut utiliser commitlogpour les mises à jour sur le KeySpace actuel. Cette option n'est pas obligatoire et par défaut, elle est définie sur true.
Exemple
Vous trouverez ci-dessous un exemple de création d'un KeySpace.
Ici, nous créons un KeySpace nommé TutorialsPoint.
Nous utilisons la première stratégie de placement de réplique, c'est-à-dire., Simple Strategy.
Et nous choisissons le facteur de réplication pour 1 replica.
cqlsh.> CREATE KEYSPACE tutorialspoint
WITH replication = {'class':'SimpleStrategy', 'replication_factor' : 3};
Vérification
Vous pouvez vérifier si la table est créée ou non à l'aide de la commande Describe. Si vous utilisez cette commande sur les espaces de clés, elle affichera tous les espaces de clés créés comme indiqué ci-dessous.
cqlsh> DESCRIBE keyspaces;
tutorialspoint system system_traces
Ici vous pouvez observer le KeySpace nouvellement créé tutorialspoint.
Durable_writes
Par défaut, les propriétés durables_writes d'une table sont définies sur true,cependant, il peut être défini sur false. Vous ne pouvez pas définir cette propriété sursimplex strategy.
Exemple
L'exemple ci-dessous montre l'utilisation de la propriété d'écritures durables.
cqlsh> CREATE KEYSPACE test
... WITH REPLICATION = { 'class' : 'NetworkTopologyStrategy', 'datacenter1' : 3 }
... AND DURABLE_WRITES = false;
Vérification
Vous pouvez vérifier si la propriété durable_writes de test KeySpace a été définie sur false en interrogeant le System Keyspace. Cette requête vous donne tous les KeySpaces ainsi que leurs propriétés.
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)
Ici, vous pouvez observer que la propriété durable_writes du test KeySpace a été définie sur false.
Utilisation d'un espace clé
Vous pouvez utiliser un KeySpace créé à l'aide du mot-clé USE. Sa syntaxe est la suivante -
Syntax:USE <identifier>
Exemple
Dans l'exemple suivant, nous utilisons le KeySpace tutorialspoint.
cqlsh> USE tutorialspoint;
cqlsh:tutorialspoint>
Création d'un Keyspace à l'aide de l'API Java
Vous pouvez créer un Keyspace en utilisant le execute() méthode de Sessionclasse. Suivez les étapes ci-dessous pour créer un espace de clés à l'aide de l'API Java.
Étape 1: créer un objet de cluster
Tout d'abord, créez une instance de Cluster.builder une sorte de com.datastax.driver.core paquet comme indiqué ci-dessous.
//Creating Cluster.Builder object
Cluster.Builder builder1 = Cluster.builder();
Ajouter un point de contact (adresse IP du nœud) en utilisant addContactPoint() méthode de Cluster.Builderobjet. Cette méthode renvoieCluster.Builder.
//Adding contact point to the Cluster.Builder object
Cluster.Builder builder2 = build.addContactPoint( "127.0.0.1" );
À l'aide du nouvel objet de générateur, créez un objet de cluster. Pour ce faire, vous disposez d'une méthode appeléebuild() dans le Cluster.Builderclasse. Le code suivant montre comment créer un objet de cluster.
//Building a cluster
Cluster cluster = builder.build();
Vous pouvez créer un objet de cluster en une seule ligne de code comme indiqué ci-dessous.
Cluster cluster = Cluster.builder().addContactPoint("127.0.0.1").build();
Étape 2: créer un objet de session
Créer une instance de Session objet utilisant le connect() méthode de Cluster classe comme indiqué ci-dessous.
Session session = cluster.connect( );
Cette méthode crée une nouvelle session et l'initialise. Si vous avez déjà un espace de clés, vous pouvez le définir sur celui existant en transmettant le nom de l'espace de clés au format chaîne à cette méthode, comme indiqué ci-dessous.
Session session = cluster.connect(“ Your keyspace name ” );
Étape 3: Exécuter la requête
Vous pouvez exécuter CQL requêtes utilisant le execute() méthode de Sessionclasse. Transmettez la requête au format chaîne ou enStatement objet de classe au execute()méthode. Tout ce que vous passez à cette méthode au format chaîne sera exécuté sur lecqlsh.
Dans cet exemple, nous créons un KeySpace nommé tp. Nous utilisons la première stratégie de placement de réplique, c'est-à-dire la stratégie simple, et nous choisissons le facteur de réplication à 1 réplique.
Vous devez stocker la requête dans une variable chaîne et la transmettre à la méthode execute () comme indiqué ci-dessous.
String query = "CREATE KEYSPACE tp WITH replication "
+ "= {'class':'SimpleStrategy', 'replication_factor':1}; ";
session.execute(query);
Étape 4: utiliser le KeySpace
Vous pouvez utiliser un KeySpace créé en utilisant la méthode execute () comme indiqué ci-dessous.
execute(“ USE tp ” );
Vous trouverez ci-dessous le programme complet pour créer et utiliser un espace de clés dans Cassandra à l'aide de l'API Java.
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");
}
}
Enregistrez le programme ci-dessus avec le nom de la classe suivi de .java, accédez à l'emplacement où il est enregistré. Compilez et exécutez le programme comme indiqué ci-dessous.
$javac Create_KeySpace.java
$java Create_KeySpace
Dans des conditions normales, il produira la sortie suivante -
Keyspace created