Upgrade to Pro
— share decks privately, control downloads, hide ads and more …
Speaker Deck
Features
Speaker Deck
PRO
Sign in
Sign up for free
Search
Search
Aloha Ruby Conf 2012: Message in a Bottle
Search
Konstantin Haase
October 10, 2012
5
2k
Aloha Ruby Conf 2012: Message in a Bottle
Konstantin Haase
October 10, 2012
Tweet
Share
More Decks by Konstantin Haase
See All by Konstantin Haase
RubyConf Philippines 2017: Magenta is a Lie
rkh
0
180
How We Replaced Salary Negotiations with a Sinatra App
rkh
17
3.9k
HTTP (RubyMonsters Edition)
rkh
5
910
GCRC 2015: Abstract Thoughts on Abstract Things
rkh
1
330
Frozen Rails: Magenta - The Art Of Abstraction
rkh
3
260
RedDotRubyConf 2014: Magenta is a Lie - and other tales of abstraction
rkh
0
710
Ancient City Ruby: Hack me, if you can!
rkh
2
380
Boston I/O: Continuous Integration
rkh
3
270
Steel City Ruby: Architecting Chaos
rkh
4
810
Featured
See All Featured
How to name files
jennybc
65
94k
How to Ace a Technical Interview
jacobian
273
22k
Stop Working from a Prison Cell
hatefulcrawdad
266
19k
Design by the Numbers
sachag
274
18k
How to train your dragon (web standard)
notwaldorf
75
5.2k
Rebuilding a faster, lazier Slack
samanthasiow
74
8.3k
Learning to Love Humans: Emotional Interface Design
aarron
267
39k
How GitHub (no longer) Works
holman
305
140k
Design and Strategy: How to Deal with People Who Don’t "Get" Design
morganepeng
117
18k
Testing 201, or: Great Expectations
jmmastey
30
6.4k
Build The Right Thing And Hit Your Dates
maggiecrowley
25
2k
The Mythical Team-Month
searls
217
42k
Transcript
MESSAGE IN A BOTTLE Konstantin Haase Aloha Ruby Conference October
8, 2012
Ruby 1.8 is slow because it's interpreted.
Surprise! Ruby 1.9 is interpreted, too.
THANKS
@konstantinhaase (I’m sorry about that) rkh on github
None
None
None
None
None
None
WWAPD
Ruby
Internals
Performance
None
RubyMotion rupypy
WHAT WE’LL LOOK INTO MRI: method dispatch and execution Rubinius:
inline caches and JIT JRuby: invokedynamic
None
THEY JUST LOVE BYTECODE
None
MRI
Rubinius
JRuby (JVM 1.6)
None
Source Code Parser Parse Tree Interpreter Bytecode Compiler Bytecode Interpreter
JIT Machine Code CPU VM
THE PLAN Find Method Execute Method
Performance
HOW TO SPEED UP? Find Method Faster Execute Method Faster
FIND FASTER Inline Cache (aka Call/ Send Site Cache) Lookup
Cache Inlining
EXECUTE FASTER Reduce operations Just-in-time compilation Speed up search
None
rb_method_entry rb_method_entry_without_cache search_method
None
None
None
None
None
None
Module MethodTable Bucket CompiledCode
None
None
None
None
InlineCache MachineCode CompiledCode initial_backend execute_backend cache_[cTrackedICHits] execute empty_cache ...
None
SPECIALIZED METHODS cached bytecode code with breakpoints specialized for arguments
JITed code
None
None
None
None
None
None
None
Process invokedynamic JVM method bootstrap guard fallback
None
Reducing CPU instructions Reducing jumps Not breaking late binding
caching inlining JITing guards
FAST LOOKUP FAST EXECUTION
THANKS