Avec l’émergence du Big Data et les applications web temps réel, la puissance et l’agilité des bases de données NoSQL en ont fait un standard pour la gestion de vastes volumes de données. Ces bases de données ne suivent pas le modèle relationnel, permettent de stocker les données sans avoir nécessairement défini un schéma (schema-less) et se reposent sur une architecture distribuée permettant l’auto-scaling et le fail-over. Il existe différents types de bases de données NoSQL et il est important de bien comprendre leurs particularités pour choisir la base de données adéquates à chaque cas d’usage.
A l'issue de cette formation, vous connaitrez les différentes familles de bases NoSQL, leurs architectures, leurs caractéristiques techniques et les principales solutions du marché. Vous serez capable d’évaluer les avantages et les inconvénients inhérents pour chaque modèle de données.
Objectifs
Comprendre les différences entre SGBD SQL et SGBD NoSQL
Évaluer les avantages et les inconvénients inhérents aux technologies NoSQL
Analyser les principales solutions du monde NoSQL pour chaque modèle de données
Identifier les champs d'application des SGBD NoSQL en opérationnel et en analytique
Comprendre les différentes architectures
Pour connaitre les dates des prochaines sessions, pour adapter le programme à vos besoins ou pour obtenir des informations complémentaires, contactez nous!
Une évaluation quotidienne de l’acquisition des connaissances de la veille est effectuée.
Une synthèse est proposée en fin de formation.
Une évaluation à chaud sera proposée au stagiaire à la fin du cours.
Un support de cours sera remis à chaque participant comprenant les slides sur la théorie, les exercices.
Une feuille d’émargement par demi-journée de présence est fournie en fin de formation ainsi qu’une attestation de fin de formation si le stagiaire a bien assisté à la totalité de la session.
Un suivi et un échange avec les participants seront mis en place quelques jours après la formation.
Pré-requis
Des connaissances générales des systèmes d’information et en bases de données sont souhaitables.
Publics
Chef de projet technique
DBA
Architectes et Développeurs
Évaluation
Cette formation ne nécessite pas d’avoir recours à une évaluation formalisée des acquis
Programme
Introduction au NoSQL
L'historique du mouvement NoSQL.
Les différentes approches de gestion de SGBD à travers le temps : hiérarchiques, relationnelles, objets, XML, NoSQL.
Les cinq « V » du big data : Volume, Variété, Vélocité, Véracité, Validité.
Données non structurées : activité web, échange de documents, réseaux sociaux, open data, IoT.
Les grands acteurs à l'origine du mouvement NoSQL et du big data analytique : Google et Amazon.
Vue synoptique des différents types de moteurs NoSQL du point de vue du modèle de données.
Le NoSQL, le big data et les architectures cloud : principes d'architecture communs et divergents.
Les modes de distribution : avec maître et décentralisé.
Transactions distribuées, failover, points de sauvegarde, parallélisation des requêtes, équilibrage de charge.
Le positionnement du NoSQL au sein du big data analytique : de l'ère de la transaction à l'ère de l'interaction.
Le relationnel et le NoSQL
Les bases de données relationnelles : leurs forces et leurs limites.
Structuration forte des données (schéma explicite) versus structure souple (schéma implicite) et la modélisation Agile.
Des qualités ACID aux qualités BASE.
Théorème CAP (cohérence, disponibilité, tolérance au partitionnement).
Les différents niveaux de cohérence.
Le langage SQL, la performance des jointures. L'accès par la clé en NoSQL.
L'évolution vers le distribué : extensibilité verticale et horizontale.
Comprendre le NoSQL par le modèle de l'agrégat et de la centralité de la donnée.
Les mondes du NoSQL
Monde du NoSQL à travers ses choix techniques et différentes bases NoSQL libres (du moins structuré au plus structuré).
L'architecture distribuée : principes, le shared-nothing.
Disponibilité et cohérence différée : gossip, timestamps, la règle de majorité, l'arbre de Merkle.
Les patterns et les modèles. Comment modéliser et travailler efficacement en NoSQL.
Les bases orientées clé-valeur et en mémoire : Redis, Riak, Aerospike.
Les bases orientées documents : le format JSON. Couchbase Server, MongoDB.
Les bases orientées colonnes distribuées pour le big data opérationnel : Hbase, Cassandra, ScyllaDB...
Les moteurs orientés graphes : Neo4j, OrientDB...
Les moteurs de recherche JSON : Elasticsearch, SOLR.
Les bases de données de séries de temps : InfluxDB, KDB, Prometheus.
Choisir et mettre en place
À quels usages correspondent les bases NoSQL ?
Comment aborder la migration ?
Comment développer efficacement avec des bases NoSQL ?
Quels outils de supervision et comment les choisir ?
Quelle est la complexité administrative et la courbe d’apprentissage ?
Cas d’utilisation dans des entreprises existantes.
Gérer les interactions avec les bases de données relationnelles.
Implémenter des stratégies NoSQL avec des moteurs relationnels. L’exemple de PostgreSQL et ses extensions.
Implémenter le NoSQL dans les clouds publics. Les pratiques et les offres de bases de données en tant que service.
NoSQL et Big Data
Big data analytique : l'écosystème Hadoop.
Stockage et traitements. Les différentes formes de stockage dans HDFS : SequenceFile, Apache Parquet.
Fonctions et usages : moteurs de recherche, outils de suggestion commerciale, détecteurs d'intrusion...