Link
Embed
Share
Beginning
This slide
Copy link URL
Copy link URL
Copy iframe embed code
Copy iframe embed code
Copy javascript embed code
Copy javascript embed code
Share
Tweet
Share
Tweet
Slide 1
Slide 1 text
! @mr_foto
Slide 2
Slide 2 text
" @mr_foto
Slide 3
Slide 3 text
HOW YOU REMEMBER SLOVENIA
Slide 4
Slide 4 text
HOW I REMEMBER BELARUS
Slide 5
Slide 5 text
@mr_foto Software Developer Team Lead Git Blame Navigator Time Zone Resolver
Slide 6
Slide 6 text
@mr_foto Software Developer Team Lead Git Blame Navigator Time Zone Resolver Slack Emoji Creator
Slide 7
Slide 7 text
#
Slide 8
Slide 8 text
No content
Slide 9
Slide 9 text
$FLAME GRAPHS$
Slide 10
Slide 10 text
WHY AND WHAT Interactive visualization of stack traces From beginners to experts How SW is consuming CPU Brendan Gregg
Slide 11
Slide 11 text
No content
Slide 12
Slide 12 text
No content
Slide 13
Slide 13 text
No content
Slide 14
Slide 14 text
No content
Slide 15
Slide 15 text
No content
Slide 16
Slide 16 text
SAMPLING My Day Reading Emails
Slide 17
Slide 17 text
My Day Reading Emails Replying to Emails SAMPLING
Slide 18
Slide 18 text
My Day Writing Code SAMPLING
Slide 19
Slide 19 text
My Day Writing Code Writing Tests SAMPLING
Slide 20
Slide 20 text
My Day Writing Code Writing Tests Running Tests SAMPLING
Slide 21
Slide 21 text
My Day Writing Code Writing Tests Running Tests Fixing Tests SAMPLING
Slide 22
Slide 22 text
My Day Writing Code Running Tests SAMPLING
Slide 23
Slide 23 text
My Day Making Espresso SAMPLING
Slide 24
Slide 24 text
SAMPLING My Day Reading Emails
Slide 25
Slide 25 text
My Day Writing Code SAMPLING
Slide 26
Slide 26 text
My Day Writing Code Running Tests SAMPLING
Slide 27
Slide 27 text
My Day Reading Emails Replying to Emails SAMPLING
Slide 28
Slide 28 text
GROUPING
Slide 29
Slide 29 text
GROUPING
Slide 30
Slide 30 text
GROUPING My Day Reading Emails Replying Writing Code ☕ Writing Tests Running Running Fix
Slide 31
Slide 31 text
FLAME GRAPH Function
Slide 32
Slide 32 text
FLAME GRAPH Function
Slide 33
Slide 33 text
FLAME GRAPH Function
Slide 34
Slide 34 text
FLAME GRAPH Stack Depth
Slide 35
Slide 35 text
FLAME GRAPH Stack Depth
Slide 36
Slide 36 text
FLAME GRAPH Stack Depth
Slide 37
Slide 37 text
FLAME GRAPH Stack Depth
Slide 38
Slide 38 text
FLAME GRAPH Ordered by Alphabet
Slide 39
Slide 39 text
FLAME GRAPH Ordered by Alphabet
Slide 40
Slide 40 text
FLAME GRAPH Total Time on CPU
Slide 41
Slide 41 text
FLAME GRAPH Total Time on CPU
Slide 42
Slide 42 text
FLAME GRAPH Total Time on CPU
Slide 43
Slide 43 text
WHO WANTS A T-SHIRT?
Slide 44
Slide 44 text
No content
Slide 45
Slide 45 text
Q&A Q: Which function is on CPU the most?
Slide 46
Slide 46 text
Q&A A: f() top edge shows what is on CPU directly
Slide 47
Slide 47 text
Q&A Q: Why is f() on CPU?
Slide 48
Slide 48 text
Q&A A: a() → b() → c() → e() → f() f() was called by e(), e() was called by c(),…
Slide 49
Slide 49 text
Q&A Q: How does b() compare to g()?
Slide 50
Slide 50 text
Q&A A: b() looks like it is running (present) about 10 times more often than g()
Slide 51
Slide 51 text
USING WITH RUBY Sam Saffron gem 'flamegraph' Flamegraph.generate(filename) do # your work here end
Slide 52
Slide 52 text
TOPTAL.BLOG
Slide 53
Slide 53 text
ORIGINAL 1.083 (± 0.0%) i/s - 33.000 in 30.86s
Slide 54
Slide 54 text
CACHE KRAMDOWN 8.368 (±12.0%) i/s - 244.000 in 30.04s
Slide 55
Slide 55 text
CACHE KRAMDOWN 8.368 (±12.0%) i/s - 244.000 in 30.04s 7.5x improvement
Slide 56
Slide 56 text
MEMOIZATION & CO. 10.140(± 9.9%) i/s - 292.000 in 30.03s
Slide 57
Slide 57 text
MEMOIZATION & CO. 10.140(± 9.9%) i/s - 292.000 in 30.03s 9.4x improvement
Slide 58
Slide 58 text
NOW WHAT? You’re here Ask me Ask someone smarter than me Ask anyone else Read/watch blog posts/videos
Slide 59
Slide 59 text
I ❤ ☕
Slide 60
Slide 60 text
I ❤ ⌨
Slide 61
Slide 61 text
I ❤ (
Slide 62
Slide 62 text
I ❤ )
Slide 63
Slide 63 text
http://mr.si/ @mr_foto THANK YOU