Cassandra - Modifier l'espace clé

Modifier un KeySpace

ALTER KEYSPACE peut être utilisé pour modifier des propriétés telles que le nombre de répliques et les écritures durables d'un KeySpace. Vous trouverez ci-dessous la syntaxe de cette commande.

Syntaxe

ALTER KEYSPACE <identifier> WITH <properties>

c'est à dire

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

Les propriétés de ALTER KEYSPACEsont identiques à CREATE KEYSPACE. Il a deux propriétés:replication et durable_writes.

Réplication

L'option de réplication spécifie la stratégie de placement des répliques et le nombre de répliques souhaitées.

Durable_writes

En utilisant cette option, vous pouvez indiquer à Cassandra s'il faut utiliser le commitlog pour les mises à jour sur le KeySpace actuel. Cette option n'est pas obligatoire et par défaut, elle est définie sur true.

Exemple

Ci-dessous, un exemple de modification d'un KeySpace.

  • Ici, nous modifions un KeySpace nommé TutorialsPoint.

  • Nous changeons le facteur de réplication de 1 à 3.

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

Modification des écritures durables

Vous pouvez également modifier la propriété durable_writes d'un KeySpace. Ci-dessous, la propriété durable_writes dutest 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;

Encore une fois, si vous vérifiez les propriétés de KeySpaces, il produira la sortie suivante.

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)

Modification d'un espace clé à l'aide de l'API Java

Vous pouvez modifier un espace de clés en utilisant le execute() méthode de Sessionclasse. Suivez les étapes ci-dessous pour modifier 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();

Ajoutez un point de contact (adresse IP du nœud) à l'aide du 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 l'objet de cluster en utilisant 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 Clusterclasse 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 des requêtes CQL en utilisant la méthode execute () de la classe Session. Transmettez la requête au format chaîne ou enStatementobjet de classe à la méthode execute (). Tout ce que vous passez à cette méthode au format chaîne sera exécuté sur lecqlsh.

Dans cet exemple,

  • Nous modifions un espace de clés nommé tp. Nous modifions l'option de réplication de la stratégie simple à la stratégie de topologie de réseau.

  • Nous modifions le durable_writes à faux

Vous devez stocker la requête dans une variable chaîne et la transmettre à la méthode execute () comme indiqué ci-dessous.

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

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 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");
   }
}

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 Alter_KeySpace.java $java Alter_KeySpace

Dans des conditions normales, il produit la sortie suivante -

Keyspace Altered