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)