RavenDB

RavenDB

Informations
Développé par Hibernating Rhinos
Première version
Dernière version 4.2 ()
Dépôt RavenDB sur GitHub
État du projet en développement actif
Écrit en C#
Type Base de données orientée documents
Licence GNU AGPL v3.0
Site web ravendb.net / hibernatingrhinos.com

Chronologie des versions

RavenDB est une base de données open-source entièrement ACID orientée documents, écrite en C#, développée par Hibernating Rhinos Ltd[1],[2],[3],[4],[5],[6]. Elle est multiplateforme, prise en charge par Windows, Linux et Mac OS[1]. RavenDB stocke les données sous forme de documents JSON et peut être déployée dans des clusters distribués avec réplication multi-maître.

Historique[modifier | modifier le code]

Initialement nommé Rhino DivanDB[1],[7], le projet RavenDB de Oren Eini (alias Ayende Rahien)[8],[9] a été lancé en 2008 et développé par Hibernating Rhinos Ltd[4]. La société affirme qu'elle a été la première base de données orientée documents à s'exécuter nativement sur le framework .NET[10],[11],[2],[12]. Elle a été la première base de données de documents ACID[3],[12],[13].

En 2019, Hibernating Rhinos a commencé à proposer RavenDB comme service cloud nommé RavenDB Cloud[14],[15],[16].

Historique des versions[modifier | modifier le code]

Version Date Fonctionnalités ajoutées (liste partielle)
1.0 [17]
2.0 [18] Réplication[19],[20]
2.5 [21] Projections; recherche facettée[19]
3.0 [22] Java API; Voron storage engine[23],[24]
3.5 [25] Clustering[25]
4.0 [26] Devenu multiplateforme; disponible avec une licence gratuite[27]
4.1 [28] Transactions à l'échelle du cluster[14],[28]
4.2 [29] Interrogation de graphes[14]
  • Rouge : Non pris en charge
  • Vert : Pris en charge

Architecture du système[modifier | modifier le code]

Les données sont stockées au format JSON sous forme de documents sans schéma[1],[7],[2],[30],[19],[20],[6]. Au niveau du stockage, les documents sont écrits dans un format binaire appelé blittable[31]. Les documents sont regroupés en collections, chaque document ayant exactement une collection[pas clair][19],[20].

Intérieur RDB4[modifier | modifier le code]

Les bases de données peuvent être déployées sur un cluster distribué de serveurs (appelés «nœuds») au moyen de la réplication multi-maître[1],[3] Certaines opérations[Lesquelles ?] au niveau du cluster nécessitent le consensus d'une majorité de nœuds; le consensus est déterminé en utilisant une implémentation de l'algorithme Raft appelé Rachis[1]. Les tâches sont réparties entre les différents nœuds de manière équilibrée[1],[32].

Les versions 1.0 à 3.5 prenaient en charge le sharding, mais pas les versions 4.0+[1],[2],[3],[19],[20].

À l'origine, RavenDB utilisait le moteur de stockage Esent[7],[8],[20]. La version 3.0 a introduit Voron, un moteur de stockage personnalisé supplémentaire[23],[24].

Les clients sont pris en charge pour C#, C++, Java, NodeJS, Python, Ruby et Go[3].

Caractéristiques principales[modifier | modifier le code]

  • Transactions ACID à l'échelle du cluster - Les transactions ACID peuvent être exécutées dans le champ d'un cluster[pas clair] (en plus des transactions à nœud unique). La transaction ne sera enregistrée que si elle est confirmée par un consensus de nœuds ; dans le cas contraire, la transaction sera annulée irréversiblement[1],[14].
  • Compteurs distribués[33],[34]

Index et interrogation[modifier | modifier le code]

Les requêtes sont exprimées en LINQ ou avec un langage de requête personnalisé nommé RQL (pour Raven Query Language) avec une syntaxe similaire à SQL[1],[2],[3].

  • Index dynamiques - dans RavenDB, une réponse peut être donnée à la requête uniquement par un index ; si aucun index approprié n'existe, un nouvel index est créé pour satisfaire la requête[1],[11],[35],[19],[20],[6]
  • Requête de graphes - les documents liés peuvent être traités comme des vertex dans un graphe, avec les connexions traitées comme des liens. Cela permet de créer des requêtes récursives[33],[34],[36].
  • Projection - les index peuvent être configurés pour transformer les données indexées, effectuer des calculs, effectuer des agrégations et exécuter du code javascript côté serveur[1],[3],[37].
  • Recherche de texte intégral - à bas niveau, les données sont indexées avec Lucene.net, ce qui signifie que les index prennent en charge la recherche de texte intégral[1],[13],[19],[20],[38],[39].

RavenDB Cloud[modifier | modifier le code]

RavenDB Cloud, lancée en 2019 sur AWS, Azure et GCP, est une base de données gérée en tant que service. Le service effectue des tâches administratives telles que la maintenance du matériel et la sécurité des utilisateurs. Il est pourvu d'une fonction partage des ressources CPU entre les différents nœuds d'un cluster pour éviter les ralentissements[14],[15],[16].

Licence[modifier | modifier le code]

RavenDB est open-source sous une licence AGPLv3[1]. Elle est disponible avec une licence gratuite et une licence commerciale.

Notes et références[modifier | modifier le code]

  1. a b c d e f g h i j k l m et n (en) « RavenDB », sur Database of Databases (consulté le ).
  2. a b c d et e (en) « Raven, a Document Database for .NET », sur www.infoq.com, (consulté le ).
  3. a b c d e f et g (en) « RavenDB System Properties », sur db-engines.com (consulté le ).
  4. a et b (en) « Other Vendors to Consider for Operational DBMSs », sur www.gartner.com, (consulté le ).
  5. (en) « Hibernating Rhinos », sur hibernatingrhinos.com (consulté le ).
  6. a b et c (en) Kaur, Harpreet, and Kamal Jeet Kaur. "A Review: Study of Document oriented databases and their Security." International Journal of Advanced Research in Computer Science 4.8 (2013).
  7. a b et c (en) « Ayende's DivanDB (also, is esent the most widely used database engine?) », sur blogs.msdn.microsoft.com, (consulté le ).
  8. a et b (en) « Hidden Windows Gems: Extensible Storage Engine », sur ayende.com, (consulté le ).
  9. (en) « Interview with Oren Eini of RavenDB on database management, analytics & security », sur bigdata-madesimple.com, (consulté le ).
  10. (en) « RavenDB Development: Finally, A Solid Document-based Database for Windows? », sur www.whoishostingthis.com, (consulté le ).
  11. a et b (en) « NoSQL Document Database - Embedding RavenDB into an ASP.NET MVC 3 Application », sur docs.microsoft.com, (consulté le ).
  12. a et b (en) « Why Raven DB? », sur dzone.com, (consulté le ).
  13. a et b (nl) « RavenDB vs SQL Server », sur www.integrace.nl (consulté le ).
  14. a b c d et e (en) « RavenDB Launches Managed Cloud Service », sur www.datanami.com, (consulté le ).
  15. a et b (en) « SD Times news digest: Google robots.text parser open sourced, Bonitasoft’s cloud and low-code capabilities, and OWASP ZAP 2.8 », sur sdtimes.com, (consulté le ).
  16. a et b (en) « RavenDB Adds New Enhancements to Its Cloud-Based Database Service », sur it.toolbox.com, (consulté le ).
  17. (en) « RavenDB goes live! », sur ayende.com, (consulté le ).
  18. (en) « RavenDB 2.0 RTM », sur ayende.com, (consulté le ).
  19. a b c d e f et g (en) « RavenDB: A document database for the .NET platform », sur learning.oreilly.com (consulté le ).
  20. a b c d e f et g (en) « RavenDB: A document database for the .NET platform », sur learning.oreilly.com (consulté le ).
  21. (en) « RavenDB 2.5 Release Candidate is out », sur ayende.com, (consulté le ).
  22. (en) « RavenDB 3.0 RTM! », sur ayende.com, (consulté le ).
  23. a et b (en) « NoSQL for .NET: RavenDB 3.0 Takes Flight », sur visualstudiomagazine.com, (consulté le ).
  24. a et b (en) « NoSQL: RavenDB 3.0 erhält weitere Storage Engine », sur www.heise.de (consulté le ).
  25. a et b (en) « RavenDB 3.5 RTM released », sur ayende.com, (consulté le ).
  26. (en) « RavenDB 4.0 is out », sur ayende.com, (consulté le ).
  27. (en) « NoSQL: RavenDB 4.0 jetzt für Windows, Linux, macOS und Docker verfügbar », sur www.heise.de, (consulté le ).
  28. a et b (en) « RavenDB 4.1 Release Candidate is out », sur ayende.com, (consulté le ).
  29. (en) « RavenDB 4.2 has been released! », sur ayende.com, (consulté le ).
  30. (en) « A document database for the .NET platform », sur learning.oreilly.com (consulté le ).
  31. (en) « The Design of RavenDB 4.0: The Implications of the Blittable Format », sur dzone.com, (consulté le )
  32. (en) « Review: NoSQL database RavenDB », sur techgenix.com, (consulté le ).
  33. a et b (en) « RavenDB Adds Graph Queries », sur www.datanami.com, (consulté le ).
  34. a et b (en) « SD Times news digest: New Relic One, WhiteSource for Developers, RavenDB4.2, and VMware’s acquisition of Bitnami », sur sdtimes.com, (consulté le ).
  35. (en) « RavenDB: Driving DX through DB infrastructure management », sur ciostory.com (consulté le ).
  36. (en) « RavenDB Features », sur ravendb.net (consulté le ).
  37. (en) « Data Modeling with Indexes in RavenDB », sur www.codeproject.com, (consulté le ).
  38. (en) Stevic, Milorad P. "Managing documents with NoSQL in service oriented architecture." Online Journal of Applied Knowledge Management (OJAKM) 1.2 (2013): 105-115.
  39. (en) « Data Points - What the Heck Are Document Databases? », sur docs.microsoft.com, (consulté le ).

Liens externes[modifier | modifier le code]