SlideShare a Scribd company logo
Treasure Island
Treasure Island -- Concurrency in JRuby
Tour
Guides
Treasure Island -- Concurrency in JRuby
Treasure Island -- Concurrency in JRuby
@tlossen
@phuesler
Treasure Island -- Concurrency in JRuby
“The Free Lunch is Over.”
 — Herb Sutter (2005)
Treasure Island -- Concurrency in JRuby
Concurrency
Treasure Island -- Concurrency in JRuby
Treasure Island -- Concurrency in JRuby
Fin?
Treasure Island -- Concurrency in JRuby
Concurrency
Multi Core
Treasure Island -- Concurrency in JRuby
Treasure Island -- Concurrency in JRuby
Thread
Concurrency
!fork()
Rubies!!!
GIL
http://igvita.com/2008/11/13/concurrency-is-a-myth-in-ruby/
Ruby MRI 1.8   X
  REE 1.8      X
Ruby MRI 1.9   X
 IronRuby      (âś”)
  Maglev        ?
  Rubinius     âś”
   JRuby       âś”
 MacRuby       âś”
JRuby
Java Island
Multi-Threading
Treasure Island -- Concurrency in JRuby
Evil?
Treasure Island -- Concurrency in JRuby
Treasure Island -- Concurrency in JRuby
Treasure Island -- Concurrency in JRuby
java.util.
concurrent
Treasure Island -- Concurrency in JRuby
Treasure Island -- Concurrency in JRuby
Atomic
Boolean
CountDown
  Latch
Cyclic
Barrier
Treasure Island -- Concurrency in JRuby
Executor
Future
Treasure Island -- Concurrency in JRuby
Actors
Treasure Island -- Concurrency in JRuby
Bad Actors
Treasure Island -- Concurrency in JRuby
and the
nominees are...
Treasure Island -- Concurrency in JRuby
MRI
Better Actors
Erlang
Scala
Rubinius
JRuby
Frameworks
Treasure Island -- Concurrency in JRuby
Treasure Island -- Concurrency in JRuby
Akka
Treasure Island -- Concurrency in JRuby
Scala
Heavily Inspired
   by Erlang
Simple
Concurrency
Distributed
Fault
Tolerant
Supervisors
Treasure Island -- Concurrency in JRuby
Fast
Treasure Island -- Concurrency in JRuby
Can it be used
 with JRuby?
Yes*
Moarrrrr!!!!
STM
Treasure Island -- Concurrency in JRuby
Treasure Island -- Concurrency in JRuby
Treasure Island -- Concurrency in JRuby
Treasure Island -- Concurrency in JRuby
Treasure Island -- Concurrency in JRuby
Treasure Island -- Concurrency in JRuby
Treasure Island -- Concurrency in JRuby
Treasure Island -- Concurrency in JRuby
Treasure Island -- Concurrency in JRuby
Treasure Island -- Concurrency in JRuby
Treasure Island -- Concurrency in JRuby
Treasure Island -- Concurrency in JRuby
Treasure Island -- Concurrency in JRuby
Treasure Island -- Concurrency in JRuby
Treasure Island -- Concurrency in JRuby
Treasure Island -- Concurrency in JRuby
Evented
Disruptor
http://martinfowler.com/articles/lmax.html
Q&A
“There ain’t no such
thing as a free lunch.”
 — Robert A. Heinlein

          ❦
Links
• “The Free Lunch Is Over” (Herb Sutter, 2005)
• “Real-World Concurrency” (Bryan Cantrill, Jeff
    Bonwick, 2008)
•   “Don't Fear the Threads” (David Copeland, 2012)
•   “Concurrency is not Parallelism” (Rob Pike, 2012)
•   “The LMAX Architecture” (Martin Fowler, 2011)
Treasure Island -- Concurrency in JRuby
Credits
Ajith Kumar (Flickr)


tontoncopt (Flickr)


Hatem Riahi (Flickr)


Stefanie (Flickr)
Credits
Barry Skeates (Flickr)


Hillary White (Flickr)


David Thompson (Flickr)


“Dope Zebra”, Rhett & Link

More Related Content

PDF
Sifat allah
PPTX
Visual Resume
PPTX
Consumers behaviour 2
PPT
Trabajo de evaluacion de periodo
DOC
resume-YOGESH MATHURn
PDF
Spectrum Community Investment Casebook May 2015lo-respages - LB
PDF
Apocalypse Later
PDF
Embracing Failure
Sifat allah
Visual Resume
Consumers behaviour 2
Trabajo de evaluacion de periodo
resume-YOGESH MATHURn
Spectrum Community Investment Casebook May 2015lo-respages - LB
Apocalypse Later
Embracing Failure

More from Tim Lossen (20)

PDF
Embracing Failure
PDF
Enemy of the State?
PDF
Beyond Devops
PDF
All Your Core Are Belong To Us
PDF
Podularity FTW!
PDF
Cubic Foot Gardening
PDF
Dashboard Mania
PDF
Event-Stream Processing with Kafka
PDF
Into the Void
PDF
Dashboard Mania
PDF
JRuby vs. Rubinius
PDF
Redis to the Rescue?
PDF
Redis to the Rescue?
PDF
The Smallest Cluster in the World
PDF
Announcing Euruko 2011
PDF
Memory: The New Disk
PDF
Key-Value-Stores -- The Key to Scaling?
PDF
Cassandra vs. Redis
PDF
An Introduction to Membase
PDF
Petascale Storage -- Do It Yourself!
Embracing Failure
Enemy of the State?
Beyond Devops
All Your Core Are Belong To Us
Podularity FTW!
Cubic Foot Gardening
Dashboard Mania
Event-Stream Processing with Kafka
Into the Void
Dashboard Mania
JRuby vs. Rubinius
Redis to the Rescue?
Redis to the Rescue?
The Smallest Cluster in the World
Announcing Euruko 2011
Memory: The New Disk
Key-Value-Stores -- The Key to Scaling?
Cassandra vs. Redis
An Introduction to Membase
Petascale Storage -- Do It Yourself!
Ad

Recently uploaded (20)

PPTX
Digital-Transformation-Roadmap-for-Companies.pptx
PDF
KodekX | Application Modernization Development
 
PDF
Blue Purple Modern Animated Computer Science Presentation.pdf.pdf
 
PDF
How UI/UX Design Impacts User Retention in Mobile Apps.pdf
PPTX
MYSQL Presentation for SQL database connectivity
PDF
7 ChatGPT Prompts to Help You Define Your Ideal Customer Profile.pdf
PDF
cuic standard and advanced reporting.pdf
PDF
Approach and Philosophy of On baking technology
PDF
Network Security Unit 5.pdf for BCA BBA.
PDF
Review of recent advances in non-invasive hemoglobin estimation
PDF
Dropbox Q2 2025 Financial Results & Investor Presentation
PDF
Encapsulation theory and applications.pdf
PDF
CIFDAQ's Market Insight: SEC Turns Pro Crypto
 
PDF
Reach Out and Touch Someone: Haptics and Empathic Computing
PDF
Per capita expenditure prediction using model stacking based on satellite ima...
PPTX
Effective Security Operations Center (SOC) A Modern, Strategic, and Threat-In...
PDF
Diabetes mellitus diagnosis method based random forest with bat algorithm
PDF
Chapter 3 Spatial Domain Image Processing.pdf
PDF
Machine learning based COVID-19 study performance prediction
PPT
Teaching material agriculture food technology
Digital-Transformation-Roadmap-for-Companies.pptx
KodekX | Application Modernization Development
 
Blue Purple Modern Animated Computer Science Presentation.pdf.pdf
 
How UI/UX Design Impacts User Retention in Mobile Apps.pdf
MYSQL Presentation for SQL database connectivity
7 ChatGPT Prompts to Help You Define Your Ideal Customer Profile.pdf
cuic standard and advanced reporting.pdf
Approach and Philosophy of On baking technology
Network Security Unit 5.pdf for BCA BBA.
Review of recent advances in non-invasive hemoglobin estimation
Dropbox Q2 2025 Financial Results & Investor Presentation
Encapsulation theory and applications.pdf
CIFDAQ's Market Insight: SEC Turns Pro Crypto
 
Reach Out and Touch Someone: Haptics and Empathic Computing
Per capita expenditure prediction using model stacking based on satellite ima...
Effective Security Operations Center (SOC) A Modern, Strategic, and Threat-In...
Diabetes mellitus diagnosis method based random forest with bat algorithm
Chapter 3 Spatial Domain Image Processing.pdf
Machine learning based COVID-19 study performance prediction
Teaching material agriculture food technology
Ad

Treasure Island -- Concurrency in JRuby