Elasticsearch par David Pilato [FR]

175
Elasticsearch. Le moteur de recherche élastique pour tous David Pilato, Elasticsearch.com, Paris lundi 23 septembre 13

description

Elasticsearch, le moteur de recherche élastique pour tous.

Transcript of Elasticsearch par David Pilato [FR]

Page 1: Elasticsearch par David Pilato [FR]

Elasticsearch.Le moteur de recherche

élastique pour tous

David Pilato, Elasticsearch.com, Paris

lundi 23 septembre 13

Page 2: Elasticsearch par David Pilato [FR]

Qui ?

$ curl http://localhost:9200/talk/speaker/dpilato{ "nom" : "David Pilato", "jobs" : [ { "boite" : "SRA Europe (SSII)", "mission" : "bon à tout faire", "date" : "1995" }, { "boite" : "SFR", "mission" : "touche à tout", "date" : "1997" }, { "boite" : "e-Brands / Vivendi", "mission" : "chef de projets", "date": "2000" }, { "boite" : "DGDDI (douane)", "mission" : "mouton à 5 pattes", "date" : "2005" }, { "boite" : "IDEO Technologies", "mission" : "directeur technique", "date" : "2012" }, { "boite" : "Elasticsearch.com", "mission" : "technical advocate", "date" : "2013" } ], "passions" : [ "famille", "job", "deejay" ], "blog" : "http://dev.david.pilato.fr/", "twitter" : [ "@dadoonet", "@elasticsearchfr", "@scrutmydocs" ], "email" : "[email protected]"}

lundi 23 septembre 13

Page 3: Elasticsearch par David Pilato [FR]

Qui ?

$ curl http://localhost:9200/talk/speaker/dpilato{ "nom" : "David Pilato", "jobs" : [ { "boite" : "SRA Europe (SSII)", "mission" : "bon à tout faire", "date" : "1995" }, { "boite" : "SFR", "mission" : "touche à tout", "date" : "1997" }, { "boite" : "e-Brands / Vivendi", "mission" : "chef de projets", "date": "2000" }, { "boite" : "DGDDI (douane)", "mission" : "mouton à 5 pattes", "date" : "2005" }, { "boite" : "IDEO Technologies", "mission" : "directeur technique", "date" : "2012" }, { "boite" : "Elasticsearch.com", "mission" : "technical advocate", "date" : "2013" } ], "passions" : [ "famille", "job", "deejay" ], "blog" : "http://dev.david.pilato.fr/", "twitter" : [ "@dadoonet", "@elasticsearchfr", "@scrutmydocs" ], "email" : "[email protected]"}

lundi 23 septembre 13

Page 4: Elasticsearch par David Pilato [FR]

ScrutMyDocs.org

lundi 23 septembre 13

Page 5: Elasticsearch par David Pilato [FR]

Elasticsearch.com

• Créée en 2012 par ses auteurs

• Formation (publique et intra)

• Support de développement

• Support de production (3 niveaux de SLA)

lundi 23 septembre 13

Page 6: Elasticsearch par David Pilato [FR]

Pour la démo

Faites du bruit sur Twitter

avec le hashtag

#elasticsearch

lundi 23 septembre 13

Page 7: Elasticsearch par David Pilato [FR]

SQL Classique

Cherche moi un document de décembre 2011 portant sur la france

et contenant produit et davidEn SQL :

lundi 23 septembre 13

Page 8: Elasticsearch par David Pilato [FR]

SQL Classique

Cherche moi un document de décembre 2011 portant sur la france

et contenant produit et davidEn SQL :

SELECT doc.*, pays.* FROM doc, paysWHERE doc.pays_code = pays.code AND doc.date_doc > to_date('2011-12', 'yyyy-mm') AND doc.date_doc < to_date('2012-01', 'yyyy-mm') AND lower(pays.libelle) = 'france' AND lower(doc.commentaire) LIKE ‘%produit%' AND lower(doc.commentaire) LIKE ‘%david%';

lundi 23 septembre 13

Page 9: Elasticsearch par David Pilato [FR]

Au final, on obtient

lundi 23 septembre 13

Page 10: Elasticsearch par David Pilato [FR]

Moteur de recherche ?• un moteur d’indexation de documents

lundi 23 septembre 13

Page 11: Elasticsearch par David Pilato [FR]

Moteur de recherche ?• un moteur d’indexation de documents

lundi 23 septembre 13

Page 12: Elasticsearch par David Pilato [FR]

Moteur de recherche ?• un moteur d’indexation de documents

• un moteur de recherche dans les index

lundi 23 septembre 13

Page 13: Elasticsearch par David Pilato [FR]

Elasticsearch

lundi 23 septembre 13

Page 14: Elasticsearch par David Pilato [FR]

ElasticsearchYour Data, your Search !

lundi 23 septembre 13

Page 15: Elasticsearch par David Pilato [FR]

Elasticsearch

• C’est un moteur !

• NoSQL orienté document

• Apache Lucene

• HTTP / REST / JSON

• Distribué, Scalable, Cloud ready

• Apache2 License

lundi 23 septembre 13

Page 16: Elasticsearch par David Pilato [FR]

Points clés

lundi 23 septembre 13

Page 17: Elasticsearch par David Pilato [FR]

Points clés

• Simple: start in 5 minutes 30 seconds

lundi 23 septembre 13

Page 18: Elasticsearch par David Pilato [FR]

Points clés

• Simple: start in 5 minutes 30 seconds

• Efficace: just start new nodes!

lundi 23 septembre 13

Page 19: Elasticsearch par David Pilato [FR]

Points clés

• Simple: start in 5 minutes 30 seconds

• Efficace: just start new nodes!

• Puissant: 20-300ms!

lundi 23 septembre 13

Page 20: Elasticsearch par David Pilato [FR]

Points clés

• Simple: start in 5 minutes 30 seconds

• Efficace: just start new nodes!

• Puissant: 20-300ms!

• Complet: built-in + plugins

lundi 23 septembre 13

Page 21: Elasticsearch par David Pilato [FR]

Penser « document » !• Document : Un objet représentant les données (au sens

NoSQL).Penser "recherche", c'est oublier le SGBDR et penser "Documents"

• Type : Regroupe des documents de même type

• Index : Espace logique de stockage des documents dont les types sont fonctionnellement communs

lundi 23 septembre 13

Page 22: Elasticsearch par David Pilato [FR]

Penser « document » !• Document : Un objet représentant les données (au sens

NoSQL).Penser "recherche", c'est oublier le SGBDR et penser "Documents"

• Type : Regroupe des documents de même type

• Index : Espace logique de stockage des documents dont les types sont fonctionnellement communs

{ "text": "Bienvenue à la conférence #elasticsearch pour #JUG", "created_at": "2012-04-06T20:45:36.000Z", "source": "Twitter for iPad", "truncated": false, "retweet_count": 0, "hashtag": [ { "text": "elasticsearch", "start": 27, "end": 40 }, { "text": "JUG", "start": 47, "end": 55 } ], "user": { "id": 51172224, "name": "David Pilato", "screen_name": "dadoonet", "location": "France", "description": "Soft Architect, Project Manager, Senior Developper.\r\nAt this time, enjoying NoSQL world : CouchDB, ElasticSearch.\r\nDeeJay 4 times a year, just for fun !" }}

lundi 23 septembre 13

Page 23: Elasticsearch par David Pilato [FR]

Penser « document » !• Document : Un objet représentant les données (au sens

NoSQL).Penser "recherche", c'est oublier le SGBDR et penser "Documents"

• Type : Regroupe des documents de même type

{ "text": "Bienvenue à la conférence #elasticsearch pour #JUG", "created_at": "2012-04-06T20:45:36.000Z", "source": "Twitter for iPad", "truncated": false, "retweet_count": 0, "hashtag": [ { "text": "elasticsearch", "start": 27, "end": 40 }, { "text": "JUG", "start": 47, "end": 55 } ], "user": { "id": 51172224, "name": "David Pilato", "screen_name": "dadoonet", "location": "France", "description": "Soft Architect, Project Manager, Senior Developper.\r\nAt this time, enjoying NoSQL world : CouchDB, ElasticSearch.\r\nDeeJay 4 times a year, just for fun !" }}

lundi 23 septembre 13

Page 24: Elasticsearch par David Pilato [FR]

Penser « document » !• Document : Un objet représentant les données (au sens

NoSQL).Penser "recherche", c'est oublier le SGBDR et penser "Documents"

• Type : Regroupe des documents de même type

• Index : Espace logique de stockage des documents dont les types sont fonctionnellement communs

{ "text": "Bienvenue à la conférence #elasticsearch pour #JUG", "created_at": "2012-04-06T20:45:36.000Z", "source": "Twitter for iPad", "truncated": false, "retweet_count": 0, "hashtag": [ { "text": "elasticsearch", "start": 27, "end": 40 }, { "text": "JUG", "start": 47, "end": 55 } ], "user": { "id": 51172224, "name": "David Pilato", "screen_name": "dadoonet", "location": "France", "description": "Soft Architect, Project Manager, Senior Developper.\r\nAt this time, enjoying NoSQL world : CouchDB, ElasticSearch.\r\nDeeJay 4 times a year, just for fun !" }}

lundi 23 septembre 13

Page 25: Elasticsearch par David Pilato [FR]

Interagir avec Elasticsearch

lundi 23 septembre 13

Page 26: Elasticsearch par David Pilato [FR]

Interagir avec Elasticsearch

• API REST : http://host:port/[index]/[type]/[_action/id]Méthodes HTTP : GET, POST, PUT, DELETE, HEAD

lundi 23 septembre 13

Page 27: Elasticsearch par David Pilato [FR]

Interagir avec Elasticsearch

• API REST : http://host:port/[index]/[type]/[_action/id]Méthodes HTTP : GET, POST, PUT, DELETE, HEAD

• Documents

• curl -XPUT http://localhost:9200/twitter/tweet/1

lundi 23 septembre 13

Page 28: Elasticsearch par David Pilato [FR]

Interagir avec Elasticsearch

• API REST : http://host:port/[index]/[type]/[_action/id]Méthodes HTTP : GET, POST, PUT, DELETE, HEAD

• Documents

• curl -XPUT http://localhost:9200/twitter/tweet/1

• curl -XGET http://localhost:9200/twitter/tweet/1

lundi 23 septembre 13

Page 29: Elasticsearch par David Pilato [FR]

Interagir avec Elasticsearch

• API REST : http://host:port/[index]/[type]/[_action/id]Méthodes HTTP : GET, POST, PUT, DELETE, HEAD

• Documents

• curl -XPUT http://localhost:9200/twitter/tweet/1

• curl -XGET http://localhost:9200/twitter/tweet/1

• curl -XDELETE http://localhost:9200/twitter/tweet/1

lundi 23 septembre 13

Page 30: Elasticsearch par David Pilato [FR]

Interagir avec Elasticsearch

• API REST : http://host:port/[index]/[type]/[_action/id]Méthodes HTTP : GET, POST, PUT, DELETE, HEAD

• Documents

• curl -XPUT http://localhost:9200/twitter/tweet/1

• curl -XGET http://localhost:9200/twitter/tweet/1

• curl -XDELETE http://localhost:9200/twitter/tweet/1

• Recherche

• curl -XPOST http://localhost:9200/twitter/tweet/_search

lundi 23 septembre 13

Page 31: Elasticsearch par David Pilato [FR]

Interagir avec Elasticsearch

• API REST : http://host:port/[index]/[type]/[_action/id]Méthodes HTTP : GET, POST, PUT, DELETE, HEAD

• Documents

• curl -XPUT http://localhost:9200/twitter/tweet/1

• curl -XGET http://localhost:9200/twitter/tweet/1

• curl -XDELETE http://localhost:9200/twitter/tweet/1

• Recherche

• curl -XPOST http://localhost:9200/twitter/tweet/_search

• curl -XPOST http://localhost:9200/twitter/_search

lundi 23 septembre 13

Page 32: Elasticsearch par David Pilato [FR]

Interagir avec Elasticsearch

• API REST : http://host:port/[index]/[type]/[_action/id]Méthodes HTTP : GET, POST, PUT, DELETE, HEAD

• Documents

• curl -XPUT http://localhost:9200/twitter/tweet/1

• curl -XGET http://localhost:9200/twitter/tweet/1

• curl -XDELETE http://localhost:9200/twitter/tweet/1

• Recherche

• curl -XPOST http://localhost:9200/twitter/tweet/_search

• curl -XPOST http://localhost:9200/twitter/_search

• curl -XPOST http://localhost:9200/_search

lundi 23 septembre 13

Page 33: Elasticsearch par David Pilato [FR]

Interagir avec Elasticsearch

• API REST : http://host:port/[index]/[type]/[_action/id]Méthodes HTTP : GET, POST, PUT, DELETE, HEAD

• Documents

• curl -XPUT http://localhost:9200/twitter/tweet/1

• curl -XGET http://localhost:9200/twitter/tweet/1

• curl -XDELETE http://localhost:9200/twitter/tweet/1

• Recherche

• curl -XPOST http://localhost:9200/twitter/tweet/_search

• curl -XPOST http://localhost:9200/twitter/_search

• curl -XPOST http://localhost:9200/_search

• Meta-données

• curl -XGET http://localhost:9200/twitter/_status

lundi 23 septembre 13

Page 34: Elasticsearch par David Pilato [FR]

Interagir avec Elasticsearch

• API REST : http://host:port/[index]/[type]/[_action/id]Méthodes HTTP : GET, POST, PUT, DELETE, HEAD

• Documents

• curl -XPUT http://localhost:9200/twitter/tweet/1

• curl -XGET http://localhost:9200/twitter/tweet/1

• curl -XDELETE http://localhost:9200/twitter/tweet/1

• Recherche

• curl -XPOST http://localhost:9200/twitter/tweet/_search

• curl -XPOST http://localhost:9200/twitter/_search

• curl -XPOST http://localhost:9200/_search

• Meta-données

• curl -XGET http://localhost:9200/twitter/_status

• curl -XPOST http://localhost:9200/_shutdown

lundi 23 septembre 13

Page 35: Elasticsearch par David Pilato [FR]

Indexer$ curl -XPUT localhost:9200/twitter/tweet/1 -d '{ "text": "Bienvenue à la conférence #elasticsearch pour #JUG", "created_at": "2012-04-06T20:45:36.000Z", "source": "Twitter for iPad", "truncated": false, "retweet_count": 0, "hashtag": [ { "text": "elasticsearch", "start": 27, "end": 40 }, { "text": "JUG", "start": 47, "end": 55 } ], "user": { "id": 51172224, "name": "David Pilato", "screen_name": "dadoonet", "location": "France", "description": "Soft Architect, Project Manager, Senior Developper.\r\nAt this time, enjoying NoSQL world : CouchDB, ElasticSearch.\r\nDeeJay 4 times a year, just for fun !" }}'

lundi 23 septembre 13

Page 36: Elasticsearch par David Pilato [FR]

Indexer

{ "ok":true, "_index":"twitter", "_type":"tweet", "_id":"1"}

$ curl -XPUT localhost:9200/twitter/tweet/1 -d '{ "text": "Bienvenue à la conférence #elasticsearch pour #JUG", "created_at": "2012-04-06T20:45:36.000Z", "source": "Twitter for iPad", "truncated": false, "retweet_count": 0, "hashtag": [ { "text": "elasticsearch", "start": 27, "end": 40 }, { "text": "JUG", "start": 47, "end": 55 } ], "user": { "id": 51172224, "name": "David Pilato", "screen_name": "dadoonet", "location": "France", "description": "Soft Architect, Project Manager, Senior Developper.\r\nAt this time, enjoying NoSQL world : CouchDB, ElasticSearch.\r\nDeeJay 4 times a year, just for fun !" }}'

lundi 23 septembre 13

Page 37: Elasticsearch par David Pilato [FR]

Chercher$ curl localhost:9200/twitter/tweet/_search?q=elasticsearch

lundi 23 septembre 13

Page 38: Elasticsearch par David Pilato [FR]

Chercher$ curl localhost:9200/twitter/tweet/_search?q=elasticsearch

{ "took" : 24, "timed_out" : false, "_shards" : { "total" : 5, "successful" : 5, "failed" : 0 }, "hits" : { "total" : 1, "max_score" : 0.227, "hits" : [ { "_index" : "twitter", "_type" : "tweet", "_id" : "1", "_score" : 0.227, "_source" : { "text": "Bienvenue à la conférence #elasticsearch pour #JUG", "created_at": "2012-04-06T20:45:36.000Z", "source": "Twitter for iPad", […] } } ] }}

lundi 23 septembre 13

Page 39: Elasticsearch par David Pilato [FR]

Chercher$ curl localhost:9200/twitter/tweet/_search?q=elasticsearch

{ "took" : 24, "timed_out" : false, "_shards" : { "total" : 5, "successful" : 5, "failed" : 0 }, "hits" : { "total" : 1, "max_score" : 0.227, "hits" : [ { "_index" : "twitter", "_type" : "tweet", "_id" : "1", "_score" : 0.227, "_source" : { "text": "Bienvenue à la conférence #elasticsearch pour #JUG", "created_at": "2012-04-06T20:45:36.000Z", "source": "Twitter for iPad", […] } } ] }}

Nb de documents

lundi 23 septembre 13

Page 40: Elasticsearch par David Pilato [FR]

Chercher$ curl localhost:9200/twitter/tweet/_search?q=elasticsearch

{ "took" : 24, "timed_out" : false, "_shards" : { "total" : 5, "successful" : 5, "failed" : 0 }, "hits" : { "total" : 1, "max_score" : 0.227, "hits" : [ { "_index" : "twitter", "_type" : "tweet", "_id" : "1", "_score" : 0.227, "_source" : { "text": "Bienvenue à la conférence #elasticsearch pour #JUG", "created_at": "2012-04-06T20:45:36.000Z", "source": "Twitter for iPad", […] } } ] }}

Coordonnées

lundi 23 septembre 13

Page 41: Elasticsearch par David Pilato [FR]

Chercher$ curl localhost:9200/twitter/tweet/_search?q=elasticsearch

{ "took" : 24, "timed_out" : false, "_shards" : { "total" : 5, "successful" : 5, "failed" : 0 }, "hits" : { "total" : 1, "max_score" : 0.227, "hits" : [ { "_index" : "twitter", "_type" : "tweet", "_id" : "1", "_score" : 0.227, "_source" : { "text": "Bienvenue à la conférence #elasticsearch pour #JUG", "created_at": "2012-04-06T20:45:36.000Z", "source": "Twitter for iPad", […] } } ] }}

Pertinence

lundi 23 septembre 13

Page 42: Elasticsearch par David Pilato [FR]

Chercher$ curl localhost:9200/twitter/tweet/_search?q=elasticsearch

{ "took" : 24, "timed_out" : false, "_shards" : { "total" : 5, "successful" : 5, "failed" : 0 }, "hits" : { "total" : 1, "max_score" : 0.227, "hits" : [ { "_index" : "twitter", "_type" : "tweet", "_id" : "1", "_score" : 0.227, "_source" : { "text": "Bienvenue à la conférence #elasticsearch pour #JUG", "created_at": "2012-04-06T20:45:36.000Z", "source": "Twitter for iPad", […] } } ] }}

Document source

lundi 23 septembre 13

Page 43: Elasticsearch par David Pilato [FR]

Query DSL

• Requêtes précises : plutôt que de chercher « à la google », on peut utiliser des critères précis :

lundi 23 septembre 13

Page 44: Elasticsearch par David Pilato [FR]

Query DSL

• Requêtes précises : plutôt que de chercher « à la google », on peut utiliser des critères précis :$ curl -XPOST localhost:9200/twitter/tweet/_search -d ’{ "bool" : { "must" : { "term" : { "user" : "kimchy" } }, "must_not" : { "range" : { "age" : { "from" : 10, "to" : 20 } } }, "should" : [ { "term" : { "tag" : "wow" } },{ "match" : { "tag" : "elasticsearch is cool" } } ] }}’

lundi 23 septembre 13

Page 45: Elasticsearch par David Pilato [FR]

Injecter les donnéesEt au milieu coule une rivière

lundi 23 septembre 13

Page 46: Elasticsearch par David Pilato [FR]

La collecte

lundi 23 septembre 13

Page 47: Elasticsearch par David Pilato [FR]

La collecte

Stockage Données

lundi 23 septembre 13

Page 48: Elasticsearch par David Pilato [FR]

La collecte

Stockage Données

Doc

lundi 23 septembre 13

Page 49: Elasticsearch par David Pilato [FR]

La collecte

Stockage Données

Doc

lundi 23 septembre 13

Page 50: Elasticsearch par David Pilato [FR]

La collecte

Stockage Données

Doc

Doc

lundi 23 septembre 13

Page 51: Elasticsearch par David Pilato [FR]

La collecte

Stockage Données

Doc Doc

lundi 23 septembre 13

Page 52: Elasticsearch par David Pilato [FR]

La collecte

Stockage Données

Doc Doc

lundi 23 septembre 13

Page 53: Elasticsearch par David Pilato [FR]

La collecte

Stockage Données

Doc Doc

lundi 23 septembre 13

Page 54: Elasticsearch par David Pilato [FR]

La collecte

Stockage Données

Doc

Doc

lundi 23 septembre 13

Page 55: Elasticsearch par David Pilato [FR]

La collecte

Stockage Données

Doc

Doc

Doc

lundi 23 septembre 13

Page 56: Elasticsearch par David Pilato [FR]

La collecte

Stockage Données

DocDoc

Doc

lundi 23 septembre 13

Page 57: Elasticsearch par David Pilato [FR]

La collecte

Stockage Données

DocDocDoc

lundi 23 septembre 13

Page 58: Elasticsearch par David Pilato [FR]

Quelques Rivers...

lundi 23 septembre 13

Page 59: Elasticsearch par David Pilato [FR]

Quelques Rivers...• CouchDB River

lundi 23 septembre 13

Page 60: Elasticsearch par David Pilato [FR]

Quelques Rivers...• CouchDB River

• CouchBase River

lundi 23 septembre 13

Page 61: Elasticsearch par David Pilato [FR]

Quelques Rivers...• CouchDB River

• CouchBase River

• MongoDB River

lundi 23 septembre 13

Page 62: Elasticsearch par David Pilato [FR]

Quelques Rivers...• CouchDB River

• CouchBase River

• MongoDB River

• JDBC River

lundi 23 septembre 13

Page 63: Elasticsearch par David Pilato [FR]

Quelques Rivers...• CouchDB River

• CouchBase River

• MongoDB River

• JDBC River

• Wikipedia River

lundi 23 septembre 13

Page 64: Elasticsearch par David Pilato [FR]

Quelques Rivers...• CouchDB River

• CouchBase River

• MongoDB River

• JDBC River

• Wikipedia River

• Twitter River

lundi 23 septembre 13

Page 65: Elasticsearch par David Pilato [FR]

Quelques Rivers...• CouchDB River

• CouchBase River

• MongoDB River

• JDBC River

• Wikipedia River

• Twitter River

• RabbitMQ River

lundi 23 septembre 13

Page 66: Elasticsearch par David Pilato [FR]

Quelques Rivers...• CouchDB River

• CouchBase River

• MongoDB River

• JDBC River

• Wikipedia River

• Twitter River

• RabbitMQ River

• ActiveMQ River

lundi 23 septembre 13

Page 67: Elasticsearch par David Pilato [FR]

Quelques Rivers...• CouchDB River

• CouchBase River

• MongoDB River

• JDBC River

• Wikipedia River

• Twitter River

• RabbitMQ River

• ActiveMQ River

• RSS River

lundi 23 septembre 13

Page 68: Elasticsearch par David Pilato [FR]

Quelques Rivers...• CouchDB River

• CouchBase River

• MongoDB River

• JDBC River

• Wikipedia River

• Twitter River

• RabbitMQ River

• ActiveMQ River

• RSS River

• LDAP River

lundi 23 septembre 13

Page 69: Elasticsearch par David Pilato [FR]

Quelques Rivers...• CouchDB River

• CouchBase River

• MongoDB River

• JDBC River

• Wikipedia River

• Twitter River

• RabbitMQ River

• ActiveMQ River

• RSS River

• LDAP River

• FS River

lundi 23 septembre 13

Page 70: Elasticsearch par David Pilato [FR]

Quelques Rivers...• CouchDB River

• CouchBase River

• MongoDB River

• JDBC River

• Wikipedia River

• Twitter River

• RabbitMQ River

• ActiveMQ River

• RSS River

• LDAP River

• FS River

• Dropbox River

lundi 23 septembre 13

Page 71: Elasticsearch par David Pilato [FR]

Quelques Rivers...• CouchDB River

• CouchBase River

• MongoDB River

• JDBC River

• Wikipedia River

• Twitter River

• RabbitMQ River

• ActiveMQ River

• RSS River

• LDAP River

• FS River

• Dropbox River

• Dick Rivers

lundi 23 septembre 13

Page 72: Elasticsearch par David Pilato [FR]

Quelques Rivers...• CouchDB River

• CouchBase River

• MongoDB River

• JDBC River

• Wikipedia River

• Twitter River

• RabbitMQ River

• ActiveMQ River

• RSS River

• LDAP River

• FS River

• Dropbox River

• Dick Rivers

lundi 23 septembre 13

Page 73: Elasticsearch par David Pilato [FR]

AnalyserLa puissance des facettes !

Faites parler vos données en les regardant sous différentes facettes !(Et en temps quasi réel, s’il vous plait !)

lundi 23 septembre 13

Page 74: Elasticsearch par David Pilato [FR]

Des tweets

ID Username Date Hashtag

1 dadoonet 2012-04-18 1

2 talk 2012-04-18 5

3 elasticsearch 2012-04-18 2

4 dadoonet 2012-04-18 2

5 talk 2012-04-18 6

6 elasticsearch 2012-04-19 3

7 dadoonet 2012-04-19 3

8 talk 2012-04-19 7

9 elasticsearch 2012-04-20 4

lundi 23 septembre 13

Page 75: Elasticsearch par David Pilato [FR]

Term Facet

ID Username Date Hashtag

1 dadoonet 2012-04-18 1

2 talk 2012-04-18 5

3 elasticsearch 2012-04-18 2

4 dadoonet 2012-04-18 2

5 talk 2012-04-18 6

6 elasticsearch 2012-04-19 3

7 dadoonet 2012-04-19 3

8 talk 2012-04-19 7

9 elasticsearch 2012-04-20 4

lundi 23 septembre 13

Page 76: Elasticsearch par David Pilato [FR]

Term Facet

ID Username Date Hashtag

1 dadoonet 2012-04-18 1

2 talk 2012-04-18 5

3 elasticsearch 2012-04-18 2

4 dadoonet 2012-04-18 2

5 talk 2012-04-18 6

6 elasticsearch 2012-04-19 3

7 dadoonet 2012-04-19 3

8 talk 2012-04-19 7

9 elasticsearch 2012-04-20 4

Username Count

dadoonet 3

talk 3

elasticsearch 3

lundi 23 septembre 13

Page 77: Elasticsearch par David Pilato [FR]

Term Facet

ID Username Date Hashtag

1 dadoonet 2012-04-18 1

2 talk 2012-04-18 5

3 elasticsearch 2012-04-18 2

4 dadoonet 2012-04-18 2

5 talk 2012-04-18 6

6 elasticsearch 2012-04-19 3

7 dadoonet 2012-04-19 3

8 talk 2012-04-19 7

9 elasticsearch 2012-04-20 4

lundi 23 septembre 13

Page 78: Elasticsearch par David Pilato [FR]

Term Facet

ID Username Date Hashtag

1 dadoonet 2012-04-18 1

2 talk 2012-04-18 5

3 elasticsearch 2012-04-18 2

4 dadoonet 2012-04-18 2

5 talk 2012-04-18 6

6 elasticsearch 2012-04-19 3

7 dadoonet 2012-04-19 3

8 talk 2012-04-19 7

9 elasticsearch 2012-04-20 4

"facets" : { "users" : { "terms" : {"field" : "username"} } }

lundi 23 septembre 13

Page 79: Elasticsearch par David Pilato [FR]

Term Facet

ID Username Date Hashtag

1 dadoonet 2012-04-18 1

2 talk 2012-04-18 5

3 elasticsearch 2012-04-18 2

4 dadoonet 2012-04-18 2

5 talk 2012-04-18 6

6 elasticsearch 2012-04-19 3

7 dadoonet 2012-04-19 3

8 talk 2012-04-19 7

9 elasticsearch 2012-04-20 4

"facets" : { "users" : { "terms" : {"field" : "username"} } }

"facets" : { "users" : { "_type" : "terms", "missing" : 0, "total": 9, "other": 0, "terms" : [ { "term" : "dadoonet", "count" : 3 }, { "term" : "talk", "count" : 3 }, { "term" : "elasticsearch", "count" : 3 } ] }}

lundi 23 septembre 13

Page 80: Elasticsearch par David Pilato [FR]

Date Histogram Facet

ID Username Date Hashtag

1 dadoonet 2012-04-18 1

2 talk 2012-04-18 5

3 elasticsearch 2012-04-18 2

4 dadoonet 2012-04-18 2

5 talk 2012-04-18 6

6 elasticsearch 2012-04-19 3

7 dadoonet 2012-04-19 3

8 talk 2012-04-19 7

9 elasticsearch 2012-04-20 4

lundi 23 septembre 13

Page 81: Elasticsearch par David Pilato [FR]

Date Histogram Facet

ID Username Date Hashtag

1 dadoonet 2012-04-18 1

2 talk 2012-04-18 5

3 elasticsearch 2012-04-18 2

4 dadoonet 2012-04-18 2

5 talk 2012-04-18 6

6 elasticsearch 2012-04-19 3

7 dadoonet 2012-04-19 3

8 talk 2012-04-19 7

9 elasticsearch 2012-04-20 4

Par moisPar mois

Date Count

2012-04 9

lundi 23 septembre 13

Page 82: Elasticsearch par David Pilato [FR]

Date Histogram Facet

ID Username Date Hashtag

1 dadoonet 2012-04-18 1

2 talk 2012-04-18 5

3 elasticsearch 2012-04-18 2

4 dadoonet 2012-04-18 2

5 talk 2012-04-18 6

6 elasticsearch 2012-04-19 3

7 dadoonet 2012-04-19 3

8 talk 2012-04-19 7

9 elasticsearch 2012-04-20 4

Par moisPar mois

Date Count

2012-04 9

Par jourPar jour

Date Count

2012-04-18 5

2012-04-19 3

2012-04-20 1

lundi 23 septembre 13

Page 83: Elasticsearch par David Pilato [FR]

Date Histogram Facet

ID Username Date Hashtag

1 dadoonet 2012-04-18 1

2 talk 2012-04-18 5

3 elasticsearch 2012-04-18 2

4 dadoonet 2012-04-18 2

5 talk 2012-04-18 6

6 elasticsearch 2012-04-19 3

7 dadoonet 2012-04-19 3

8 talk 2012-04-19 7

9 elasticsearch 2012-04-20 4

lundi 23 septembre 13

Page 84: Elasticsearch par David Pilato [FR]

Date Histogram Facet

ID Username Date Hashtag

1 dadoonet 2012-04-18 1

2 talk 2012-04-18 5

3 elasticsearch 2012-04-18 2

4 dadoonet 2012-04-18 2

5 talk 2012-04-18 6

6 elasticsearch 2012-04-19 3

7 dadoonet 2012-04-19 3

8 talk 2012-04-19 7

9 elasticsearch 2012-04-20 4

"facets" : { "perday" : { "date_histogram" : { "field" : "date", "interval" : "day" } } }

lundi 23 septembre 13

Page 85: Elasticsearch par David Pilato [FR]

Date Histogram Facet

ID Username Date Hashtag

1 dadoonet 2012-04-18 1

2 talk 2012-04-18 5

3 elasticsearch 2012-04-18 2

4 dadoonet 2012-04-18 2

5 talk 2012-04-18 6

6 elasticsearch 2012-04-19 3

7 dadoonet 2012-04-19 3

8 talk 2012-04-19 7

9 elasticsearch 2012-04-20 4

"facets" : { "perday" : { "date_histogram" : { "field" : "date", "interval" : "day" } } }

"facets" : { "perday" : { "_type" : "date_histogram", "entries": [ { "time": 1334700000000, "count": 5 }, { "time": 1334786400000, "count": 3 }, { "time": 1334872800000, "count": 1 } ] }}

lundi 23 septembre 13

Page 86: Elasticsearch par David Pilato [FR]

Range Facet

ID Username Date Hashtag

1 dadoonet 2012-04-18 1

2 talk 2012-04-18 5

3 elasticsearch 2012-04-18 2

4 dadoonet 2012-04-18 2

5 talk 2012-04-18 6

6 elasticsearch 2012-04-19 3

7 dadoonet 2012-04-19 3

8 talk 2012-04-19 7

9 elasticsearch 2012-04-20 4

lundi 23 septembre 13

Page 87: Elasticsearch par David Pilato [FR]

Range Facet

ID Username Date Hashtag

1 dadoonet 2012-04-18 1

2 talk 2012-04-18 5

3 elasticsearch 2012-04-18 2

4 dadoonet 2012-04-18 2

5 talk 2012-04-18 6

6 elasticsearch 2012-04-19 3

7 dadoonet 2012-04-19 3

8 talk 2012-04-19 7

9 elasticsearch 2012-04-20 4

Hashtag Count Min Max Moy Total

x < 3 3 1 2 1.667 5

3 <= x < 5 3 3 4 3.333 10

x >= 5 3 5 7 6 18

lundi 23 septembre 13

Page 88: Elasticsearch par David Pilato [FR]

Range Facet

ID Username Date Hashtag

1 dadoonet 2012-04-18 1

2 talk 2012-04-18 5

3 elasticsearch 2012-04-18 2

4 dadoonet 2012-04-18 2

5 talk 2012-04-18 6

6 elasticsearch 2012-04-19 3

7 dadoonet 2012-04-19 3

8 talktalk 2012-04-19 7

9 elasticsearch 2012-04-20 4

lundi 23 septembre 13

Page 89: Elasticsearch par David Pilato [FR]

Range Facet

ID Username Date Hashtag

1 dadoonet 2012-04-18 1

2 talk 2012-04-18 5

3 elasticsearch 2012-04-18 2

4 dadoonet 2012-04-18 2

5 talk 2012-04-18 6

6 elasticsearch 2012-04-19 3

7 dadoonet 2012-04-19 3

8 talktalk 2012-04-19 7

9 elasticsearch 2012-04-20 4

"facets" : { "hashtags" : { "range" : { "field" : "hashtag", "ranges" : [ { "to" : 3 }, { "from" : 3, "to" : 5 }, { "from" : 5 } ] } } }

lundi 23 septembre 13

Page 90: Elasticsearch par David Pilato [FR]

Range Facet

ID Username Date Hashtag

1 dadoonet 2012-04-18 1

2 talk 2012-04-18 5

3 elasticsearch 2012-04-18 2

4 dadoonet 2012-04-18 2

5 talk 2012-04-18 6

6 elasticsearch 2012-04-19 3

7 dadoonet 2012-04-19 3

8 talktalk 2012-04-19 7

9 elasticsearch 2012-04-20 4

"facets" : { "hashtags" : { "range" : { "field" : "hashtag", "ranges" : [ { "to" : 3 }, { "from" : 3, "to" : 5 }, { "from" : 5 } ] } } }

"facets" : { "hashtags" : { "_type" : "range", "ranges" : [ { "to": 3, "count": 3, "min": 1, "max": 2, "total": 5, "mean": 1.667 }, { "from":3, "to" : 5, "count": 3, "min": 3, "max": 4, "total": 10, "mean": 3.333 },{ "from":5, "count": 3, "min": 5, "max": 7, "total": 18, "mean": 6 } ] } }

lundi 23 septembre 13

Page 91: Elasticsearch par David Pilato [FR]

Site marchand

lundi 23 septembre 13

Page 92: Elasticsearch par David Pilato [FR]

Site marchand

lundi 23 septembre 13

Page 93: Elasticsearch par David Pilato [FR]

Site marchand

lundi 23 septembre 13

Page 94: Elasticsearch par David Pilato [FR]

Site marchand

lundi 23 septembre 13

Page 95: Elasticsearch par David Pilato [FR]

Site marchand

Ranges

Term

Term

Ranges

lundi 23 septembre 13

Page 96: Elasticsearch par David Pilato [FR]

Analyse temps-réel

• Faire un matchAll sur l'ensemble des données

• Actualiser toutes les x secondes

• Indexer en même temps les nouvelles données

Term

Date histogram

lundi 23 septembre 13

Page 97: Elasticsearch par David Pilato [FR]

Facettes Cartographiques

lundi 23 septembre 13

Page 98: Elasticsearch par David Pilato [FR]

Reprenons notre formulaire

lundi 23 septembre 13

Page 99: Elasticsearch par David Pilato [FR]

Reprenons notre formulaire

Recherche Full Text

lundi 23 septembre 13

Page 100: Elasticsearch par David Pilato [FR]

Reprenons notre formulaire

lundi 23 septembre 13

Page 101: Elasticsearch par David Pilato [FR]

Reprenons notre formulaire

lundi 23 septembre 13

Page 102: Elasticsearch par David Pilato [FR]

DémonstrationAvez-vous fait du bruit ?

lundi 23 septembre 13

Page 103: Elasticsearch par David Pilato [FR]

Architecture

Chrome

lundi 23 septembre 13

Page 104: Elasticsearch par David Pilato [FR]

Architecture

Chrome

lundi 23 septembre 13

Page 105: Elasticsearch par David Pilato [FR]

Architecture

TwitterStreaming

API

Chrome

lundi 23 septembre 13

Page 106: Elasticsearch par David Pilato [FR]

Architecture

TwitterStreaming

API

Chrome

lundi 23 septembre 13

Page 107: Elasticsearch par David Pilato [FR]

Architecture

TwitterRiver

TwitterStreaming

API

Chrome

$ curl -XPUT localhost:9200/_river/twitter/_meta -d '{ "type" : "twitter", "twitter" : { "user" : "twitter_user", "password" : "twitter_password", "filter" : { "tracks" : ["elasticsearch"] } }}'

lundi 23 septembre 13

Page 108: Elasticsearch par David Pilato [FR]

Démonstrationshttp://onemilliontweetmap.com/

http://www.scrutmydocs.orgMake sense of your (BIG) datahttp://elasticsearch.pilato.fr/

lundi 23 septembre 13

Page 109: Elasticsearch par David Pilato [FR]

ArchitectureUn peu plus de technique : partitions / réplications / scalabilité

lundi 23 septembre 13

Page 110: Elasticsearch par David Pilato [FR]

Lexique

lundi 23 septembre 13

Page 111: Elasticsearch par David Pilato [FR]

Lexique

• Nœud (node) : Une instance d'Elasticsearch (~ machine ?)

lundi 23 septembre 13

Page 112: Elasticsearch par David Pilato [FR]

Lexique

• Nœud (node) : Une instance d'Elasticsearch (~ machine ?)

• Cluster : Un ensemble de nœuds

lundi 23 septembre 13

Page 113: Elasticsearch par David Pilato [FR]

Lexique

• Nœud (node) : Une instance d'Elasticsearch (~ machine ?)

• Cluster : Un ensemble de nœuds

• Partition (shard) : permet de découper un index en plusieurs parties pour y distribuer les documents

lundi 23 septembre 13

Page 114: Elasticsearch par David Pilato [FR]

Lexique

• Nœud (node) : Une instance d'Elasticsearch (~ machine ?)

• Cluster : Un ensemble de nœuds

• Partition (shard) : permet de découper un index en plusieurs parties pour y distribuer les documents

• Réplication (replica) : recopie d’une partition en une ou plusieurs copies dans l'ensemble du cluster

lundi 23 septembre 13

Page 115: Elasticsearch par David Pilato [FR]

Créons un index

Cluster

Nœud 1

Client CURL

lundi 23 septembre 13

Page 116: Elasticsearch par David Pilato [FR]

Créons un index

Cluster

Nœud 1

Shard 0

Shard 1

réplication non respectée

Client CURL

$ curl -XPUT localhost:9200/twitter -d '{

"index" : {

"number_of_shards" : 2,

"number_of_replicas" : 1

}

}'

lundi 23 septembre 13

Page 117: Elasticsearch par David Pilato [FR]

Créons un index

Cluster

Nœud 2

Shard 0

Shard 1

Nœud 1

Shard 0

Shard 1

réplication respectée

Client CURL

$ curl -XPUT localhost:9200/twitter -d '{

"index" : {

"number_of_shards" : 2,

"number_of_replicas" : 1

}

}'

lundi 23 septembre 13

Page 118: Elasticsearch par David Pilato [FR]

Réallocation dynamique

Cluster

Nœud 1

Shard 1

Nœud 2

Shard 0

Shard 1

Shard 0

lundi 23 septembre 13

Page 119: Elasticsearch par David Pilato [FR]

Réallocation dynamique

Cluster

Nœud 3Nœud 1

Shard 1

Nœud 2

Shard 0

Shard 1

Shard 0 Shard 0

lundi 23 septembre 13

Page 120: Elasticsearch par David Pilato [FR]

Réallocation dynamique

Cluster

Nœud 3Nœud 1

Shard 1

Nœud 2

Shard 0

Shard 1

Shard 0 Shard 0

lundi 23 septembre 13

Page 121: Elasticsearch par David Pilato [FR]

Réallocation dynamique

Cluster

Nœud 3Nœud 1

Shard 1

Nœud 2

Shard 1

Shard 0 Shard 0

lundi 23 septembre 13

Page 122: Elasticsearch par David Pilato [FR]

Réallocation dynamique

Cluster

Nœud 3Nœud 1

Shard 1

Nœud 2

Shard 1

Shard 0

Shard 1

Shard 0

lundi 23 septembre 13

Page 123: Elasticsearch par David Pilato [FR]

Réallocation dynamique

Cluster

Nœud 3Nœud 1

Shard 1

Nœud 2

Shard 1

Shard 0

Nœud 4

Shard 1

Shard 0

lundi 23 septembre 13

Page 124: Elasticsearch par David Pilato [FR]

Réallocation dynamique

Cluster

Nœud 3Nœud 1

Shard 1

Nœud 2

Shard 1

Shard 0

Nœud 4

Shard 1

Shard 0

lundi 23 septembre 13

Page 125: Elasticsearch par David Pilato [FR]

Réallocation dynamique

Cluster

Nœud 3Nœud 1 Nœud 2

Shard 1

Shard 0

Nœud 4

Shard 1

Le tuning, c'est trouver le bon équilibre entre le nombre de nodes, shards et replicas !

Shard 0

lundi 23 septembre 13

Page 126: Elasticsearch par David Pilato [FR]

Indexons un document

$ curl -XPUT localhost:9200/twitter/tweet/1 -d '{ "text": "Bienvenue à la conférence #elasticsearch pour #JUG", "created_at": "2012-04-06T20:45:36.000Z", "source": "Twitter for iPad", ...}'

Cluster

Nœud 3Nœud 1 Nœud 2

Shard 1

Shard 0 Shard 0

Nœud 4

Shard 1

Client CURL

Doc 1

lundi 23 septembre 13

Page 127: Elasticsearch par David Pilato [FR]

Indexons un document

$ curl -XPUT localhost:9200/twitter/tweet/1 -d '{ "text": "Bienvenue à la conférence #elasticsearch pour #JUG", "created_at": "2012-04-06T20:45:36.000Z", "source": "Twitter for iPad", ...}'

Cluster

Nœud 3Nœud 1 Nœud 2

Shard 1

Shard 0 Shard 0

Nœud 4

Shard 1

Client CURL

Doc 1

lundi 23 septembre 13

Page 128: Elasticsearch par David Pilato [FR]

Indexons un document

$ curl -XPUT localhost:9200/twitter/tweet/1 -d '{ "text": "Bienvenue à la conférence #elasticsearch pour #JUG", "created_at": "2012-04-06T20:45:36.000Z", "source": "Twitter for iPad", ...}'

Cluster

Nœud 3Nœud 1 Nœud 2

Shard 1

Shard 0 Shard 0

Nœud 4

Shard 1

Client CURL

Doc 1

Doc 1

lundi 23 septembre 13

Page 129: Elasticsearch par David Pilato [FR]

Indexons un document

$ curl -XPUT localhost:9200/twitter/tweet/1 -d '{ "text": "Bienvenue à la conférence #elasticsearch pour #JUG", "created_at": "2012-04-06T20:45:36.000Z", "source": "Twitter for iPad", ...}'

Cluster

Nœud 3Nœud 1 Nœud 2

Shard 1

Shard 0 Shard 0

Nœud 4

Shard 1

Client CURL

Doc 1

Doc 1

lundi 23 septembre 13

Page 130: Elasticsearch par David Pilato [FR]

Indexons un 2ème document

$ curl -XPUT localhost:9200/twitter/tweet/2 -d '{ "text": "Je fais du bruit pour #elasticsearch à #JUG", "created_at": "2012-04-06T21:12:52.000Z", "source": "Twitter for iPad", ...}'

Cluster

Nœud 3Nœud 1 Nœud 2

Shard 1

Shard 0 Shard 0

Nœud 4

Shard 1

Client CURL

Doc 1

Doc 1

Doc 2

lundi 23 septembre 13

Page 131: Elasticsearch par David Pilato [FR]

Indexons un 2ème document

$ curl -XPUT localhost:9200/twitter/tweet/2 -d '{ "text": "Je fais du bruit pour #elasticsearch à #JUG", "created_at": "2012-04-06T21:12:52.000Z", "source": "Twitter for iPad", ...}'

Cluster

Nœud 3Nœud 1 Nœud 2

Shard 1

Shard 0 Shard 0

Nœud 4

Shard 1

Client CURL

Doc 1

Doc 1

Doc 2

lundi 23 septembre 13

Page 132: Elasticsearch par David Pilato [FR]

Indexons un 2ème document

$ curl -XPUT localhost:9200/twitter/tweet/2 -d '{ "text": "Je fais du bruit pour #elasticsearch à #JUG", "created_at": "2012-04-06T21:12:52.000Z", "source": "Twitter for iPad", ...}'

Cluster

Nœud 3Nœud 1 Nœud 2

Shard 1

Shard 0 Shard 0

Nœud 4

Shard 1

Client CURL

Doc 1

Doc 1

Doc 2

lundi 23 septembre 13

Page 133: Elasticsearch par David Pilato [FR]

Indexons un 2ème document

$ curl -XPUT localhost:9200/twitter/tweet/2 -d '{ "text": "Je fais du bruit pour #elasticsearch à #JUG", "created_at": "2012-04-06T21:12:52.000Z", "source": "Twitter for iPad", ...}'

Cluster

Nœud 3Nœud 1 Nœud 2

Shard 1

Shard 0 Shard 0

Nœud 4

Shard 1

Client CURL

Doc 1

Doc 1

Doc 2

Doc 2

lundi 23 septembre 13

Page 134: Elasticsearch par David Pilato [FR]

Indexons un 2ème document

$ curl -XPUT localhost:9200/twitter/tweet/2 -d '{ "text": "Je fais du bruit pour #elasticsearch à #JUG", "created_at": "2012-04-06T21:12:52.000Z", "source": "Twitter for iPad", ...}'

Cluster

Nœud 3Nœud 1 Nœud 2

Shard 1

Shard 0 Shard 0

Nœud 4

Shard 1

Client CURL

Doc 1

Doc 1

Doc 2

Doc 2

lundi 23 septembre 13

Page 135: Elasticsearch par David Pilato [FR]

Cherchons !

$ curl localhost:9200/twitter/_search?q=elasticsearch

Cluster

Nœud 3Nœud 1 Nœud 2

Shard 1

Shard 0 Shard 0

Nœud 4

Shard 1

Client CURL

Doc 1

Doc 1

Doc 2

Doc 2

lundi 23 septembre 13

Page 136: Elasticsearch par David Pilato [FR]

Cherchons !

$ curl localhost:9200/twitter/_search?q=elasticsearch

Cluster

Nœud 3Nœud 1 Nœud 2

Shard 1

Shard 0 Shard 0

Nœud 4

Shard 1

Client CURL

Doc 1

Doc 1

Doc 2

Doc 2

lundi 23 septembre 13

Page 137: Elasticsearch par David Pilato [FR]

Cherchons !

$ curl localhost:9200/twitter/_search?q=elasticsearch

Cluster

Nœud 3Nœud 1 Nœud 2

Shard 1

Shard 0 Shard 0

Nœud 4

Shard 1

Client CURL

Doc 1

Doc 1

Doc 2

Doc 2

lundi 23 septembre 13

Page 138: Elasticsearch par David Pilato [FR]

Cherchons !

$ curl localhost:9200/twitter/_search?q=elasticsearch

Cluster

Nœud 3Nœud 1 Nœud 2

Shard 1

Shard 0 Shard 0

Nœud 4

Shard 1

Client CURL

Doc 1

Doc 1

Doc 2

Doc 2

lundi 23 septembre 13

Page 139: Elasticsearch par David Pilato [FR]

Cherchons !

$ curl localhost:9200/twitter/_search?q=elasticsearch

Cluster

Nœud 3Nœud 1 Nœud 2

Shard 1

Shard 0 Shard 0

Nœud 4

Shard 1

Client CURL

Doc 1

Doc 1

Doc 2

Doc 2

{ "took" : 24, "timed_out" : false, "_shards" : { "total" : 5, "successful" : 5, "failed" : 0 }, "hits" : { "total" : 2, "max_score" : 0.227, "hits" : [ { "_index" : "twitter", "_type" : "tweet", "_id" : "1", "_score" : 0.227, "_source" : { ... } }, { "_index" : "twitter", "_type" : "tweet", "_id" : "2", "_score" : 0.152, "_source" : { ... } } ] }

lundi 23 septembre 13

Page 140: Elasticsearch par David Pilato [FR]

Cherchons encore !

$ curl localhost:9200/twitter/_search?q=elasticsearch

Cluster

Nœud 3Nœud 1 Nœud 2

Shard 1

Shard 0 Shard 0

Nœud 4

Shard 1

Client CURL

Doc 1

Doc 1

Doc 2

Doc 2

lundi 23 septembre 13

Page 141: Elasticsearch par David Pilato [FR]

Cherchons encore !

$ curl localhost:9200/twitter/_search?q=elasticsearch

Cluster

Nœud 3Nœud 1 Nœud 2

Shard 1

Shard 0 Shard 0

Nœud 4

Shard 1

Client CURL

Doc 1

Doc 1

Doc 2

Doc 2

lundi 23 septembre 13

Page 142: Elasticsearch par David Pilato [FR]

Cherchons encore !

$ curl localhost:9200/twitter/_search?q=elasticsearch

Cluster

Nœud 3Nœud 1 Nœud 2

Shard 1

Shard 0 Shard 0

Nœud 4

Shard 1

Client CURL

Doc 1

Doc 2

Doc 2

Doc 1

lundi 23 septembre 13

Page 143: Elasticsearch par David Pilato [FR]

Cherchons encore !

$ curl localhost:9200/twitter/_search?q=elasticsearch

Cluster

Nœud 3Nœud 1 Nœud 2

Shard 1

Shard 0 Shard 0

Client CURL

Doc 1

Doc 2

Doc 1

lundi 23 septembre 13

Page 144: Elasticsearch par David Pilato [FR]

Cherchons encore !

$ curl localhost:9200/twitter/_search?q=elasticsearch

Cluster

Nœud 3Nœud 1 Nœud 2

Shard 1

Shard 0 Shard 0

Client CURL

Doc 1

Doc 2

Doc 1

lundi 23 septembre 13

Page 145: Elasticsearch par David Pilato [FR]

Cherchons encore !

$ curl localhost:9200/twitter/_search?q=elasticsearch

Cluster

Nœud 3Nœud 1 Nœud 2

Shard 1

Shard 0 Shard 0

Client CURL

Doc 1

Doc 1

Doc 2

lundi 23 septembre 13

Page 146: Elasticsearch par David Pilato [FR]

Cherchons encore !

$ curl localhost:9200/twitter/_search?q=elasticsearch

Cluster

Nœud 3Nœud 1 Nœud 2

Shard 1

Shard 0 Shard 0

Client CURL

Doc 1

Doc 1

Doc 2

lundi 23 septembre 13

Page 147: Elasticsearch par David Pilato [FR]

Cherchons encore !

$ curl localhost:9200/twitter/_search?q=elasticsearch

Cluster

Nœud 3Nœud 1 Nœud 2

Shard 1

Shard 0 Shard 0

Client CURL

Doc 1

Doc 1

Doc 2

{ "took" : 24, "timed_out" : false, "_shards" : { "total" : 5, "successful" : 5, "failed" : 0 }, "hits" : { "total" : 2, "max_score" : 0.227, "hits" : [ { "_index" : "twitter", "_type" : "tweet", "_id" : "1", "_score" : 0.227, "_source" : { ... } }, { "_index" : "twitter", "_type" : "tweet", "_id" : "2", "_score" : 0.152, "_source" : { ... } } ] }

lundi 23 septembre 13

Page 148: Elasticsearch par David Pilato [FR]

La percolationOu la recherche inversée

lundi 23 septembre 13

Page 149: Elasticsearch par David Pilato [FR]

Usage courant d’un moteur de recherche

• J’indexe un document

• Je cherche de temps en temps si un document m’intéresse

• Avec de la chance, il sera bien placé au niveau pertinence dans les résultats. Sinon, il passe inaperçu !

lundi 23 septembre 13

Page 150: Elasticsearch par David Pilato [FR]

La recherche inversée

• Enregistrer ses critères de recherche

• A chaque document indexé, on récupère la liste des recherches qui correspondent

• On a un « listener » sur le moteur d’indexation : le percolator

lundi 23 septembre 13

Page 151: Elasticsearch par David Pilato [FR]

Usage du percolator$ curl -XPOST localhost:9200/_percolator/twitter/dadoonet -d ’{ "query" : { "term" : { "user.screen_name" : "dadoonet" } }}’

$ curl -XPOST localhost:9200/_percolator/twitter/elasticsearch -d ’{ "query" : { "match" : { "hashtag.text" : "elasticsearch" } }}’

$ curl -XPOST localhost:9200/_percolator/twitter/mycomplexquery -d ’{ "query" : { "bool" : { "must" : { "term" : { "user" : "kimchy" } }, "must_not" : { "range" : { "age" : { "from" : 10, "to" : 20 } } }, "should" : [ { "term" : { "tag" : "wow" } },{ "match" : { "tag" : "elasticsearch is cool" } } ] } }}’

lundi 23 septembre 13

Page 152: Elasticsearch par David Pilato [FR]

Usage du percolator

lundi 23 septembre 13

Page 153: Elasticsearch par David Pilato [FR]

Usage du percolator$ curl -XPUT localhost:9200/twitter/tweet/1&percolate=* -d '{ "text": "Bienvenue à la conférence #elasticsearch pour #JUG", "created_at": "2012-04-06T20:45:36.000Z", "source": "Twitter for iPad", "truncated": false, "retweet_count": 0, "hashtag": [ { "text": "elasticsearch", "start": 27, "end": 40 }, { "text": "JUG", "start": 47, "end": 55 } ], "user": { "id": 51172224, "name": "David Pilato", "screen_name": "dadoonet", "location": "France", "description": "Soft Architect, Project Manager, Senior Developper.\r\nAt this time, enjoying NoSQL world : CouchDB, ElasticSearch.\r\nDeeJay 4 times a year, just for fun !" }}'

lundi 23 septembre 13

Page 154: Elasticsearch par David Pilato [FR]

Usage du percolator$ curl -XPUT localhost:9200/twitter/tweet/1&percolate=* -d '{ "text": "Bienvenue à la conférence #elasticsearch pour #JUG", "created_at": "2012-04-06T20:45:36.000Z", "source": "Twitter for iPad", "truncated": false, "retweet_count": 0, "hashtag": [ { "text": "elasticsearch", "start": 27, "end": 40 }, { "text": "JUG", "start": 47, "end": 55 } ], "user": { "id": 51172224, "name": "David Pilato", "screen_name": "dadoonet", "location": "France", "description": "Soft Architect, Project Manager, Senior Developper.\r\nAt this time, enjoying NoSQL world : CouchDB, ElasticSearch.\r\nDeeJay 4 times a year, just for fun !" }}'

{ "ok": true, "_index": "twitter", "_type": "tweet", "_id": "1", "matches": [ "dadoonet", "elasticsearch" ]}

lundi 23 septembre 13

Page 155: Elasticsearch par David Pilato [FR]

Tout doit être indexé ?

Analyse et mapping

lundi 23 septembre 13

Page 156: Elasticsearch par David Pilato [FR]

The lazy dog...

lundi 23 septembre 13

Page 157: Elasticsearch par David Pilato [FR]

The quick brown fox jumps over the lazy Dog

The lazy dog...

lundi 23 septembre 13

Page 158: Elasticsearch par David Pilato [FR]

The quick brown fox jumps over the lazy dog

The quick brown fox jumps over the lazy Dog

The lazy dog...

lundi 23 septembre 13

Page 159: Elasticsearch par David Pilato [FR]

Analyseur standard$ curl -XPOST 'localhost:9200/test/_analyze?analyzer=standard&pretty=1' -d 'The quick brown fox jumps over the lazy Dog'

lundi 23 septembre 13

Page 160: Elasticsearch par David Pilato [FR]

Analyseur standard$ curl -XPOST 'localhost:9200/test/_analyze?analyzer=standard&pretty=1' -d 'The quick brown fox jumps over the lazy Dog'

{ "tokens" : [ { "token" : "quick", "start_offset": 4, "end_offset": 9, "type": "<ALPHANUM>", "position": 2 }, { "token" : "brown", "start_offset": 10, "end_offset": 15, "type": "<ALPHANUM>", "position": 3 }, { "token" : "fox", "start_offset": 16, "end_offset": 19, "type": "<ALPHANUM>", "position": 4 }, { "token": "jumps", "start_offset": 20, "end_offset": 26, "type": "<ALPHANUM>", "position": 5 }, { "token": "over", "start_offset": 27, "end_offset": 31, "type": "<ALPHANUM>", "position": 6 }, { "token" : "lazy", "start_offset": 36, "end_offset": 40, "type": "<ALPHANUM>", "position": 8 }, { "token" : "dog", "start_offset": 41, "end_offset": 44, "type": "<ALPHANUM>", "position": 9 } ] }

lundi 23 septembre 13

Page 161: Elasticsearch par David Pilato [FR]

Analyseur whitespace$ curl -XPOST 'localhost:9200/test/_analyze?analyzer=whitespace&pretty=1' -d 'The quick brown fox jumps over the lazy Dog'

lundi 23 septembre 13

Page 162: Elasticsearch par David Pilato [FR]

Analyseur whitespace$ curl -XPOST 'localhost:9200/test/_analyze?analyzer=whitespace&pretty=1' -d 'The quick brown fox jumps over the lazy Dog'

{ "tokens" : [ { "token" : "The", ... }, { "token" : "quick", ... }, { "token" : "brown", ... }, { "token" : "fox", ... }, { "token" : "jumps", ... }, { "token" : "over", ... }, { "token" : "the", ... }, { "token" : "lazy", ... }, { "token" : "Dog", ... } ] }

lundi 23 septembre 13

Page 163: Elasticsearch par David Pilato [FR]

Un analyseur

Un ensemble de tokenizers et

de filtres

lundi 23 septembre 13

Page 164: Elasticsearch par David Pilato [FR]

Un tokenizer

• Découpe une chaine en « mots » et transforme :

• whitespace tokenizer :

"the dog!" -> "the", "dog!"

• standard tokenizer :

"the dog!" -> "the", "dog"

lundi 23 septembre 13

Page 165: Elasticsearch par David Pilato [FR]

Un filtre• Supprime ou transforme un token :

• asciifolding filter :

éléphant -> elephant

• stemmer filter (french) :

elephants -> "eleph"

cheval -> "cheval"

chevaux -> "cheval"

• phonetic (plugin) :

quick -> "Q200"

quik -> "Q200"

lundi 23 septembre 13

Page 166: Elasticsearch par David Pilato [FR]

Analyzer

"analysis":{ "analyzer":{ "francais":{ "type":"custom", "tokenizer":"standard", "filter":["lowercase", "stop_francais", "fr_stemmer", "asciifolding", "elision"] } }, "filter":{ "stop_francais":{ "type":"stop", "stopwords":["_french_", "twitter"] }, "fr_stemmer" : { "type" : "stemmer", "name" : "french" }, "elision" : { "type" : "elision", "articles" : ["l", "m", "t", "qu", "n", "s", "j", "d"] } } }

lundi 23 septembre 13

Page 167: Elasticsearch par David Pilato [FR]

Mapping "type1" : { "properties" : { "text1" : { "type" : "string", "analyzer" : "simple" }, "text2" : { "type" : "string", "index_analyzer" : "simple", "search_analyzer" : "standard" }, "text3" : { "type" : "multi_field", "fields" : { "text3" : { "type" : "string", "analyzer" : "standard" }, "ngram" : { "type" : "string", "analyzer" : "ngram" }, "soundex" : { "type" : "string", "analyzer" : "soundex" } } } } }

lundi 23 septembre 13

Page 168: Elasticsearch par David Pilato [FR]

Les types• string

• integer / long

• float / double

• boolean

• null

• array

• objects

• multi_field

• ip

• geo_point

• geo_shape

• binary

• attachment (plugin)

lundi 23 septembre 13

Page 169: Elasticsearch par David Pilato [FR]

Champs spéciaux

• _all (et include_in_all)

• _source

• _ttl

• parent / child

• nested

lundi 23 septembre 13

Page 170: Elasticsearch par David Pilato [FR]

Autres fonctionnalités

• highlighting

• scoring

• sort

• bulk

• et bien d’autres...

lundi 23 septembre 13

Page 171: Elasticsearch par David Pilato [FR]

Autres fonctionnalités

• highlighting

• scoring

• sort

• bulk

• et bien d’autres...

lundi 23 septembre 13

Page 172: Elasticsearch par David Pilato [FR]

La communauté

~80 contributeurs directs au projet (+ de 4400 watchers et + de 1000 forks)lundi 23 septembre 13

Page 174: Elasticsearch par David Pilato [FR]

lundi 23 septembre 13

Page 175: Elasticsearch par David Pilato [FR]

Rejoignez le mouvement !@ElasticsearchFR

Slides sur http://fr.slideshare.net/dadoonet Sources sur https://github.com/elasticsearchfr/talks

Prochaines rencontres surhttp://www.meetup.com/elasticsearchfr/

lundi 23 septembre 13