HBase - Présentation
Depuis 1970, le SGBDR est la solution aux problèmes liés au stockage et à la maintenance des données. Après l'avènement du Big Data, les entreprises ont réalisé l'avantage du traitement du Big Data et ont commencé à opter pour des solutions comme Hadoop.
Hadoop utilise un système de fichiers distribué pour stocker des données volumineuses et MapReduce pour les traiter. Hadoop excelle dans le stockage et le traitement d'énormes données de différents formats tels que arbitraires, semi-structurés ou même non structurés.
Limitations de Hadoop
Hadoop ne peut effectuer qu'un traitement par lots et les données ne seront accessibles que de manière séquentielle. Cela signifie qu'il faut rechercher l'ensemble de données, même pour les tâches les plus simples.
Un énorme ensemble de données lorsqu'il est traité entraîne un autre énorme ensemble de données, qui devrait également être traité séquentiellement. À ce stade, une nouvelle solution est nécessaire pour accéder à n'importe quel point de données en une seule unité de temps (accès aléatoire).
Bases de données à accès aléatoire Hadoop
Des applications telles que HBase, Cassandra, couchDB, Dynamo et MongoDB font partie des bases de données qui stockent d'énormes quantités de données et accèdent aux données de manière aléatoire.
Qu'est-ce que HBase?
HBase est une base de données distribuée orientée colonnes construite sur le système de fichiers Hadoop. Il s'agit d'un projet open source et évolutif horizontalement.
HBase est un modèle de données similaire à la grande table de Google, conçu pour fournir un accès aléatoire rapide à d'énormes quantités de données structurées. Il exploite la tolérance aux pannes fournie par le système de fichiers Hadoop (HDFS).
Il fait partie de l'écosystème Hadoop qui fournit un accès aléatoire en lecture / écriture en temps réel aux données du système de fichiers Hadoop.
On peut stocker les données dans HDFS soit directement, soit via HBase. Le consommateur de données lit / accède aux données dans HDFS de manière aléatoire à l'aide de HBase. HBase se trouve au-dessus du système de fichiers Hadoop et fournit un accès en lecture et en écriture.
HBase et HDFS
HDFS | HBase |
---|---|
HDFS est un système de fichiers distribué adapté au stockage de fichiers volumineux. | HBase est une base de données construite sur le HDFS. |
HDFS ne prend pas en charge les recherches rapides d'enregistrements individuels. | HBase fournit des recherches rapides pour des tables plus volumineuses. |
Il fournit un traitement par lots à latence élevée; pas de concept de traitement par lots. | Il fournit un accès à faible latence à des lignes uniques à partir de milliards d'enregistrements (accès aléatoire). |
Il ne fournit qu'un accès séquentiel aux données. | HBase utilise en interne des tables de hachage et fournit un accès aléatoire, et stocke les données dans des fichiers HDFS indexés pour des recherches plus rapides. |
Mécanisme de stockage dans HBase
HBase est un column-oriented databaseet les tableaux qu'il contient sont triés par ligne. Le schéma de table définit uniquement les familles de colonnes, qui sont les paires valeur / clé. Une table a plusieurs familles de colonnes et chaque famille de colonnes peut avoir n'importe quel nombre de colonnes. Les valeurs de colonne suivantes sont stockées de manière contiguë sur le disque. Chaque valeur de cellule de la table a un horodatage. En bref, dans une HBase:
- La table est une collection de lignes.
- Row est une collection de familles de colonnes.
- La famille de colonnes est une collection de colonnes.
- La colonne est une collection de paires valeur / clé.
Ci-dessous, un exemple de schéma de table dans HBase.
Rowid | Famille de colonnes | Famille de colonnes | Famille de colonnes | Famille de colonnes | ||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|
col1 | col2 | col3 | col1 | col2 | col3 | col1 | col2 | col3 | col1 | col2 | col3 | |
1 | ||||||||||||
2 | ||||||||||||
3 |
Orienté colonne et orienté ligne
Les bases de données orientées colonnes sont celles qui stockent les tables de données sous forme de sections de colonnes de données, plutôt que sous forme de lignes de données. Bientôt, ils auront des familles de colonnes.
Base de données orientée lignes | Base de données orientée colonnes |
---|---|
Il convient au processus de transaction en ligne (OLTP). | Il convient au traitement analytique en ligne (OLAP). |
Ces bases de données sont conçues pour un petit nombre de lignes et de colonnes. | Les bases de données orientées colonnes sont conçues pour les tables volumineuses. |
L'image suivante montre les familles de colonnes dans une base de données orientée colonnes:
HBase et SGBDR
HBase | SGBDR |
---|---|
HBase est sans schéma, il n'a pas le concept de schéma de colonnes fixes; définit uniquement les familles de colonnes. | Un SGBDR est régi par son schéma, qui décrit toute la structure des tables. |
Il est conçu pour les grandes tables. HBase est évolutif horizontalement. | Il est fin et conçu pour les petites tables. Difficile à mettre à l'échelle. |
Aucune transaction n'est présente dans HBase. | Le SGBDR est transactionnel. |
Il a des données dé-normalisées. | Il aura des données normalisées. |
C'est bon pour les données semi-structurées et structurées. | C'est bon pour les données structurées. |
Caractéristiques de HBase
- HBase est linéairement évolutif.
- Il a un support de panne automatique.
- Il fournit des lectures et des écritures cohérentes.
- Il s'intègre à Hadoop, à la fois comme source et comme destination.
- Il a une API Java facile pour le client.
- Il assure la réplication des données entre les clusters.
Où utiliser HBase
Apache HBase est utilisé pour avoir un accès aléatoire en lecture / écriture en temps réel au Big Data.
Il héberge de très grandes tables au-dessus de grappes de matériel de base.
Apache HBase est une base de données non relationnelle calquée sur la Bigtable de Google. Bigtable fonctionne sur Google File System, de même qu'Apache HBase fonctionne sur Hadoop et HDFS.
Applications de HBase
- Il est utilisé chaque fois qu'il est nécessaire d'écrire des applications lourdes.
- HBase est utilisé chaque fois que nous devons fournir un accès aléatoire rapide aux données disponibles.
- Des entreprises telles que Facebook, Twitter, Yahoo et Adobe utilisent HBase en interne.
Histoire HBase
An | un événement |
---|---|
Novembre 2006 | Google a publié le document sur BigTable. |
Février 2007 | Le prototype initial de HBase a été créé en tant que contribution Hadoop. |
Octobre 2007 | Le premier HBase utilisable avec Hadoop 0.15.0 a été publié. |
Janv.2008 | HBase est devenu le sous-projet de Hadoop. |
Octobre 2008 | HBase 0.18.1 a été libéré. |
Janv.2009 | HBase 0.19.0 a été publié. |
Septembre 2009 | HBase 0.20.0 a été publié. |
Mai 2010 | HBase est devenu le projet de premier niveau Apache. |