MICRO-SERVICES
MAGENTO 2.0 PERFORMANCE
by Ivan Chepurnyi
 
 
 
 
 
 
ABOUT ME
One of lucky former members of Magento 1.x Core Team
I love to optimize performance
I give trainings and independent consultancy
Let's talk about PHP APP evolution
All started from the good old Apache's
mod_php
mod_php
Spawns 
 new PHP process
Server 
Thread
Executes 
PHP script
PHP
 Initialization
Executes 
Business Logic
Application
 Bootstrap
Rendering the
Page
DRAWBACKS
Dynamic server processes was not limited
PHP process is alive unless all bytes transfered to a
remote connection
Every new PHP process takes time to start
Who is still running mod_php on production?
Then started an era of PHP-FPM
PHP-FPM
Waits 
for Response
Server 
Thread
Executes 
PHP File
Takes running
process
FPM
FastCGI Process
Manager
Process Pool
1..n
Executes 
Business Logic
Application
 Bootstrap
Rendering the
Page
DRAWBACK
Not controlling your memory usage, might results in
memory over-usage by one of the processes
Now the era of async I/O PHP apps is
emerging...
Application Process Manager
Waits 
for Response
Server 
Thread
Fork/Re-use Process 
with Business Logic
Application
Master Process
Rendering the
Page
DRAWBACKS
You have to control used memory
You have to ensure async IO on any operation
If single line of code fails, all app crashes
Is it possible with Magento 2?
The answer is micro-services...
What is a micro-service?
Micro-service is a component that runs as a separate
application
MICRO-SERVICE CANDIDATES IN MAGENTO 2.0
SESSIONS
Every page load requires I/O operation to cache storage
Dynamic requests in Varnish bootstrap full application
SESSION APPLICATION
Start Server
GC Inactive
Sessions every 5
minutes
Stop Server
IO to Redis IO to Redis
Lazy Load a
Session 
IO to Redis
STOCK PROCESSING
Every order place request requires database lock on stock
table
You usually sacrifice stock integrity for performance
reasons
STOCK APPLICATION
Live proof of concept demo
QUOTE (SHOPPING CARTS)
Every change shopping cart is a write DB operation
QUOTE APPLICATION
Store quotes in memory
Delayed DB syncronization
Endless BI possibilities
IMAGE RESIZE
Images has to be resized sequentially
Cold image cache perfromance hit
IMAGE MICROSERVICE
Image can be resized in parallel
Main Application can utilize Async I/O
LEARN MORE
ReactPHP:
PHPFastCGI:
Sample counter server:
http://reactphp.org/
http://phpfastcgi.github.io/
http://bit.ly/counter-sample
Q&A
@IvanChepurnyi
ivan@ecomdev.org

More Related Content

PDF
How to Install Magento on WAMP Server
PDF
Wordpress
PPTX
Php website developers toronto
PPTX
Magento Meetup New Delhi- Console
PDF
Introduction to Magento Functional Testing Framework
DOC
Rajesh CV
PPTX
Introduction to Office Development Topics
PPTX
php tutorial - By Bally Chohan
How to Install Magento on WAMP Server
Wordpress
Php website developers toronto
Magento Meetup New Delhi- Console
Introduction to Magento Functional Testing Framework
Rajesh CV
Introduction to Office Development Topics
php tutorial - By Bally Chohan

What's hot (11)

DOCX
PPT
php lesson 1
PPTX
Get AMP'ed for Accelerated Mobile Pages - SEO Grail Philadelphia 1/20/16
PDF
Certificate (1)
PDF
StorageCraft classroom configuration v1.5
PPT
Mule soft debugprogram
PDF
Laravel installation
PPTX
Php vs asp
PDF
DevCon Summit 2014 #DevelopersUnitePH: PHP Users Group Philippines (PHPUGPH) ...
PPTX
Php training in chandigarh - CBitss Technologies
php lesson 1
Get AMP'ed for Accelerated Mobile Pages - SEO Grail Philadelphia 1/20/16
Certificate (1)
StorageCraft classroom configuration v1.5
Mule soft debugprogram
Laravel installation
Php vs asp
DevCon Summit 2014 #DevelopersUnitePH: PHP Users Group Philippines (PHPUGPH) ...
Php training in chandigarh - CBitss Technologies
Ad

Viewers also liked (15)

PPTX
Super-scaling Magento with Docker, micro-services and micro-costs
PPTX
Bx3082 international marketingpresentation_sharnabrendecke
DOC
Arte islámico
PDF
Top Dresses
PDF
Best of Rome in One Day by e Bike
PDF
Nrf 130-pemex-2013
PPT
אלסקן מלמוט
PPTX
Sam zavosh, what to Look for in a Realtor
PDF
Coca Cola Drinks
PPTX
PDF
Nice Fashion
PPTX
Actividad 2 base de datos
PDF
Belgian Boys Mini Choco Stroopwafel
PDF
Blue Diamond Almond Breeze Unsweetened Original Beverage
PDF
Ariat Boots for Women
Super-scaling Magento with Docker, micro-services and micro-costs
Bx3082 international marketingpresentation_sharnabrendecke
Arte islámico
Top Dresses
Best of Rome in One Day by e Bike
Nrf 130-pemex-2013
אלסקן מלמוט
Sam zavosh, what to Look for in a Realtor
Coca Cola Drinks
Nice Fashion
Actividad 2 base de datos
Belgian Boys Mini Choco Stroopwafel
Blue Diamond Almond Breeze Unsweetened Original Beverage
Ariat Boots for Women
Ad

Similar to Mage Titans USA 2016 - Ivan Chepurnyi - Creating Micro-Services for Magento 2.0 Performance (20)

PDF
Prepara tu entorno para Magento 2
PDF
Magento 2 Performance: Every Second Counts
PPTX
Nexcess Magento Imagine 2014 Performance Breakout
PDF
Magento Meetup Mancheter with PushON: Elena Leonova
PDF
Microservices Application Simplicity Infrastructure Complexity
PDF
PHP Experience 2016 - [Palestra] Scaling with Microservice
PDF
Scaling with Microservice
PDF
Why Is MCP Server Development Trending Now.pdf
PDF
Everything you want to know about microservices
PPTX
Igor Miniailo - Magento 2 API Design Best Practices
PDF
Why Is MCP Server Development Trending Now.pdf
PPTX
Zendcon scaling magento
PDF
Magento 2 Development for PHP Developers
PDF
Oleh Kobchenko - Configure Magento 2 to get maximum performance
PDF
DevCommerce Conference 2016: Micro serviços muito além da teoria: a prática d...
PDF
Microservices Using Docker Containers for Magento 2
PDF
Magento 2 - An Intro to a Modern PHP-Based System - ZendCon 2015
PPTX
Backward Compatibility Developer's Guide in Magento 2. #MM17CZ
PPTX
Not all services can be micro interact usg 2018
PPT
Meet Magento Belarus - Elena Leonova
Prepara tu entorno para Magento 2
Magento 2 Performance: Every Second Counts
Nexcess Magento Imagine 2014 Performance Breakout
Magento Meetup Mancheter with PushON: Elena Leonova
Microservices Application Simplicity Infrastructure Complexity
PHP Experience 2016 - [Palestra] Scaling with Microservice
Scaling with Microservice
Why Is MCP Server Development Trending Now.pdf
Everything you want to know about microservices
Igor Miniailo - Magento 2 API Design Best Practices
Why Is MCP Server Development Trending Now.pdf
Zendcon scaling magento
Magento 2 Development for PHP Developers
Oleh Kobchenko - Configure Magento 2 to get maximum performance
DevCommerce Conference 2016: Micro serviços muito além da teoria: a prática d...
Microservices Using Docker Containers for Magento 2
Magento 2 - An Intro to a Modern PHP-Based System - ZendCon 2015
Backward Compatibility Developer's Guide in Magento 2. #MM17CZ
Not all services can be micro interact usg 2018
Meet Magento Belarus - Elena Leonova

More from Stacey Whitney (10)

PDF
Jason Woosley - Community Engagement 2.0 - Mage Titans Manchester 2016
PPTX
Mage Titans USA 2016 - Jonathan Bownds - Magento CI and Testing
PPTX
Mage Titans USA 2016 - Igor Melnykov - Staging and Preview
PDF
Mage Titans USA 2016 - Kimberely Thomas - Adopting Scrum and Agile for Develo...
PDF
Mage Titans USA 2016 - Joshua Warren - Magento 2 Integrations
PPTX
Mage Titans USA 2016 - Mathew Beane - Edit Fully Stacked: Less OOPS, More OPS...
PDF
Mage Titans USA 2016 - Miguel Balparda - Magento 2: Premium Performance with ...
PDF
Mage Titans USA 2016 - Brendan Falkowski Designing the B2B Experience
PPTX
Mage Titans USA 2016 - Brent Peterson - Start your project with a Bourbon and...
PPTX
Mage Titans USA 2016 - Eugene Tulika - Integrations with Magento, end to end...
Jason Woosley - Community Engagement 2.0 - Mage Titans Manchester 2016
Mage Titans USA 2016 - Jonathan Bownds - Magento CI and Testing
Mage Titans USA 2016 - Igor Melnykov - Staging and Preview
Mage Titans USA 2016 - Kimberely Thomas - Adopting Scrum and Agile for Develo...
Mage Titans USA 2016 - Joshua Warren - Magento 2 Integrations
Mage Titans USA 2016 - Mathew Beane - Edit Fully Stacked: Less OOPS, More OPS...
Mage Titans USA 2016 - Miguel Balparda - Magento 2: Premium Performance with ...
Mage Titans USA 2016 - Brendan Falkowski Designing the B2B Experience
Mage Titans USA 2016 - Brent Peterson - Start your project with a Bourbon and...
Mage Titans USA 2016 - Eugene Tulika - Integrations with Magento, end to end...

Recently uploaded (20)

PDF
Taming the Chaos: How to Turn Unstructured Data into Decisions
PDF
A comparative study of natural language inference in Swahili using monolingua...
PDF
Getting Started with Data Integration: FME Form 101
PDF
CloudStack 4.21: First Look Webinar slides
PDF
DASA ADMISSION 2024_FirstRound_FirstRank_LastRank.pdf
PDF
TrustArc Webinar - Click, Consent, Trust: Winning the Privacy Game
PDF
WOOl fibre morphology and structure.pdf for textiles
PDF
A Late Bloomer's Guide to GenAI: Ethics, Bias, and Effective Prompting - Boha...
PPTX
Benefits of Physical activity for teenagers.pptx
PPTX
MicrosoftCybserSecurityReferenceArchitecture-April-2025.pptx
PDF
How ambidextrous entrepreneurial leaders react to the artificial intelligence...
PDF
sustainability-14-14877-v2.pddhzftheheeeee
PDF
Enhancing emotion recognition model for a student engagement use case through...
PDF
Hybrid model detection and classification of lung cancer
PDF
A review of recent deep learning applications in wood surface defect identifi...
PDF
Hybrid horned lizard optimization algorithm-aquila optimizer for DC motor
PDF
Hindi spoken digit analysis for native and non-native speakers
PDF
DP Operators-handbook-extract for the Mautical Institute
PPTX
The various Industrial Revolutions .pptx
PPTX
Group 1 Presentation -Planning and Decision Making .pptx
Taming the Chaos: How to Turn Unstructured Data into Decisions
A comparative study of natural language inference in Swahili using monolingua...
Getting Started with Data Integration: FME Form 101
CloudStack 4.21: First Look Webinar slides
DASA ADMISSION 2024_FirstRound_FirstRank_LastRank.pdf
TrustArc Webinar - Click, Consent, Trust: Winning the Privacy Game
WOOl fibre morphology and structure.pdf for textiles
A Late Bloomer's Guide to GenAI: Ethics, Bias, and Effective Prompting - Boha...
Benefits of Physical activity for teenagers.pptx
MicrosoftCybserSecurityReferenceArchitecture-April-2025.pptx
How ambidextrous entrepreneurial leaders react to the artificial intelligence...
sustainability-14-14877-v2.pddhzftheheeeee
Enhancing emotion recognition model for a student engagement use case through...
Hybrid model detection and classification of lung cancer
A review of recent deep learning applications in wood surface defect identifi...
Hybrid horned lizard optimization algorithm-aquila optimizer for DC motor
Hindi spoken digit analysis for native and non-native speakers
DP Operators-handbook-extract for the Mautical Institute
The various Industrial Revolutions .pptx
Group 1 Presentation -Planning and Decision Making .pptx

Mage Titans USA 2016 - Ivan Chepurnyi - Creating Micro-Services for Magento 2.0 Performance