Cassandra - Commandes Shell

Cassandra fournit des commandes shell documentées en plus des commandes CQL. Vous trouverez ci-dessous les commandes shell documentées par Cassandra.

Aidez-moi

La commande HELP affiche un synopsis et une brève description de toutes les commandes cqlsh. Vous trouverez ci-dessous l'utilisation de la commande help.

cqlsh> help

Documented shell commands:
===========================
CAPTURE COPY DESCRIBE EXPAND PAGING SOURCE
CONSISTENCY DESC EXIT HELP SHOW TRACING.

CQL help topics:
================
ALTER           CREATE_TABLE_OPTIONS       SELECT
ALTER_ADD       CREATE_TABLE_TYPES         SELECT_COLUMNFAMILY
ALTER_ALTER     CREATE_USER                SELECT_EXPR
ALTER_DROP      DELETE                     SELECT_LIMIT
ALTER_RENAME    DELETE_COLUMNS             SELECT_TABLE

Capturer

Cette commande capture la sortie d'une commande et l'ajoute à un fichier. Par exemple, jetez un œil au code suivant qui capture la sortie dans un fichier nomméOutputfile.

cqlsh> CAPTURE '/home/hadoop/CassandraProgs/Outputfile'

Lorsque nous tapons une commande dans le terminal, la sortie sera capturée par le fichier donné. Ci-dessous, la commande utilisée et l'instantané du fichier de sortie.

cqlsh:tutorialspoint> select * from emp;

Vous pouvez désactiver la capture à l'aide de la commande suivante.

cqlsh:tutorialspoint> capture off;

Cohérence

Cette commande affiche le niveau de cohérence actuel ou définit un nouveau niveau de cohérence.

cqlsh:tutorialspoint> CONSISTENCY
Current consistency level is 1.

Copie

Cette commande copie les données vers et depuis Cassandra dans un fichier. Ci-dessous un exemple pour copier la table nomméeemp au dossier myfile.

cqlsh:tutorialspoint> COPY emp (emp_id, emp_city, emp_name, emp_phone,emp_sal) TO ‘myfile’;
4 rows exported in 0.034 seconds.

Si vous ouvrez et vérifiez le fichier fourni, vous pouvez trouver les données copiées comme indiqué ci-dessous.

Décris

Cette commande décrit le cluster actuel de Cassandra et ses objets. Les variantes de cette commande sont expliquées ci-dessous.

Describe cluster - Cette commande fournit des informations sur le cluster.

cqlsh:tutorialspoint> describe cluster;

Cluster: Test Cluster
Partitioner: Murmur3Partitioner

Range ownership:
                  -658380912249644557 [127.0.0.1]
                  -2833890865268921414 [127.0.0.1]
                  -6792159006375935836 [127.0.0.1]

Describe Keyspaces- Cette commande répertorie tous les espaces de clés d'un cluster. Vous trouverez ci-dessous l'utilisation de cette commande.

cqlsh:tutorialspoint> describe keyspaces;

system_traces system tp tutorialspoint

Describe tables- Cette commande répertorie toutes les tables d'un espace de clés. Vous trouverez ci-dessous l'utilisation de cette commande.

cqlsh:tutorialspoint> describe tables;
emp

Describe table- Cette commande fournit la description d'une table. Vous trouverez ci-dessous l'utilisation de cette commande.

cqlsh:tutorialspoint> describe table emp;

CREATE TABLE tutorialspoint.emp (
   emp_id int PRIMARY KEY,
   emp_city text,
   emp_name text,
   emp_phone varint,
   emp_sal varint
) WITH bloom_filter_fp_chance = 0.01
   AND caching = '{"keys":"ALL", "rows_per_partition":"NONE"}'
   AND comment = ''
   AND compaction = {'min_threshold': '4', 'class':
   'org.apache.cassandra.db.compaction.SizeTieredCompactionStrategy',
   'max_threshold': '32'}
	
   AND compression = {'sstable_compression':
   'org.apache.cassandra.io.compress.LZ4Compressor'}
	
   AND dclocal_read_repair_chance = 0.1
   AND default_time_to_live = 0
   AND gc_grace_seconds = 864000
   AND max_index_interval = 2048
   AND memtable_flush_period_in_ms = 0
   AND min_index_interval = 128
   AND read_repair_chance = 0.0
   AND speculative_retry = '99.0PERCENTILE';
CREATE INDEX emp_emp_sal_idx ON tutorialspoint.emp (emp_sal);

Décrivez le type

Cette commande est utilisée pour décrire un type de données défini par l'utilisateur. Vous trouverez ci-dessous l'utilisation de cette commande.

cqlsh:tutorialspoint> describe type card_details;

CREATE TYPE tutorialspoint.card_details (
   num int,
   pin int,
   name text,
   cvv int,
   phone set<int>,
   mail text
);

Décrire les types

Cette commande répertorie tous les types de données définis par l'utilisateur. Vous trouverez ci-dessous l'utilisation de cette commande. Supposons qu'il existe deux types de données définis par l'utilisateur:card et card_details.

cqlsh:tutorialspoint> DESCRIBE TYPES;

card_details card

Développer

Cette commande est utilisée pour développer la sortie. Avant d'utiliser cette commande, vous devez activer la commande d'expansion. Vous trouverez ci-dessous l'utilisation de cette commande.

cqlsh:tutorialspoint> expand on;
cqlsh:tutorialspoint> select * from emp;

@ Row 1
-----------+------------
    emp_id | 1
  emp_city | Hyderabad
  emp_name | ram
 emp_phone | 9848022338
   emp_sal | 50000
  
@ Row 2
-----------+------------
    emp_id | 2
  emp_city | Delhi
  emp_name | robin
 emp_phone | 9848022339
   emp_sal | 50000
  
@ Row 3
-----------+------------
    emp_id | 4
  emp_city | Pune
  emp_name | rajeev
 emp_phone | 9848022331
   emp_sal | 30000
  
@ Row 4
-----------+------------
    emp_id | 3
  emp_city | Chennai
  emp_name | rahman
 emp_phone | 9848022330
   emp_sal | 50000
(4 rows)

Note - Vous pouvez désactiver l'option d'extension à l'aide de la commande suivante.

cqlsh:tutorialspoint> expand off;
Disabled Expanded output.

Sortie

Cette commande est utilisée pour terminer le shell cql.

Spectacle

Cette commande affiche les détails de la session cqlsh en cours, comme la version de Cassandra, l'hôte ou les hypothèses de type de données. Vous trouverez ci-dessous l'utilisation de cette commande.

cqlsh:tutorialspoint> show host;
Connected to Test Cluster at 127.0.0.1:9042.

cqlsh:tutorialspoint> show version;
[cqlsh 5.0.1 | Cassandra 2.1.2 | CQL spec 3.2.0 | Native protocol v3]

La source

En utilisant cette commande, vous pouvez exécuter les commandes dans un fichier. Supposons que notre fichier d'entrée soit le suivant -

Ensuite, vous pouvez exécuter le fichier contenant les commandes comme indiqué ci-dessous.

cqlsh:tutorialspoint> source '/home/hadoop/CassandraProgs/inputfile';

 emp_id |  emp_city | emp_name |  emp_phone | emp_sal
--------+-----------+----------+------------+---------
      1 | Hyderabad |   ram    | 9848022338 | 50000
      2 | Delhi     |   robin  | 9848022339 | 50000
      3 | Pune      |   rajeev | 9848022331 | 30000
      4 | Chennai   |   rahman | 9848022330 | 50000
(4 rows)