Cassandra - Modèle de données
Le modèle de données de Cassandra est très différent de ce que nous voyons normalement dans un SGBDR. Ce chapitre donne un aperçu de la manière dont Cassandra stocke ses données.
Grappe
La base de données Cassandra est répartie sur plusieurs machines qui fonctionnent ensemble. Le conteneur le plus extérieur est connu sous le nom de cluster. Pour la gestion des pannes, chaque nœud contient une réplique, et en cas de panne, la réplique prend en charge. Cassandra organise les nœuds dans un cluster, dans un format en anneau, et leur attribue des données.
Espace clé
Keyspace est le conteneur le plus extérieur pour les données dans Cassandra. Les attributs de base d'un espace clé dans Cassandra sont -
Replication factor - Il s'agit du nombre de machines du cluster qui recevront des copies des mêmes données.
Replica placement strategy- Ce n'est rien d'autre que la stratégie de placer des répliques sur le ring. Nous avons des stratégies telles quesimple strategy (stratégie rackable), old network topology strategy (stratégie sensible au rack), et network topology strategy (stratégie partagée par le centre de données).
Column families- Keyspace est un conteneur pour une liste d'une ou plusieurs familles de colonnes. Une famille de colonnes, à son tour, est un conteneur d'une collection de lignes. Chaque ligne contient des colonnes ordonnées. Les familles de colonnes représentent la structure de vos données. Chaque espace de clés a au moins une et souvent plusieurs familles de colonnes.
La syntaxe de création d'un Keyspace est la suivante -
CREATE KEYSPACE Keyspace name
WITH replication = {'class': 'SimpleStrategy', 'replication_factor' : 3};
L'illustration suivante montre une vue schématique d'un Keyspace.
Famille de colonnes
Une famille de colonnes est un conteneur pour une collection ordonnée de lignes. Chaque ligne, à son tour, est une collection ordonnée de colonnes. Le tableau suivant répertorie les points qui différencient une famille de colonnes d'une table de bases de données relationnelles.
Table relationnelle | Famille de colonnes Cassandra |
---|---|
Un schéma dans un modèle relationnel est fixe. Une fois que nous avons défini certaines colonnes pour une table, lors de l'insertion de données, dans chaque ligne, toutes les colonnes doivent être remplies au moins avec une valeur nulle. | Dans Cassandra, bien que les familles de colonnes soient définies, les colonnes ne le sont pas. Vous pouvez ajouter librement n'importe quelle colonne à n'importe quelle famille de colonnes à tout moment. |
Les tables relationnelles définissent uniquement des colonnes et l'utilisateur remplit la table avec des valeurs. | Dans Cassandra, une table contient des colonnes ou peut être définie comme une famille de super colonnes. |
Une famille de colonnes Cassandra possède les attributs suivants:
keys_cached - Il représente le nombre d'emplacements à conserver en cache par SSTable.
rows_cached - Il représente le nombre de lignes dont tout le contenu sera mis en cache en mémoire.
preload_row_cache - Il spécifie si vous souhaitez pré-remplir le cache de lignes.
Note − Contrairement aux tables relationnelles où le schéma d'une famille de colonnes n'est pas fixe, Cassandra ne force pas les lignes individuelles à avoir toutes les colonnes.
La figure suivante montre un exemple de famille de colonnes Cassandra.
Colonne
Une colonne est la structure de données de base de Cassandra avec trois valeurs, à savoir le nom de la clé ou de la colonne, la valeur et un horodatage. Ci-dessous, la structure d'une colonne.
SuperColonne
Une super colonne est une colonne spéciale, c'est donc aussi une paire clé-valeur. Mais une super colonne stocke une carte de sous-colonnes.
En général, les familles de colonnes sont stockées sur disque dans des fichiers individuels. Par conséquent, pour optimiser les performances, il est important de conserver les colonnes que vous êtes susceptible d'interroger ensemble dans la même famille de colonnes, et une super colonne peut être utile ici.Voici la structure d'une super colonne.
Modèles de données de Cassandra et SGBDR
Le tableau suivant répertorie les points qui différencient le modèle de données de Cassandra de celui d'un SGBDR.
SGBDR | Cassandra |
---|---|
Le SGBDR traite des données structurées. | Cassandra traite des données non structurées. |
Il a un schéma fixe. | Cassandra a un schéma flexible. |
Dans le SGBDR, une table est un tableau de tableaux. (RANGÉE x COLONNE) | Dans Cassandra, une table est une liste de «paires clé-valeur imbriquées». (ROW x COLUMN key x COLUMN value) |
La base de données est le conteneur le plus externe qui contient les données correspondant à une application. | Keyspace est le conteneur le plus externe qui contient les données correspondant à une application. |
Les tables sont les entités d'une base de données. | Les tables ou familles de colonnes sont l'entité d'un espace de clés. |
Row est un enregistrement individuel dans le SGBDR. | Row est une unité de réplication dans Cassandra. |
La colonne représente les attributs d'une relation. | La colonne est une unité de stockage à Cassandra. |
SGBDR prend en charge les concepts de clés étrangères, jointures. | Les relations sont représentées à l'aide de collections. |