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