SlideShare a Scribd company logo
ERLANG
SILICON VALLEY
MEETUP
April 14, 2014
AGENDA
6:30 - Doors open
6:45 - Introduction / Announcements
7:00 - Why Erlang?
7:45 - Meetup Organization
8:15 - Erlang Intro
9:00 - Doors close
INTRODUCTION
AND
ANNOUNCEMENTS
DOUG GOLDIE
Freelance developer, architect, consultant
Ruby, Rails stack
Boatbound, V.me at Visa, Paynearme
doug@codecauldron.com
WHY ERLANG?
by Doug Goldie
WHATSAPP
• 465M monthly users
• 19B messages in & 40B out per day
• Small team (~10 on Erlang),
handle development and ops
• ~ 550 servers + standby gear
• > 11,000 cores
A YEAR AGO…
• I took the summer off….
• “Why Erlang?”
• Challenges of SOA
• Curious about Erlang.
• Learn a functional language again.
ERICSSON
TELECOM NEEDED
• Concurrency
• Distribution
• Fault Tolerance
• Soft real-time
• Hot code upgrade
• Incremental code loading
• External interfaces
ERLANG
CONCURRENCY
• Isolated processes
• Asynchronous messaging passing
• Actor model
Why erlang
Why erlang
Why erlang
Distributed
FAULT TOLERANCE
Reliability
Redundancy
Nine nines 99.9999999%
SOFT REAL-TIME
Deadlines
Soft allows some slip
SOFT REAL-TIME
Lightweight processes.
Garbage collection
HOT
CODE
UPGRAD
E
Why erlang
INCREMENTAL CODE LOADING
EXTERNAL INTERFACES
–Robert Virding, OTP class, 2014
“It’s about building Systems.”
ERLANG LANGUAGE
FUNCTIONAL
fac(N) when N == 0 -> 1;
fac(N) when N > 0 -> N*fac(N-1).
Recursion
double([H|T]) -> [2*H|double(T)];
double([]) -> [].
Pattern matching
MODULES, ETC.
• Modules
• Behaviours
ERLANG/OTP
OTP• Library of Design
Patterns
• Supervision Tree
• Workers and
supervisors
• Behaviours
CLIENT SERVER
gen_server
FINITE STATE MACHINE
gen_fsm
Why erlang
ELIXIR
• Jose Valim
• Light layer of syntactic sugar
• Pipes
• Macros
THE WEB
THE WEB
• Concurrent
• Soft real-time
• Asynchronous
• Omnipresent
• Internet of Things
Why erlang
REFERENCES
• Erlang and the Web
http://ninenines.eu/docs/en/cowboy/HEAD/guide/erlang_web/
• Concurrency Oriented Programming in Erlang
http://www.guug.de/veranstaltungen/ffg2003/papers/ffg2003-armstrong.pdf
• Why OO Sucks
http://www.sics.se/~joe/bluetail/vol1/v1_oo.html
• Erlang Central
https://erlangcentral.org/
• Erlang History
http://www.erlang.org/faq/academic.html
• WhatsApp presentation
http://www.erlang-factory.com/conference/show/conference-6/home/#rick-reed
DOUG GOLDIE
doug@codecauldron.com

More Related Content

PDF
SITIST 2015 Dev - Intro
PPTX
Welcome to Anjna Global - The DMC of Dubai, Singapore, Malaysia & Bali
PDF
Sfour company overview
PDF
Sajan, Inc. - Innovation in Translation
DOC
CV - Priyank Jain_summarized
PPTX
Finding Translations: Localization and Internationalization in Rails
PPTX
#sitNL - My SAP TechEd takeaways with regards to mobility and developers
SITIST 2015 Dev - Intro
Welcome to Anjna Global - The DMC of Dubai, Singapore, Malaysia & Bali
Sfour company overview
Sajan, Inc. - Innovation in Translation
CV - Priyank Jain_summarized
Finding Translations: Localization and Internationalization in Rails
#sitNL - My SAP TechEd takeaways with regards to mobility and developers

Viewers also liked (20)

ODP
Developing web apps using Erlang-Web
PDF
Erlang web framework: Chicago boss
PDF
Caching Strategies for an Erlang Based Web Stack
PDF
learn you some erlang - chap 6 to chap7
PDF
learn you some erlang - chap0 to chap2
PDF
WebCamp: Developer Day: N2O: The Most Powerful Erlang Web Framework - Максим ...
PDF
MPI, Erlang and the web
PPT
Erlang Concurrency
PDF
Lightning Talk: Erlang on Xen - Mikhail Bortnyk
PPTX
The mystique of erlang
PPTX
Introduction to Couchbase Server 2.0
PPS
Erlang plus BDB: Disrupting the Conventional Web Wisdom
PDF
Erlang on OSv
PDF
Erlang Developments: The Good, The Bad and The Ugly
PPTX
Exception Handler, Controller Advice Of Spring
PDF
Erlang Practice
KEY
Intro to Erlang
PDF
learn you some erlang - chap13 to chap14
PPT
Erlang For Five Nines
ODP
An introduction to erlang
Developing web apps using Erlang-Web
Erlang web framework: Chicago boss
Caching Strategies for an Erlang Based Web Stack
learn you some erlang - chap 6 to chap7
learn you some erlang - chap0 to chap2
WebCamp: Developer Day: N2O: The Most Powerful Erlang Web Framework - Максим ...
MPI, Erlang and the web
Erlang Concurrency
Lightning Talk: Erlang on Xen - Mikhail Bortnyk
The mystique of erlang
Introduction to Couchbase Server 2.0
Erlang plus BDB: Disrupting the Conventional Web Wisdom
Erlang on OSv
Erlang Developments: The Good, The Bad and The Ugly
Exception Handler, Controller Advice Of Spring
Erlang Practice
Intro to Erlang
learn you some erlang - chap13 to chap14
Erlang For Five Nines
An introduction to erlang
Ad

Similar to Why erlang (20)

PDF
Localization Realization
PPTX
How to run a global, cloud scale event for 10000 people
PDF
ELEKS-Company-Overview
PDF
ELEKS_Company_Overview
PPTX
LVOUG news 5-OCT-2015
PDF
How children learn software testing
PPTX
on job training in banga
PDF
Scaling Uber
PDF
2022-11-08 All About career path in Salesforce Eco System_KR.pdf
PPTX
LVOUG meetup #14
PPTX
UTICamp-2020. Postgraduate Translation Study at KU Leuven, Antwerp
PPTX
OneHourTranslation - AWS Cloud Case Study
PPTX
inplant training for ece students || inplant training for engineering student...
DOC
hossam ahmed salah CV
PDF
How To Train Your Microservice
PDF
Childcare Web Application
DOC
Gülden akyıldızcv1
PDF
Java: Create The Future Keynote
PDF
Java Certification by HUJAK - 2015-05-12 - at JavaCro'15 conference
PPTX
Meetups - The Oracle Ace Way
Localization Realization
How to run a global, cloud scale event for 10000 people
ELEKS-Company-Overview
ELEKS_Company_Overview
LVOUG news 5-OCT-2015
How children learn software testing
on job training in banga
Scaling Uber
2022-11-08 All About career path in Salesforce Eco System_KR.pdf
LVOUG meetup #14
UTICamp-2020. Postgraduate Translation Study at KU Leuven, Antwerp
OneHourTranslation - AWS Cloud Case Study
inplant training for ece students || inplant training for engineering student...
hossam ahmed salah CV
How To Train Your Microservice
Childcare Web Application
Gülden akyıldızcv1
Java: Create The Future Keynote
Java Certification by HUJAK - 2015-05-12 - at JavaCro'15 conference
Meetups - The Oracle Ace Way
Ad

Recently uploaded (20)

PPTX
Funds Management Learning Material for Beg
PPTX
presentation_pfe-universite-molay-seltan.pptx
PPTX
Internet___Basics___Styled_ presentation
PDF
Sims 4 Historia para lo sims 4 para jugar
PPT
Design_with_Watersergyerge45hrbgre4top (1).ppt
PPTX
artificial intelligence overview of it and more
PDF
Paper PDF World Game (s) Great Redesign.pdf
PDF
The New Creative Director: How AI Tools for Social Media Content Creation Are...
PDF
💰 𝐔𝐊𝐓𝐈 𝐊𝐄𝐌𝐄𝐍𝐀𝐍𝐆𝐀𝐍 𝐊𝐈𝐏𝐄𝐑𝟒𝐃 𝐇𝐀𝐑𝐈 𝐈𝐍𝐈 𝟐𝟎𝟐𝟓 💰
PPTX
Introduction to Information and Communication Technology
PPTX
Module 1 - Cyber Law and Ethics 101.pptx
PPTX
INTERNET------BASICS-------UPDATED PPT PRESENTATION
PPT
Ethics in Information System - Management Information System
PDF
Best Practices for Testing and Debugging Shopify Third-Party API Integrations...
PPTX
Power Point - Lesson 3_2.pptx grad school presentation
PPTX
Job_Card_System_Styled_lorem_ipsum_.pptx
PDF
SASE Traffic Flow - ZTNA Connector-1.pdf
PDF
Tenda Login Guide: Access Your Router in 5 Easy Steps
PPTX
June-4-Sermon-Powerpoint.pptx USE THIS FOR YOUR MOTIVATION
PDF
Smart Home Technology for Health Monitoring (www.kiu.ac.ug)
Funds Management Learning Material for Beg
presentation_pfe-universite-molay-seltan.pptx
Internet___Basics___Styled_ presentation
Sims 4 Historia para lo sims 4 para jugar
Design_with_Watersergyerge45hrbgre4top (1).ppt
artificial intelligence overview of it and more
Paper PDF World Game (s) Great Redesign.pdf
The New Creative Director: How AI Tools for Social Media Content Creation Are...
💰 𝐔𝐊𝐓𝐈 𝐊𝐄𝐌𝐄𝐍𝐀𝐍𝐆𝐀𝐍 𝐊𝐈𝐏𝐄𝐑𝟒𝐃 𝐇𝐀𝐑𝐈 𝐈𝐍𝐈 𝟐𝟎𝟐𝟓 💰
Introduction to Information and Communication Technology
Module 1 - Cyber Law and Ethics 101.pptx
INTERNET------BASICS-------UPDATED PPT PRESENTATION
Ethics in Information System - Management Information System
Best Practices for Testing and Debugging Shopify Third-Party API Integrations...
Power Point - Lesson 3_2.pptx grad school presentation
Job_Card_System_Styled_lorem_ipsum_.pptx
SASE Traffic Flow - ZTNA Connector-1.pdf
Tenda Login Guide: Access Your Router in 5 Easy Steps
June-4-Sermon-Powerpoint.pptx USE THIS FOR YOUR MOTIVATION
Smart Home Technology for Health Monitoring (www.kiu.ac.ug)

Why erlang