Slide 1

Slide 1 text

Evolving Search

Slide 2

Slide 2 text

Agenda

Slide 3

Slide 3 text

Introduction

Slide 4

Slide 4 text

Kau and e-commerce

Slide 5

Slide 5 text

About me

Slide 6

Slide 6 text

Questions?

Slide 7

Slide 7 text

Questions?

Slide 8

Slide 8 text

Architecture

Slide 9

Slide 9 text

Architecture BigQuery Kafka Indexer Elasticsearch Searcher Monolith reads reads reads writes reads

Slide 10

Slide 10 text

Architecture

Slide 11

Slide 11 text

Architecture

Slide 12

Slide 12 text

Searches

Slide 13

Slide 13 text

Phase: Analysis { "title": "Modernes Wandbild ... Kunstdruck New York", "search_stats": [ { "id_item": 306593629, "rank": 0.00012203718164007487, "term": "modernes wandbild new york" } ] }

Slide 14

Slide 14 text

Phase: Analysis - Category Guessing

Slide 15

Slide 15 text

Phase: Analysis - Shorter queries

Slide 16

Slide 16 text

Phase: Search

Slide 17

Slide 17 text

Search: FTS vs. signals

Slide 18

Slide 18 text

Quiz: ← ←

Slide 19

Slide 19 text

Running in production

Slide 20

Slide 20 text

Cost reduction

Slide 21

Slide 21 text

Journey to Elasticsearch 8

Slide 22

Slide 22 text

Node caches lling up

Slide 23

Slide 23 text

Node caches lling up

Slide 24

Slide 24 text

Upgrade: Unreleased shard locks

Slide 25

Slide 25 text

Performance

Slide 26

Slide 26 text

Performance

Slide 27

Slide 27 text

Less scripting esb .scriptScoreFunction( esb.script('source', "Math.sqrt(1+doc['rank'].value/10)"), ) esb .function(esb.fieldValueFactorFunction('rank').missing(1).weight(

Slide 28

Slide 28 text

Unexpected refreshes

Slide 29

Slide 29 text

Set

Slide 30

Slide 30 text

Set

Slide 31

Slide 31 text

Range query vs. term query { "term" : { "term_exact.token_count" : 2 } } { "range" : { "term_exact.token_count" : { "gte" : 2, "lte" : 2 } } }

Slide 32

Slide 32 text

Range query vs. term query

Slide 33

Slide 33 text

has no e ect

Slide 34

Slide 34 text

Tracking total hits: weird behaviour

Slide 35

Slide 35 text

Switching o a microservice

Slide 36

Slide 36 text

Improving relevance

Slide 37

Slide 37 text

Keyword search

Slide 38

Slide 38 text

ELSER

Slide 39

Slide 39 text

Query Processing Pipeline

Slide 40

Slide 40 text

Query expansion

Slide 41

Slide 41 text

Summary

Slide 42

Slide 42 text

Upgrade!

Slide 43

Slide 43 text

Summary

Slide 44

Slide 44 text

Thank you

Slide 45

Slide 45 text

One last thing

Slide 46

Slide 46 text

Thank you