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
How Swoole Blows Up Your Mind
Search
Sponsored
·
Your Podcast. Everywhere. Effortlessly.
Share. Educate. Inspire. Entertain. You do you. We'll handle the rest.
→
Albert Chen
December 20, 2022
310
1
Share
Embed
Copy iframe code
Copy JS code
Copy link
Start on current slide
How Swoole Blows Up Your Mind
PHPCon Okinawa 2019
Albert Chen
December 20, 2022
More Decks by Albert Chen
See All by Albert Chen
Supercharge Laravel Queues with Hypervel
albertcht
0
49
Introduction to Swoole's AOT Compiler
albertcht
0
72
Hypervel - A Coroutine Framework for Laravel Artisans
albertcht
2
320
Beyond Laravel Octane - Hyperf for Laravel Artisans
albertcht
1
860
Source Code Protection Techniques in PHP
albertcht
0
1.3k
High Concurrency Web Architecutre and Laravel Performance Tuning
albertcht
2
390
Build Your High Concurrency App With PHP and Swoole
albertcht
2
710
From Generator to Fiber the Road to Coroutine in PHP
albertcht
1
690
The System Architecture of Real-time Report in Laravel
albertcht
1
650
Featured
See All Featured
SEO for Brand Visibility & Recognition
aleyda
0
4.6k
What Being in a Rock Band Can Teach Us About Real World SEO
427marketing
0
250
The Language of Interfaces
destraynor
162
27k
Fashionably flexible responsive web design (full day workshop)
malarkey
408
66k
AI Search: Implications for SEO and How to Move Forward - #ShenzhenSEOConference
aleyda
1
1.3k
Unlocking the hidden potential of vector embeddings in international SEO
frankvandijk
0
840
How STYLIGHT went responsive
nonsquared
100
6.2k
ReactJS: Keep Simple. Everything can be a component!
pedronauck
666
130k
End of SEO as We Know It (SMX Advanced Version)
ipullrank
3
4.2k
Agile Actions for Facilitating Distributed Teams - ADO2019
mkilby
0
210
The Myth of the Modular Monolith - Day 2 Keynote - Rails World 2024
eileencodes
28
3.5k
Bridging the Design Gap: How Collaborative Modelling removes blockers to flow between stakeholders and teams @FastFlow conf
baasie
0
580
Transcript
How Swoole Blows Up Your Mind? @PHPCon Okinawa 2019 By
Albert Chen
About Me • Albert Chen • Software Architect • M17
HandsUp • Open Source Maintainer
What is Swoole?
None
What is Swoole? • A C extension for PHP •
An asynchronous network engine for PHP • Features: • Event-driven non-blocking I/O • HTTP / HTTP2 / Websocket / TCP / UDP • Coroutine (CSP Model) • High performance for high concurrency
Why PHP Performs Poorly in High Concurrency?
Lifecycle in PHP
Lifecycle in PHP PHP Files Tokenizing Semantic Parsing AST Generate
Bytecode Execute Bytecode Output Load Bytecode From Memory Check Bytecode Cache
Blocking I/O in PHP Request Request Request Request PHP FPM
FPM Pool FPM Pool Worker Worker Worker Worker Blocking I/O
Eventloop in NodeJS
There’s no Eventloop in Traditional PHP
Let’s See What Changes in Swoole?
Structure in Swoole Server
Structure in Swoole Server • Code Is Persistent in Memory
• Swoole Takes Lifecycle Over PHP • Reduce Initialization Steps • Reduce Response Latency • Event-driven Non-blocking I/O for Requests
Benchmark Comparison of Go with Swoole
Server Benchmark in Go
Server Benchmark in Go
Server Benchmark in Swoole
Server Benchmark in Swoole
This Doesn’t Mean PHP with Swoole is Faster Than Go
(Of Course Not)
Coroutine in Swoole
Coroutine in Swoole • Blocking I/Os Are Scheduled By Coroutine
Automatically.
Coroutine in Swoole • Blocking I/Os Are Scheduled By Coroutine
Automatically.
Coroutine in Swoole • CSP Model
Does This Mean Every Blocking I/O Doesn’t Block Anymore?
Coroutine in Swoole • How about This?
Coroutine in Swoole • How about This?
Runtime Hooks Transform Blocking I/Os into Coroutines with Magic!
Use Case In HandsUp
Use Case Facebook Webhooks Message Load Balancer Server Server Server
Queue PubNub Service Analysis Service Swoole Service PubSub Many to Many Queue Workers High Concurrent Requests
Use Case • Replace Guzzle Handler with Swoole Client
Q&A