SlideShare uma empresa Scribd logo
1 de 43
Baixar para ler offline
Xen and the Art of
Rails Deployment
Who am I?

• Ezra Zygmuntowicz
• Rubyist for 4 years
• Engine Yard Founder and Architect
• Blog: http://brainspl.at
Deploying Rails

• Details have changed rapidly over the years
• Many different webservers have come and
  gone
• Basics remain the same
Full Stack Request/Response Life-Cycle


•   Request comes into gateway
    server


•   Rewrite rules are evaluated and
    request gets served directly if it’s
    a static asset


•   Dynamic requests are proxied to
    one Mongrel in the Mongrel
    Cluster


•   Mongrel dispatches request
    through Rails and returns
    response to client
History Lesson
 •   CGI

 •   Apache1.3.x/mod_fastcgi

 •   Lighttpd/fcgi

 •   Apache2.x/mod_fcgid

 •   Lighttpd/SCGI

 •   Lightspeed
Enough Already




X
  •   CGI

  •   Apache1.3.x/mod_fastcgi

  •   Lighttpd/fcgi

  •   Apache2.x/mod_fcgid

  •   Lighttpd/SCGI

  •   Lightspeed
Enter Mongrel

The year of the Dog
What is Mongrel?
Mongrel is an HTTP Server
 Library written by Zed Shaw

• Fast HTTP Parser written in Ragel + C
• Fast URI Classifier written in C
• Stackable Request Handlers
• Flexible Configuration
• Secure and RFC Compliant HTTP Parser
Ragel State Machine
Defined HTTP Parser
Why is Mongrel better?

• HTTP is a well known and well tooled
  protocol
• Mongrel is way easier to setup and use
• Transparent wire protocol
But Rails isn’t Thread Safe!

• Giant Mutex Lock around Rails Dispatch
• Only one request served at a time by one
  mongrel
• Use mongrel_cluster to scale with multiple
  processes
Rails Internal Request/Response Life-Cycle
•   Mongrel Locks Mutex

•   Rails Dispatcher is invoked with
    request/response objects

•   Routing is invoked and returns
    the proper Controller object or
    404 if no route found

•   Filter chain is invoked

•   Controller’s Action is called,
    manipulates Models

•   View is rendered and any after
    filters are called

•   Mongrel Unlocks Mutex

•   Final response or error page
    returned to client
New dog seeking old
          tricks
•   Wide array of options for HTTP tools to front mongrel
    clusters

•   Pen, Pound, Balance, Haproxy ( No static file serving, just
    proxies)

•   Lightspeed can serve static files and proxy to mongrel

•   Apache2.2.x/mod_proxy_balancer can do the same
On the prowl for the
       perfect stack
•   Pen(no ssl support, no connection rate limiting)

•   Pound(Falls down under high load, no connection rate limiting)

•   Haproxy(supports conn rate limits, very high perf, no static files
    so more moving parts in a full stack)

•   Lightspeed(free version is crippled)

•   Apache2.2.x(Does work but.. bloat, bloat, bloat...)
Nginx:
From Russia, with Love
•   Seriously bent on performance

•   Super small resource footprint

•   Stands up under the heaviest loads without leaking memory

•   Killer rewrite and proxy modules

•   Approachable author and growing community
Nginx + Mongrel
•   This is *the* stack to be on

•   Only keep apache around for mod_dav_svn

•   Flexible nginx.conf syntax allows for serving static files and
    rails caches and proxying dynamic requests to mongrel

•   Fast, fast, fast

•   Did I say it’s fast yet?
A few gotchas


•   Nginx buffers file uploads, so no mongrel_upload_progress. This
    will be addressed soon

•   No connection rate limiting for proxy module yet, this too shall
    pass
A bright future for nginx

•   mod_rewrite is going away

•   To be replaced with http_script_module

•   This will embed the NekoVM(http://nekovm.org/) directly in
    nginx so customizing behavior for rewriting and proxying will
    become infinitley flexible
Perfect Simple Stack

    •   Linux

    •   Nginx

    •   Mongrel(mongrel_cluster)

    •   Monit
Swiftiply:
Teaching the Dog new tricks
      http://swiftiply.swiftcore.org
Swiftiply: Evented Mongrel
 •   Hot patch to Mongrel

 •   Removes Ruby’s Thread’s and Socket handling from Mongrel
     Core

 •   Replace with EventMachine event loop

 •   Mongrel becomes Single threaded, event driven

 •   Noticable Speed and IO throughtput increase

 •   Stands up much better under higher concurrent load without
     starting to slow down or leak memory
But how does a single threaded
event driven mongrel outperform
    a multithreaded mongrel?
•   Ruby’s green threads have a lot of overhead in context switching
    and have to copy a lot of state context for each thread

•   Mutual exclusion locks are expensive

•   One process can only do so much IO

•   Event driven means running in a tight loop and firing callbacks in
    response to network ‘events’

•   Since there is no context switching between threads, a single
    process has less overhead to deal with which allows for higher
    throughput and faster networking IO
Mongrel VS Evented Mongrel
       in a Hello World dogfight
  Mongrel:
1 concurrent
    user


   Evented
  Mongrel:
1 concurrent
     user
Mongrel:
100 concurrent
     users




Evented Mongrel:
 100 concurrent
      users
Swiftiply Proxy

•   Event driven proxy, small memory footprint(7-10Mb)

•   Faster then Haproxy

•   Did I mention Fast?
How it differs from a
               normal proxy
Standard proxy must know about the        With swiftiply, the backends connect to the proxy. So
ports of all backends. Usually requires   all mongrels get started on the same port and then
    restart to add more backends            they open a persistent connection to the proxy
This means you can start and stop as many
        mongrels as you want and they get auto
               configured in the proxy!




This opens the door for scaling the number of mongrels
 automatically in response to increased load on the fly!
The Zen of Xen
Monolithic Linux VS
      Modularized Linux
•   Old way of thinking is dedicated boxes running all services in
    one big hodgepodge on one kernel

•   New school is sharply targeted virtualized linux with each VM
    running a single tier or service
We all strive for code
    modularization right?
•   Why not do the same thing with our servers?

•   Each VM runs one or two related services

•   Simplifies deployment and scaling

•   Even if you only have one box you absolutely should run
    Xen on it from the start
Old VS New
What happens when you need to
 scale to more then one box?
Old School
•   Get another box and move mysql on there

•   Get another box to run some of the other services

•   Lots of setup required, downtime to migrate

•   Complex Linux installs with many services running are harder
    to debug when performance problems happen

•   This *can* scale but is way less flexible
New School
•   Add another box with Xen installed

•   Pick a few services that need more resources and migrate
    them *live* to the other machine

•   Each VM runs one thing and runs it well

•   Easy to target performance problems

•   Scales much better
Advanced Clustering
•   Virtualized compute nodes that boot Xen dom0 off of USB
    thumb drives

•   SAN storage for all Xen domU(VPS’s)

•   Red Hat Clustering Suite for fencing and cluster quorems

•   GFS for 100% posix compliant clustered filesystem(no shitty
    NFS)

•   Hardware load balancers or dedicated boxes running Ultra
    Monkey or just straight LVS
Fabric of Compute and
        Storage
•   When a compute node fails just swap it out for a new one and
    plug in the thumbdrive and you’re back in business

•   Move hot VM’s to less loaded nodes easily as they are not tied
    to a single machine

•   Deploy your app code to one node and then bounce the
    mongrels on all nodes with a clustered filesystem like GFS

•   Fragment and page caching consistency across all nodes
    instantly

•   Scale from one or 2 VM’s to as many as traffic requires *and*
    back down again once traffic subsides.
RAM RAM RAM

•   Most Rails apps are RAM bound way before they are CPU
    bound

•   Average mongrel size on 64bit EngineYard is 70-120Mb *per*
    mongrel. Slightly less on 32 bit systems

•   Rmagick and :include the worst culprits

•   95% of Rails apps will leak memory at one point or another
Rails eats Database
resources for breakfast
•   Majority of app in the wild have *no* indexes in their
    databases

•   Learn when and where to apply indexes, it will save your
    ass

•   ActiveRecord insulates developers from SQL to the point
    of massive ineficiencies. Look at your logs and see what
    SQL is being generated. Do not fear the SQL and don’t
    think you can get away without some denormalization and
    custom SQL if you plan on your app having a chance of
    scaling
Other tips & tricks
•   *Don’t* use filesystem sessions, AR or SQLSession or
    memcached if you don’t need persistance

•   script/runner is massively ineficient. Try as hard as possible
    to not load all of rails in your background processes. Use
    the raw Mysql library and plain ruby if you can and your
    servers will thank you for it

•   *Do not* use script runner to process incoming email.
    Run a daemon in a loop and poll a mail server with net/
    pop2 or net/imap. Forking a whole rails process for each
    incoming email will never work in a production
    environment period
Rails is great for the
           80/20 rule
•   But you are on your own when you need the last 20%

•   Learn how to write custom mongrel handlers for perf critical
    sections of your app

•   When is optimization not premature?

•   Ruby is plenty fast, it’s rails that tends to be on the slow side

•   Cache, cache, cache. It doesnt get much faster then service
    cached static html files
Parting Thought

•   Don’t take what I or anyone else says about this stuff as
    gospel

•   Test it and benchmark it for yourself to be sure

•   Trust but verify and you will stay in good shape
Questions?

Mais conteúdo relacionado

Mais procurados

Beyond Apache: Faster Web Servers
Beyond Apache: Faster Web ServersBeyond Apache: Faster Web Servers
Beyond Apache: Faster Web Serverswebhostingguy
 
Reactor, Reactive streams and MicroServices
Reactor, Reactive streams and MicroServicesReactor, Reactive streams and MicroServices
Reactor, Reactive streams and MicroServicesStéphane Maldini
 
Scaling a MeteorJS SaaS app on AWS
Scaling a MeteorJS SaaS app on AWSScaling a MeteorJS SaaS app on AWS
Scaling a MeteorJS SaaS app on AWSBrett McLain
 
Building a smarter application Stack by Tomas Doran from Yelp
Building a smarter application Stack by Tomas Doran from YelpBuilding a smarter application Stack by Tomas Doran from Yelp
Building a smarter application Stack by Tomas Doran from YelpdotCloud
 
High-speed, Reactive Microservices 2017
High-speed, Reactive Microservices 2017High-speed, Reactive Microservices 2017
High-speed, Reactive Microservices 2017Rick Hightower
 
Introduction to Systems Management with SaltStack
Introduction to Systems Management with SaltStackIntroduction to Systems Management with SaltStack
Introduction to Systems Management with SaltStackCraig Sebenik
 
Data Models and Consumer Idioms Using Apache Kafka for Continuous Data Stream...
Data Models and Consumer Idioms Using Apache Kafka for Continuous Data Stream...Data Models and Consumer Idioms Using Apache Kafka for Continuous Data Stream...
Data Models and Consumer Idioms Using Apache Kafka for Continuous Data Stream...Erik Onnen
 
Reactive Micro Services with Java seminar
Reactive Micro Services with Java seminarReactive Micro Services with Java seminar
Reactive Micro Services with Java seminarGal Marder
 
Kafka 0.8.0 Presentation to Atlanta Java User's Group March 2013
Kafka 0.8.0 Presentation to Atlanta Java User's Group March 2013Kafka 0.8.0 Presentation to Atlanta Java User's Group March 2013
Kafka 0.8.0 Presentation to Atlanta Java User's Group March 2013Christopher Curtin
 
Caching 101: Caching on the JVM (and beyond)
Caching 101: Caching on the JVM (and beyond)Caching 101: Caching on the JVM (and beyond)
Caching 101: Caching on the JVM (and beyond)Louis Jacomet
 
Go Reactive: Event-Driven, Scalable, Resilient & Responsive Systems
Go Reactive: Event-Driven, Scalable, Resilient & Responsive SystemsGo Reactive: Event-Driven, Scalable, Resilient & Responsive Systems
Go Reactive: Event-Driven, Scalable, Resilient & Responsive SystemsJonas Bonér
 
NATS - A new nervous system for distributed cloud platforms
NATS - A new nervous system for distributed cloud platformsNATS - A new nervous system for distributed cloud platforms
NATS - A new nervous system for distributed cloud platformsDerek Collison
 
Developing with the Go client for Apache Kafka
Developing with the Go client for Apache KafkaDeveloping with the Go client for Apache Kafka
Developing with the Go client for Apache KafkaJoe Stein
 
High Performance Systems in Go - GopherCon 2014
High Performance Systems in Go - GopherCon 2014High Performance Systems in Go - GopherCon 2014
High Performance Systems in Go - GopherCon 2014Derek Collison
 
Event Driven Architecture with Apache Camel
Event Driven Architecture with Apache CamelEvent Driven Architecture with Apache Camel
Event Driven Architecture with Apache Camelprajods
 

Mais procurados (15)

Beyond Apache: Faster Web Servers
Beyond Apache: Faster Web ServersBeyond Apache: Faster Web Servers
Beyond Apache: Faster Web Servers
 
Reactor, Reactive streams and MicroServices
Reactor, Reactive streams and MicroServicesReactor, Reactive streams and MicroServices
Reactor, Reactive streams and MicroServices
 
Scaling a MeteorJS SaaS app on AWS
Scaling a MeteorJS SaaS app on AWSScaling a MeteorJS SaaS app on AWS
Scaling a MeteorJS SaaS app on AWS
 
Building a smarter application Stack by Tomas Doran from Yelp
Building a smarter application Stack by Tomas Doran from YelpBuilding a smarter application Stack by Tomas Doran from Yelp
Building a smarter application Stack by Tomas Doran from Yelp
 
High-speed, Reactive Microservices 2017
High-speed, Reactive Microservices 2017High-speed, Reactive Microservices 2017
High-speed, Reactive Microservices 2017
 
Introduction to Systems Management with SaltStack
Introduction to Systems Management with SaltStackIntroduction to Systems Management with SaltStack
Introduction to Systems Management with SaltStack
 
Data Models and Consumer Idioms Using Apache Kafka for Continuous Data Stream...
Data Models and Consumer Idioms Using Apache Kafka for Continuous Data Stream...Data Models and Consumer Idioms Using Apache Kafka for Continuous Data Stream...
Data Models and Consumer Idioms Using Apache Kafka for Continuous Data Stream...
 
Reactive Micro Services with Java seminar
Reactive Micro Services with Java seminarReactive Micro Services with Java seminar
Reactive Micro Services with Java seminar
 
Kafka 0.8.0 Presentation to Atlanta Java User's Group March 2013
Kafka 0.8.0 Presentation to Atlanta Java User's Group March 2013Kafka 0.8.0 Presentation to Atlanta Java User's Group March 2013
Kafka 0.8.0 Presentation to Atlanta Java User's Group March 2013
 
Caching 101: Caching on the JVM (and beyond)
Caching 101: Caching on the JVM (and beyond)Caching 101: Caching on the JVM (and beyond)
Caching 101: Caching on the JVM (and beyond)
 
Go Reactive: Event-Driven, Scalable, Resilient & Responsive Systems
Go Reactive: Event-Driven, Scalable, Resilient & Responsive SystemsGo Reactive: Event-Driven, Scalable, Resilient & Responsive Systems
Go Reactive: Event-Driven, Scalable, Resilient & Responsive Systems
 
NATS - A new nervous system for distributed cloud platforms
NATS - A new nervous system for distributed cloud platformsNATS - A new nervous system for distributed cloud platforms
NATS - A new nervous system for distributed cloud platforms
 
Developing with the Go client for Apache Kafka
Developing with the Go client for Apache KafkaDeveloping with the Go client for Apache Kafka
Developing with the Go client for Apache Kafka
 
High Performance Systems in Go - GopherCon 2014
High Performance Systems in Go - GopherCon 2014High Performance Systems in Go - GopherCon 2014
High Performance Systems in Go - GopherCon 2014
 
Event Driven Architecture with Apache Camel
Event Driven Architecture with Apache CamelEvent Driven Architecture with Apache Camel
Event Driven Architecture with Apache Camel
 

Destaque

Subsides Entreprises Bruxelles
Subsides Entreprises BruxellesSubsides Entreprises Bruxelles
Subsides Entreprises Bruxellesecobuild.brussels
 
Abe panorama de l'économie bruxelloise 2012
Abe panorama de l'économie bruxelloise 2012Abe panorama de l'économie bruxelloise 2012
Abe panorama de l'économie bruxelloise 2012ecobuild.brussels
 
Sentri slides
Sentri slidesSentri slides
Sentri slidesSentri
 
Abe obtention du financement de l'entreprise
Abe obtention du financement de l'entrepriseAbe obtention du financement de l'entreprise
Abe obtention du financement de l'entrepriseecobuild.brussels
 
Master Banking Web
Master Banking WebMaster Banking Web
Master Banking WebIlaria Rega
 
Microsoft cloud-services-architecture-1226619291360503-8
Microsoft cloud-services-architecture-1226619291360503-8Microsoft cloud-services-architecture-1226619291360503-8
Microsoft cloud-services-architecture-1226619291360503-8LLC NewLink
 
Abe comment obtenir un financement pour votre projet
Abe comment obtenir un financement pour votre projetAbe comment obtenir un financement pour votre projet
Abe comment obtenir un financement pour votre projetecobuild.brussels
 

Destaque (8)

Subsides Entreprises Bruxelles
Subsides Entreprises BruxellesSubsides Entreprises Bruxelles
Subsides Entreprises Bruxelles
 
Abe panorama de l'économie bruxelloise 2012
Abe panorama de l'économie bruxelloise 2012Abe panorama de l'économie bruxelloise 2012
Abe panorama de l'économie bruxelloise 2012
 
Sentri slides
Sentri slidesSentri slides
Sentri slides
 
Abe obtention du financement de l'entreprise
Abe obtention du financement de l'entrepriseAbe obtention du financement de l'entreprise
Abe obtention du financement de l'entreprise
 
Master Banking Web
Master Banking WebMaster Banking Web
Master Banking Web
 
Microsoft cloud-services-architecture-1226619291360503-8
Microsoft cloud-services-architecture-1226619291360503-8Microsoft cloud-services-architecture-1226619291360503-8
Microsoft cloud-services-architecture-1226619291360503-8
 
7982 overview
7982 overview7982 overview
7982 overview
 
Abe comment obtenir un financement pour votre projet
Abe comment obtenir un financement pour votre projetAbe comment obtenir un financement pour votre projet
Abe comment obtenir un financement pour votre projet
 

Semelhante a Xen and-the-art-of-rails-deployment2640

Real time system_performance_mon
Real time system_performance_monReal time system_performance_mon
Real time system_performance_monTomas Doran
 
Midwest PHP - Scaling Magento
Midwest PHP - Scaling MagentoMidwest PHP - Scaling Magento
Midwest PHP - Scaling MagentoMathew Beane
 
Full stack development using javascript what and why - ajay chandravadiya
Full stack development using javascript   what and why - ajay chandravadiyaFull stack development using javascript   what and why - ajay chandravadiya
Full stack development using javascript what and why - ajay chandravadiyaajayrcgmail
 
Messaging, interoperability and log aggregation - a new framework
Messaging, interoperability and log aggregation - a new frameworkMessaging, interoperability and log aggregation - a new framework
Messaging, interoperability and log aggregation - a new frameworkTomas Doran
 
FreeSWITCH as a Microservice
FreeSWITCH as a MicroserviceFreeSWITCH as a Microservice
FreeSWITCH as a MicroserviceEvan McGee
 
John adams talk cloudy
John adams   talk cloudyJohn adams   talk cloudy
John adams talk cloudyJohn Adams
 
Micro Services Architecture
Micro Services ArchitectureMicro Services Architecture
Micro Services ArchitectureRanjan Baisak
 
High Performance Drupal
High Performance DrupalHigh Performance Drupal
High Performance DrupalChapter Three
 
Cooking a rabbit pie
Cooking a rabbit pieCooking a rabbit pie
Cooking a rabbit pieTomas Doran
 
Realtime traffic analyser
Realtime traffic analyserRealtime traffic analyser
Realtime traffic analyserAlex Moskvin
 
MySQL Options in OpenStack
MySQL Options in OpenStackMySQL Options in OpenStack
MySQL Options in OpenStackTesora
 
Machine Learning With H2O vs SparkML
Machine Learning With H2O vs SparkMLMachine Learning With H2O vs SparkML
Machine Learning With H2O vs SparkMLArnab Biswas
 
OpenStack Days East -- MySQL Options in OpenStack
OpenStack Days East -- MySQL Options in OpenStackOpenStack Days East -- MySQL Options in OpenStack
OpenStack Days East -- MySQL Options in OpenStackMatt Lord
 
Sanger, upcoming Openstack for Bio-informaticians
Sanger, upcoming Openstack for Bio-informaticiansSanger, upcoming Openstack for Bio-informaticians
Sanger, upcoming Openstack for Bio-informaticiansPeter Clapham
 
Select Stars: A DBA's Guide to Azure Cosmos DB (SQL Saturday Oslo 2018)
Select Stars: A DBA's Guide to Azure Cosmos DB (SQL Saturday Oslo 2018)Select Stars: A DBA's Guide to Azure Cosmos DB (SQL Saturday Oslo 2018)
Select Stars: A DBA's Guide to Azure Cosmos DB (SQL Saturday Oslo 2018)Bob Pusateri
 
Eventual Consistency @WalmartLabs with Kafka, Avro, SolrCloud and Hadoop
Eventual Consistency @WalmartLabs with Kafka, Avro, SolrCloud and HadoopEventual Consistency @WalmartLabs with Kafka, Avro, SolrCloud and Hadoop
Eventual Consistency @WalmartLabs with Kafka, Avro, SolrCloud and HadoopAyon Sinha
 
DrupalCampLA 2014 - Drupal backend performance and scalability
DrupalCampLA 2014 - Drupal backend performance and scalabilityDrupalCampLA 2014 - Drupal backend performance and scalability
DrupalCampLA 2014 - Drupal backend performance and scalabilitycherryhillco
 
12-Step Program for Scaling Web Applications on PostgreSQL
12-Step Program for Scaling Web Applications on PostgreSQL12-Step Program for Scaling Web Applications on PostgreSQL
12-Step Program for Scaling Web Applications on PostgreSQLKonstantin Gredeskoul
 

Semelhante a Xen and-the-art-of-rails-deployment2640 (20)

webservers
webserverswebservers
webservers
 
Real time system_performance_mon
Real time system_performance_monReal time system_performance_mon
Real time system_performance_mon
 
Midwest PHP - Scaling Magento
Midwest PHP - Scaling MagentoMidwest PHP - Scaling Magento
Midwest PHP - Scaling Magento
 
Full stack development using javascript what and why - ajay chandravadiya
Full stack development using javascript   what and why - ajay chandravadiyaFull stack development using javascript   what and why - ajay chandravadiya
Full stack development using javascript what and why - ajay chandravadiya
 
Messaging, interoperability and log aggregation - a new framework
Messaging, interoperability and log aggregation - a new frameworkMessaging, interoperability and log aggregation - a new framework
Messaging, interoperability and log aggregation - a new framework
 
FreeSWITCH as a Microservice
FreeSWITCH as a MicroserviceFreeSWITCH as a Microservice
FreeSWITCH as a Microservice
 
John adams talk cloudy
John adams   talk cloudyJohn adams   talk cloudy
John adams talk cloudy
 
Micro Services Architecture
Micro Services ArchitectureMicro Services Architecture
Micro Services Architecture
 
High Performance Drupal
High Performance DrupalHigh Performance Drupal
High Performance Drupal
 
Cooking a rabbit pie
Cooking a rabbit pieCooking a rabbit pie
Cooking a rabbit pie
 
Realtime traffic analyser
Realtime traffic analyserRealtime traffic analyser
Realtime traffic analyser
 
MySQL Options in OpenStack
MySQL Options in OpenStackMySQL Options in OpenStack
MySQL Options in OpenStack
 
Machine Learning With H2O vs SparkML
Machine Learning With H2O vs SparkMLMachine Learning With H2O vs SparkML
Machine Learning With H2O vs SparkML
 
OpenStack Days East -- MySQL Options in OpenStack
OpenStack Days East -- MySQL Options in OpenStackOpenStack Days East -- MySQL Options in OpenStack
OpenStack Days East -- MySQL Options in OpenStack
 
Sanger, upcoming Openstack for Bio-informaticians
Sanger, upcoming Openstack for Bio-informaticiansSanger, upcoming Openstack for Bio-informaticians
Sanger, upcoming Openstack for Bio-informaticians
 
Flexible compute
Flexible computeFlexible compute
Flexible compute
 
Select Stars: A DBA's Guide to Azure Cosmos DB (SQL Saturday Oslo 2018)
Select Stars: A DBA's Guide to Azure Cosmos DB (SQL Saturday Oslo 2018)Select Stars: A DBA's Guide to Azure Cosmos DB (SQL Saturday Oslo 2018)
Select Stars: A DBA's Guide to Azure Cosmos DB (SQL Saturday Oslo 2018)
 
Eventual Consistency @WalmartLabs with Kafka, Avro, SolrCloud and Hadoop
Eventual Consistency @WalmartLabs with Kafka, Avro, SolrCloud and HadoopEventual Consistency @WalmartLabs with Kafka, Avro, SolrCloud and Hadoop
Eventual Consistency @WalmartLabs with Kafka, Avro, SolrCloud and Hadoop
 
DrupalCampLA 2014 - Drupal backend performance and scalability
DrupalCampLA 2014 - Drupal backend performance and scalabilityDrupalCampLA 2014 - Drupal backend performance and scalability
DrupalCampLA 2014 - Drupal backend performance and scalability
 
12-Step Program for Scaling Web Applications on PostgreSQL
12-Step Program for Scaling Web Applications on PostgreSQL12-Step Program for Scaling Web Applications on PostgreSQL
12-Step Program for Scaling Web Applications on PostgreSQL
 

Mais de LLC NewLink

Content Delivery Network
Content Delivery NetworkContent Delivery Network
Content Delivery NetworkLLC NewLink
 
Video 111127013709-phpapp02
Video 111127013709-phpapp02Video 111127013709-phpapp02
Video 111127013709-phpapp02LLC NewLink
 
Cloud computing-1224001671523233-9
Cloud computing-1224001671523233-9Cloud computing-1224001671523233-9
Cloud computing-1224001671523233-9LLC NewLink
 
Carrier ethernet-services-the-future-public-multivendor1976
Carrier ethernet-services-the-future-public-multivendor1976Carrier ethernet-services-the-future-public-multivendor1976
Carrier ethernet-services-the-future-public-multivendor1976LLC NewLink
 
Asterisk presence-im-091015103222-phpapp02
Asterisk presence-im-091015103222-phpapp02Asterisk presence-im-091015103222-phpapp02
Asterisk presence-im-091015103222-phpapp02LLC NewLink
 
Apc 091016024613-phpapp01
Apc 091016024613-phpapp01Apc 091016024613-phpapp01
Apc 091016024613-phpapp01LLC NewLink
 
Amazonwhitepaper 110511144038-phpapp01
Amazonwhitepaper 110511144038-phpapp01Amazonwhitepaper 110511144038-phpapp01
Amazonwhitepaper 110511144038-phpapp01LLC NewLink
 
2011 06-29- sp-seminar- cisco cdn solution-1
2011 06-29- sp-seminar- cisco cdn solution-12011 06-29- sp-seminar- cisco cdn solution-1
2011 06-29- sp-seminar- cisco cdn solution-1LLC NewLink
 

Mais de LLC NewLink (11)

Cristmas
CristmasCristmas
Cristmas
 
Newlink
NewlinkNewlink
Newlink
 
Content Delivery Network
Content Delivery NetworkContent Delivery Network
Content Delivery Network
 
Video 111127013709-phpapp02
Video 111127013709-phpapp02Video 111127013709-phpapp02
Video 111127013709-phpapp02
 
Cloud computing-1224001671523233-9
Cloud computing-1224001671523233-9Cloud computing-1224001671523233-9
Cloud computing-1224001671523233-9
 
Carrier ethernet-services-the-future-public-multivendor1976
Carrier ethernet-services-the-future-public-multivendor1976Carrier ethernet-services-the-future-public-multivendor1976
Carrier ethernet-services-the-future-public-multivendor1976
 
Asterisk presence-im-091015103222-phpapp02
Asterisk presence-im-091015103222-phpapp02Asterisk presence-im-091015103222-phpapp02
Asterisk presence-im-091015103222-phpapp02
 
Apc 091016024613-phpapp01
Apc 091016024613-phpapp01Apc 091016024613-phpapp01
Apc 091016024613-phpapp01
 
Amazonwhitepaper 110511144038-phpapp01
Amazonwhitepaper 110511144038-phpapp01Amazonwhitepaper 110511144038-phpapp01
Amazonwhitepaper 110511144038-phpapp01
 
2011 06-29- sp-seminar- cisco cdn solution-1
2011 06-29- sp-seminar- cisco cdn solution-12011 06-29- sp-seminar- cisco cdn solution-1
2011 06-29- sp-seminar- cisco cdn solution-1
 
Newlink
Newlink Newlink
Newlink
 

Último

Handwritten Text Recognition for manuscripts and early printed texts
Handwritten Text Recognition for manuscripts and early printed textsHandwritten Text Recognition for manuscripts and early printed texts
Handwritten Text Recognition for manuscripts and early printed textsMaria Levchenko
 
Kotlin Multiplatform & Compose Multiplatform - Starter kit for pragmatics
Kotlin Multiplatform & Compose Multiplatform - Starter kit for pragmaticsKotlin Multiplatform & Compose Multiplatform - Starter kit for pragmatics
Kotlin Multiplatform & Compose Multiplatform - Starter kit for pragmaticscarlostorres15106
 
Presentation on how to chat with PDF using ChatGPT code interpreter
Presentation on how to chat with PDF using ChatGPT code interpreterPresentation on how to chat with PDF using ChatGPT code interpreter
Presentation on how to chat with PDF using ChatGPT code interpreternaman860154
 
The 7 Things I Know About Cyber Security After 25 Years | April 2024
The 7 Things I Know About Cyber Security After 25 Years | April 2024The 7 Things I Know About Cyber Security After 25 Years | April 2024
The 7 Things I Know About Cyber Security After 25 Years | April 2024Rafal Los
 
Benefits Of Flutter Compared To Other Frameworks
Benefits Of Flutter Compared To Other FrameworksBenefits Of Flutter Compared To Other Frameworks
Benefits Of Flutter Compared To Other FrameworksSoftradix Technologies
 
Pigging Solutions in Pet Food Manufacturing
Pigging Solutions in Pet Food ManufacturingPigging Solutions in Pet Food Manufacturing
Pigging Solutions in Pet Food ManufacturingPigging Solutions
 
My Hashitalk Indonesia April 2024 Presentation
My Hashitalk Indonesia April 2024 PresentationMy Hashitalk Indonesia April 2024 Presentation
My Hashitalk Indonesia April 2024 PresentationRidwan Fadjar
 
SIEMENS: RAPUNZEL – A Tale About Knowledge Graph
SIEMENS: RAPUNZEL – A Tale About Knowledge GraphSIEMENS: RAPUNZEL – A Tale About Knowledge Graph
SIEMENS: RAPUNZEL – A Tale About Knowledge GraphNeo4j
 
Azure Monitor & Application Insight to monitor Infrastructure & Application
Azure Monitor & Application Insight to monitor Infrastructure & ApplicationAzure Monitor & Application Insight to monitor Infrastructure & Application
Azure Monitor & Application Insight to monitor Infrastructure & ApplicationAndikSusilo4
 
Automating Business Process via MuleSoft Composer | Bangalore MuleSoft Meetup...
Automating Business Process via MuleSoft Composer | Bangalore MuleSoft Meetup...Automating Business Process via MuleSoft Composer | Bangalore MuleSoft Meetup...
Automating Business Process via MuleSoft Composer | Bangalore MuleSoft Meetup...shyamraj55
 
[2024]Digital Global Overview Report 2024 Meltwater.pdf
[2024]Digital Global Overview Report 2024 Meltwater.pdf[2024]Digital Global Overview Report 2024 Meltwater.pdf
[2024]Digital Global Overview Report 2024 Meltwater.pdfhans926745
 
Key Features Of Token Development (1).pptx
Key  Features Of Token  Development (1).pptxKey  Features Of Token  Development (1).pptx
Key Features Of Token Development (1).pptxLBM Solutions
 
A Domino Admins Adventures (Engage 2024)
A Domino Admins Adventures (Engage 2024)A Domino Admins Adventures (Engage 2024)
A Domino Admins Adventures (Engage 2024)Gabriella Davis
 
Understanding the Laravel MVC Architecture
Understanding the Laravel MVC ArchitectureUnderstanding the Laravel MVC Architecture
Understanding the Laravel MVC ArchitecturePixlogix Infotech
 
FULL ENJOY 🔝 8264348440 🔝 Call Girls in Diplomatic Enclave | Delhi
FULL ENJOY 🔝 8264348440 🔝 Call Girls in Diplomatic Enclave | DelhiFULL ENJOY 🔝 8264348440 🔝 Call Girls in Diplomatic Enclave | Delhi
FULL ENJOY 🔝 8264348440 🔝 Call Girls in Diplomatic Enclave | Delhisoniya singh
 
Transforming Data Streams with Kafka Connect: An Introduction to Single Messa...
Transforming Data Streams with Kafka Connect: An Introduction to Single Messa...Transforming Data Streams with Kafka Connect: An Introduction to Single Messa...
Transforming Data Streams with Kafka Connect: An Introduction to Single Messa...HostedbyConfluent
 
Factors to Consider When Choosing Accounts Payable Services Providers.pptx
Factors to Consider When Choosing Accounts Payable Services Providers.pptxFactors to Consider When Choosing Accounts Payable Services Providers.pptx
Factors to Consider When Choosing Accounts Payable Services Providers.pptxKatpro Technologies
 
Enhancing Worker Digital Experience: A Hands-on Workshop for Partners
Enhancing Worker Digital Experience: A Hands-on Workshop for PartnersEnhancing Worker Digital Experience: A Hands-on Workshop for Partners
Enhancing Worker Digital Experience: A Hands-on Workshop for PartnersThousandEyes
 
Install Stable Diffusion in windows machine
Install Stable Diffusion in windows machineInstall Stable Diffusion in windows machine
Install Stable Diffusion in windows machinePadma Pradeep
 
From Event to Action: Accelerate Your Decision Making with Real-Time Automation
From Event to Action: Accelerate Your Decision Making with Real-Time AutomationFrom Event to Action: Accelerate Your Decision Making with Real-Time Automation
From Event to Action: Accelerate Your Decision Making with Real-Time AutomationSafe Software
 

Último (20)

Handwritten Text Recognition for manuscripts and early printed texts
Handwritten Text Recognition for manuscripts and early printed textsHandwritten Text Recognition for manuscripts and early printed texts
Handwritten Text Recognition for manuscripts and early printed texts
 
Kotlin Multiplatform & Compose Multiplatform - Starter kit for pragmatics
Kotlin Multiplatform & Compose Multiplatform - Starter kit for pragmaticsKotlin Multiplatform & Compose Multiplatform - Starter kit for pragmatics
Kotlin Multiplatform & Compose Multiplatform - Starter kit for pragmatics
 
Presentation on how to chat with PDF using ChatGPT code interpreter
Presentation on how to chat with PDF using ChatGPT code interpreterPresentation on how to chat with PDF using ChatGPT code interpreter
Presentation on how to chat with PDF using ChatGPT code interpreter
 
The 7 Things I Know About Cyber Security After 25 Years | April 2024
The 7 Things I Know About Cyber Security After 25 Years | April 2024The 7 Things I Know About Cyber Security After 25 Years | April 2024
The 7 Things I Know About Cyber Security After 25 Years | April 2024
 
Benefits Of Flutter Compared To Other Frameworks
Benefits Of Flutter Compared To Other FrameworksBenefits Of Flutter Compared To Other Frameworks
Benefits Of Flutter Compared To Other Frameworks
 
Pigging Solutions in Pet Food Manufacturing
Pigging Solutions in Pet Food ManufacturingPigging Solutions in Pet Food Manufacturing
Pigging Solutions in Pet Food Manufacturing
 
My Hashitalk Indonesia April 2024 Presentation
My Hashitalk Indonesia April 2024 PresentationMy Hashitalk Indonesia April 2024 Presentation
My Hashitalk Indonesia April 2024 Presentation
 
SIEMENS: RAPUNZEL – A Tale About Knowledge Graph
SIEMENS: RAPUNZEL – A Tale About Knowledge GraphSIEMENS: RAPUNZEL – A Tale About Knowledge Graph
SIEMENS: RAPUNZEL – A Tale About Knowledge Graph
 
Azure Monitor & Application Insight to monitor Infrastructure & Application
Azure Monitor & Application Insight to monitor Infrastructure & ApplicationAzure Monitor & Application Insight to monitor Infrastructure & Application
Azure Monitor & Application Insight to monitor Infrastructure & Application
 
Automating Business Process via MuleSoft Composer | Bangalore MuleSoft Meetup...
Automating Business Process via MuleSoft Composer | Bangalore MuleSoft Meetup...Automating Business Process via MuleSoft Composer | Bangalore MuleSoft Meetup...
Automating Business Process via MuleSoft Composer | Bangalore MuleSoft Meetup...
 
[2024]Digital Global Overview Report 2024 Meltwater.pdf
[2024]Digital Global Overview Report 2024 Meltwater.pdf[2024]Digital Global Overview Report 2024 Meltwater.pdf
[2024]Digital Global Overview Report 2024 Meltwater.pdf
 
Key Features Of Token Development (1).pptx
Key  Features Of Token  Development (1).pptxKey  Features Of Token  Development (1).pptx
Key Features Of Token Development (1).pptx
 
A Domino Admins Adventures (Engage 2024)
A Domino Admins Adventures (Engage 2024)A Domino Admins Adventures (Engage 2024)
A Domino Admins Adventures (Engage 2024)
 
Understanding the Laravel MVC Architecture
Understanding the Laravel MVC ArchitectureUnderstanding the Laravel MVC Architecture
Understanding the Laravel MVC Architecture
 
FULL ENJOY 🔝 8264348440 🔝 Call Girls in Diplomatic Enclave | Delhi
FULL ENJOY 🔝 8264348440 🔝 Call Girls in Diplomatic Enclave | DelhiFULL ENJOY 🔝 8264348440 🔝 Call Girls in Diplomatic Enclave | Delhi
FULL ENJOY 🔝 8264348440 🔝 Call Girls in Diplomatic Enclave | Delhi
 
Transforming Data Streams with Kafka Connect: An Introduction to Single Messa...
Transforming Data Streams with Kafka Connect: An Introduction to Single Messa...Transforming Data Streams with Kafka Connect: An Introduction to Single Messa...
Transforming Data Streams with Kafka Connect: An Introduction to Single Messa...
 
Factors to Consider When Choosing Accounts Payable Services Providers.pptx
Factors to Consider When Choosing Accounts Payable Services Providers.pptxFactors to Consider When Choosing Accounts Payable Services Providers.pptx
Factors to Consider When Choosing Accounts Payable Services Providers.pptx
 
Enhancing Worker Digital Experience: A Hands-on Workshop for Partners
Enhancing Worker Digital Experience: A Hands-on Workshop for PartnersEnhancing Worker Digital Experience: A Hands-on Workshop for Partners
Enhancing Worker Digital Experience: A Hands-on Workshop for Partners
 
Install Stable Diffusion in windows machine
Install Stable Diffusion in windows machineInstall Stable Diffusion in windows machine
Install Stable Diffusion in windows machine
 
From Event to Action: Accelerate Your Decision Making with Real-Time Automation
From Event to Action: Accelerate Your Decision Making with Real-Time AutomationFrom Event to Action: Accelerate Your Decision Making with Real-Time Automation
From Event to Action: Accelerate Your Decision Making with Real-Time Automation
 

Xen and-the-art-of-rails-deployment2640

  • 1. Xen and the Art of Rails Deployment
  • 2. Who am I? • Ezra Zygmuntowicz • Rubyist for 4 years • Engine Yard Founder and Architect • Blog: http://brainspl.at
  • 3. Deploying Rails • Details have changed rapidly over the years • Many different webservers have come and gone • Basics remain the same
  • 4. Full Stack Request/Response Life-Cycle • Request comes into gateway server • Rewrite rules are evaluated and request gets served directly if it’s a static asset • Dynamic requests are proxied to one Mongrel in the Mongrel Cluster • Mongrel dispatches request through Rails and returns response to client
  • 5. History Lesson • CGI • Apache1.3.x/mod_fastcgi • Lighttpd/fcgi • Apache2.x/mod_fcgid • Lighttpd/SCGI • Lightspeed
  • 6. Enough Already X • CGI • Apache1.3.x/mod_fastcgi • Lighttpd/fcgi • Apache2.x/mod_fcgid • Lighttpd/SCGI • Lightspeed
  • 9. Mongrel is an HTTP Server Library written by Zed Shaw • Fast HTTP Parser written in Ragel + C • Fast URI Classifier written in C • Stackable Request Handlers • Flexible Configuration • Secure and RFC Compliant HTTP Parser
  • 11. Why is Mongrel better? • HTTP is a well known and well tooled protocol • Mongrel is way easier to setup and use • Transparent wire protocol
  • 12. But Rails isn’t Thread Safe! • Giant Mutex Lock around Rails Dispatch • Only one request served at a time by one mongrel • Use mongrel_cluster to scale with multiple processes
  • 13. Rails Internal Request/Response Life-Cycle • Mongrel Locks Mutex • Rails Dispatcher is invoked with request/response objects • Routing is invoked and returns the proper Controller object or 404 if no route found • Filter chain is invoked • Controller’s Action is called, manipulates Models • View is rendered and any after filters are called • Mongrel Unlocks Mutex • Final response or error page returned to client
  • 14. New dog seeking old tricks • Wide array of options for HTTP tools to front mongrel clusters • Pen, Pound, Balance, Haproxy ( No static file serving, just proxies) • Lightspeed can serve static files and proxy to mongrel • Apache2.2.x/mod_proxy_balancer can do the same
  • 15. On the prowl for the perfect stack • Pen(no ssl support, no connection rate limiting) • Pound(Falls down under high load, no connection rate limiting) • Haproxy(supports conn rate limits, very high perf, no static files so more moving parts in a full stack) • Lightspeed(free version is crippled) • Apache2.2.x(Does work but.. bloat, bloat, bloat...)
  • 16. Nginx: From Russia, with Love • Seriously bent on performance • Super small resource footprint • Stands up under the heaviest loads without leaking memory • Killer rewrite and proxy modules • Approachable author and growing community
  • 17. Nginx + Mongrel • This is *the* stack to be on • Only keep apache around for mod_dav_svn • Flexible nginx.conf syntax allows for serving static files and rails caches and proxying dynamic requests to mongrel • Fast, fast, fast • Did I say it’s fast yet?
  • 18. A few gotchas • Nginx buffers file uploads, so no mongrel_upload_progress. This will be addressed soon • No connection rate limiting for proxy module yet, this too shall pass
  • 19. A bright future for nginx • mod_rewrite is going away • To be replaced with http_script_module • This will embed the NekoVM(http://nekovm.org/) directly in nginx so customizing behavior for rewriting and proxying will become infinitley flexible
  • 20. Perfect Simple Stack • Linux • Nginx • Mongrel(mongrel_cluster) • Monit
  • 21. Swiftiply: Teaching the Dog new tricks http://swiftiply.swiftcore.org
  • 22. Swiftiply: Evented Mongrel • Hot patch to Mongrel • Removes Ruby’s Thread’s and Socket handling from Mongrel Core • Replace with EventMachine event loop • Mongrel becomes Single threaded, event driven • Noticable Speed and IO throughtput increase • Stands up much better under higher concurrent load without starting to slow down or leak memory
  • 23. But how does a single threaded event driven mongrel outperform a multithreaded mongrel? • Ruby’s green threads have a lot of overhead in context switching and have to copy a lot of state context for each thread • Mutual exclusion locks are expensive • One process can only do so much IO • Event driven means running in a tight loop and firing callbacks in response to network ‘events’ • Since there is no context switching between threads, a single process has less overhead to deal with which allows for higher throughput and faster networking IO
  • 24. Mongrel VS Evented Mongrel in a Hello World dogfight Mongrel: 1 concurrent user Evented Mongrel: 1 concurrent user
  • 25. Mongrel: 100 concurrent users Evented Mongrel: 100 concurrent users
  • 26. Swiftiply Proxy • Event driven proxy, small memory footprint(7-10Mb) • Faster then Haproxy • Did I mention Fast?
  • 27. How it differs from a normal proxy Standard proxy must know about the With swiftiply, the backends connect to the proxy. So ports of all backends. Usually requires all mongrels get started on the same port and then restart to add more backends they open a persistent connection to the proxy
  • 28. This means you can start and stop as many mongrels as you want and they get auto configured in the proxy! This opens the door for scaling the number of mongrels automatically in response to increased load on the fly!
  • 29. The Zen of Xen
  • 30. Monolithic Linux VS Modularized Linux • Old way of thinking is dedicated boxes running all services in one big hodgepodge on one kernel • New school is sharply targeted virtualized linux with each VM running a single tier or service
  • 31. We all strive for code modularization right? • Why not do the same thing with our servers? • Each VM runs one or two related services • Simplifies deployment and scaling • Even if you only have one box you absolutely should run Xen on it from the start
  • 33. What happens when you need to scale to more then one box?
  • 34. Old School • Get another box and move mysql on there • Get another box to run some of the other services • Lots of setup required, downtime to migrate • Complex Linux installs with many services running are harder to debug when performance problems happen • This *can* scale but is way less flexible
  • 35. New School • Add another box with Xen installed • Pick a few services that need more resources and migrate them *live* to the other machine • Each VM runs one thing and runs it well • Easy to target performance problems • Scales much better
  • 36. Advanced Clustering • Virtualized compute nodes that boot Xen dom0 off of USB thumb drives • SAN storage for all Xen domU(VPS’s) • Red Hat Clustering Suite for fencing and cluster quorems • GFS for 100% posix compliant clustered filesystem(no shitty NFS) • Hardware load balancers or dedicated boxes running Ultra Monkey or just straight LVS
  • 37. Fabric of Compute and Storage • When a compute node fails just swap it out for a new one and plug in the thumbdrive and you’re back in business • Move hot VM’s to less loaded nodes easily as they are not tied to a single machine • Deploy your app code to one node and then bounce the mongrels on all nodes with a clustered filesystem like GFS • Fragment and page caching consistency across all nodes instantly • Scale from one or 2 VM’s to as many as traffic requires *and* back down again once traffic subsides.
  • 38. RAM RAM RAM • Most Rails apps are RAM bound way before they are CPU bound • Average mongrel size on 64bit EngineYard is 70-120Mb *per* mongrel. Slightly less on 32 bit systems • Rmagick and :include the worst culprits • 95% of Rails apps will leak memory at one point or another
  • 39. Rails eats Database resources for breakfast • Majority of app in the wild have *no* indexes in their databases • Learn when and where to apply indexes, it will save your ass • ActiveRecord insulates developers from SQL to the point of massive ineficiencies. Look at your logs and see what SQL is being generated. Do not fear the SQL and don’t think you can get away without some denormalization and custom SQL if you plan on your app having a chance of scaling
  • 40. Other tips & tricks • *Don’t* use filesystem sessions, AR or SQLSession or memcached if you don’t need persistance • script/runner is massively ineficient. Try as hard as possible to not load all of rails in your background processes. Use the raw Mysql library and plain ruby if you can and your servers will thank you for it • *Do not* use script runner to process incoming email. Run a daemon in a loop and poll a mail server with net/ pop2 or net/imap. Forking a whole rails process for each incoming email will never work in a production environment period
  • 41. Rails is great for the 80/20 rule • But you are on your own when you need the last 20% • Learn how to write custom mongrel handlers for perf critical sections of your app • When is optimization not premature? • Ruby is plenty fast, it’s rails that tends to be on the slow side • Cache, cache, cache. It doesnt get much faster then service cached static html files
  • 42. Parting Thought • Don’t take what I or anyone else says about this stuff as gospel • Test it and benchmark it for yourself to be sure • Trust but verify and you will stay in good shape