Drupal and the rise of the documents

Post on 08-May-2015

670 views 0 download

description

Slides for the session I gave at the Drupal Day Rome about Drupal and MongoDB

Transcript of Drupal and the rise of the documents

Drupal and the rise of the Documents

Claudio Beatrice (@omissis)

1Monday, December 5, 11

It was a warm summer evening in ancient Greece, when one of the greatest philosopher of all times(guess who? :) gave birth to the Theory of Forms, greatly contributing to Ontology, eg the study of the nature of being, existence or reality as such.

2Monday, December 5, 11

An entity(from greek εἶναι, “to be”) may be defined as a thing which is recognized as being capable of an independent existence and which can be uniquely identified. An entity is an abstraction from the complexities of some domain. When we speak of an entity we normally speak of some aspect of the real world which can be distinguished from other aspects of the real world.

3Monday, December 5, 11

Who did just say “yeah but whattabout relationships...

A relationship captures how two or more entities are related to one another.

4Monday, December 5, 11

... and tables?”

5Monday, December 5, 11

and btw, a question:

Awesome! Count to 3 and go asking mr. Boyce and mr. Codd then

6Monday, December 5, 11

A quick look at Drupal’s system table

This is quite a good example from “Master how to hammer a screw vol. 666”: there must be a better solution!

7Monday, December 5, 11

Introducing MongoDB

• Document oriented• schema-less• json-style• Scalable• sharding• replica sets• Performant• Fully featured• indexes• queries• map/reduce• gridfs• geospatial functions• capped collections• journaling

8Monday, December 5, 11

It looks like an interesting compromise between performance, scalability and number of functionalities

Introducing MongoDB

9Monday, December 5, 11

Oh noes! Philosophy again!

Flexibility Power

Ease of useSpeed/Scaling

JSON documents provide a schema-less, rich data model that maps to native programming language types

A consistent set of RDBMS features implemented such as secondary indexes, dynamic queries, sorting, upserts, aggregation plus his own ones such as gridfs and map/reduce

Embedded documents help avoiding heavy joins, while auto sharding makes quick and easy to scale out the database

Installing, configuring, maintaining and using MongoDB are all kept as easy as possible: more time for your app, less for your server configuration

10Monday, December 5, 11

Ok then.. tell us about Drupal!mongodb - support library for the other modules

mongodb_block - stores block information

mongodb_cache - stores cache

mongodb_field_storage - stores fields

mongodb_session - stores sessions

mongodb_queue - DrupalQueueInterface implementation

mongodb_watchdog - store watchdog messages

search_api_mongodb - backend storage mechanism for Search API

11Monday, December 5, 11

Time for a demo!

12Monday, December 5, 11

The Next Big Drupal Things

Drupal Dev Days 2012Barcelona - June 15-17

Drupalcon EU 2012Munich - August 20-23

15Monday, December 5, 11

Claudio Beatrice

http://twitter.com/#!/omissis

http://agavee.com

http://associazione.drupalitalia.org

16Monday, December 5, 11

17Monday, December 5, 11