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
Skalowanie aplikacji PHP
Search
Leszek Krupiński
September 27, 2014
Programming
430
1
Share
Skalowanie aplikacji PHP
Leszek Krupiński
September 27, 2014
More Decks by Leszek Krupiński
See All by Leszek Krupiński
So that the daemon won’t die
leafnode
2
410
Practical PHP7
leafnode
2
480
Dobrze posól swoje hasło
leafnode
0
120
Dobrze posól swoje hasło (z notatkami)
leafnode
0
110
PHPNG kontra HHVM
leafnode
0
120
PHPNG kontra HHVM (z notatkami)
leafnode
0
83
Ewolucja PHP: PHP 5.6, NG, PHP 7, HHVM
leafnode
2
310
Sculpin - Generowanie statycznych stron w PHP
leafnode
2
76
Varnish to the Rescue
leafnode
0
140
Other Decks in Programming
See All in Programming
今こそ押さえておきたい アマゾンウェブサービス(AWS)の データベースの基礎 おもクラ #6版
satoshi256kbyte
1
240
RSAが破られる前に知っておきたい 耐量子計算機暗号(PQC)入門 / Intro to PQC: Preparing for the Post-RSA Era
mackey0225
3
130
年間50登壇、単著出版、雑誌寄稿、Podcast出演、YouTube、CM、カンファレンス主催……全部やってみたので面白さ等を比較してみよう / I’ve tried them all, so let’s compare how interesting they are.
nrslib
4
770
The Monolith Strikes Back: Why AI Agents ❤️ Rails Monoliths
serradura
0
310
Rethinking API Platform Filters
vinceamstoutz
0
11k
Feature Toggle は捨てやすく使おう
gennei
0
570
Server-Side Kotlin LT大会 vol.18 [Kotlin-lspの最新情報と Neovimのlsp設定例]
yasunori0418
1
110
ハーネスエンジニアリングにどう向き合うか 〜ルールファイルを超えて開発プロセスを設計する〜 / How to approach harness engineering
rkaga
12
4.5k
AWS re:Invent 2025の少し振り返り + DevOps AgentとBacklogを連携させてみた
satoshi256kbyte
3
160
LM Linkで(非力な!)ノートPCでローカルLLM
seosoft
0
470
Coding at the Speed of Thought: The New Era of Symfony Docker
dunglas
0
4.8k
夢の無限スパゲッティ製造機 -実装篇- #phpstudy
o0h
PRO
0
200
Featured
See All Featured
[SF Ruby Conf 2025] Rails X
palkan
2
950
Why Your Marketing Sucks and What You Can Do About It - Sophie Logan
marketingsoph
0
130
sira's awesome portfolio website redesign presentation
elsirapls
0
210
Ecommerce SEO: The Keys for Success Now & Beyond - #SERPConf2024
aleyda
1
1.9k
Ruling the World: When Life Gets Gamed
codingconduct
0
190
The Cost Of JavaScript in 2023
addyosmani
55
9.8k
Improving Core Web Vitals using Speculation Rules API
sergeychernyshev
21
1.4k
Game over? The fight for quality and originality in the time of robots
wayneb77
1
160
Practical Orchestrator
shlominoach
191
11k
個人開発の失敗を避けるイケてる考え方 / tips for indie hackers
panda_program
122
21k
Darren the Foodie - Storyboard
khoart
PRO
3
3.2k
The agentic SEO stack - context over prompts
schlessera
0
740
Transcript
SKALOWANIE APLIKACJI PHP Leszek Krupiński, PHPCon 2014
LEAFNODE
CO TO JEST SKALOWALNOŚĆ?
— WIKIPEDIA Skalowalność (ang. scalability) - zapewnienie coraz wydajniejszej pracy
w miarę zwiększania liczby elementów składowych.
SKALOWANIE WERTYKALNE
SKALOWANIE HORYZONTALNE
PO CO DBAĆ O SKALOWALNOŚĆ?
ZADOWOLENIE KLIENTA
bit.ly/slowwebspeed
None
None
JAKIE SĄ KRYTYCZNE WARTOŚCI?
None
None
WYMIERNE KORZYŚCI
15,4% WIĘCEJ POBRAŃ FIREFOKSA PO PRZYSPIESZENIU STRONY MOZILLI O 2,2s
14% WIĘCEJ WPŁAT NA KAMPANIĘ BARACKA OBAMY PO PRZYSPIESZENIU STRONY
ZGŁOSZENIOWEJ O 60%
WYLICZENIA WALMARTU I AMAZONU: ZYSKI WIĘKSZE O 1% ZA KAŻDE
100ms
WYLICZENIA YAHOO: 9% WIĘCEJ RUCHU W SERWISIE ZA KAŻDE 400ms
PODSTAWY
HTTP REQUEST
None
None
None
SKOCZĘ JESZCZE PO WARZYWA
CO MOŻNA ZROBIĆ?
• SZYBSZA OBSŁUGA KLIENTA • WIĘCEJ KAS • KOLEJNE SKLEPY
KUPMY WIĘKSZY SERWER
KUPMY WIĘCEJ SERWERÓW
BEZ ODPOWIEDNIEJ ARCHITEKTURY NIE MA TO SENSU
BYĆ MOŻE WYSTARCZY OPTYALIZACJA APLIKACJI
WYCIŚNIĘCIE MAKSIMUM Z MOŻLIWOŚCI MASZYNY
OPTYMALIZUJ ISTOTNE FRAGMENTY KODU
— Donald Knuth Premature optimization is the root of all
evil.
UPEWNIJ SIĘ, ŻE TO NA PEWNO PHP JEST WINNE
NARZĘDZIA
xdebug + cachegrind
None
XHProf
None
New Relic
NEWRELIC POKAŻE KTÓRE KOMPONENTY DOMINUJĄ OBCIĄŻENIE
METRYKI
None
STATSD
None
MIN, MAX, 90th, COUNT, MEAN
GRAPHITE
None
None
ANALIZA LOGÓW: LOGSTASH, GRAYLOG2
PHP
ZAKTUALIZUJ PHP
STANDARD NA 2014: NGINX + PHP-FPM
NGINX: SZYBKOŚĆ, ELASTYCZNOŚĆ
PHP-FPM: ROZDZIELENIE PROCESÓW
WŁĄCZ OPCODE CACHE
ZOPTYMALIZUJ FRAMEWORK
WŁĄCZ CACHE
WYŁĄCZ AUTOGENEROWANIE
WYŁĄCZ ZBĘDNE MODUŁY
OPTYMALIZACJA BAZY DANYCH
GŁÓWNA PRZYCZYNA PROBLEMÓW Z WYDAJNOŚCIĄ
SLOW LOG? PERCONA TOOLKIT
INDEKSY QUERY CACHE ALTERNATYWNE SILNIKI
NOSQL
ARCHITEKTURA
None
DOBIERZ KOMPONENTY
FULL TEXT SEARCH? SPHINX.
STRUKTURY DANYCH? REDIS.
BUFORUJ DANE
•WYNIKI ZAPYTAŃ •ODPOWIEDZI API •KONFIGURACJA •GENEROWANE DANE
NAJCZĘŚCIEJ UŻYWANE: W PAMIĘCI
MEMCACHE
MOŻLIWOŚĆ WYDZIELENIA WSPÓŁDZIELONEGO SERWERA MEMCACHE
VARNISH
NAGŁÓWKI HTTP bit.ly/httpcache
MAX AGE LAST MODIFIED ETAG
ROZDZIEL SKŁADNIKI
! ARCHITEKTURA HEKSAGONALNA
None
PRZETWARZAJ ASYNCHRONICZNIE
GDZIEŚ TU UŻYTKOWNIK KLIKA “RELOAD”
Aplikacja Kolejka
Nowa%piosenka Rekodowanie C++ MusicShare Generowanie%skrótu% piosenki C++ Web%Service Java Jabber
erlang Statyczny%HTML PHP DECOUPLING
LOAD BALANCING Front&end RabbitMQ Consumer
! POZA JEDEN SERWER
LOAD BALANCER
VARNISH HAPROXY NGINX
PROBLEMY
! DANE WSPÓŁDZIELONE
SESJE
! PERSISTENT LOAD BALANCER
! WSPÓLNY MEMCACHE
INNE DANE
! PLIKI STATYCZNE
! WSPÓLDZIELONY SYSTEM PLIKÓW
API
ARCHITEKTURA DLA BAZ DANYCH
REPLIKACJA MASTER-SLAVE
SHARDING
None
None
None
PROBLEMY
RESHARDING
JOIN
NA KONIEC
NIE OPTYMALIZUJ PRZEDWCZEŚNIE
BUDUJ ARCHITEKTURĘ PERSPETYWICZNIE
OPTYMALIZUJ STOSOWNIE DO SKALI
BĄDŹ ZEN
ŻYCZĘ WSZYSTKIM TAKICH PROBLEMÓW :-)
https://joind.in/11839 @leafnode
PYTANIA?
DZIĘKUJĘ ZA UWAGĘ Title image credits: https://www.flickr.com/photos/torkildr/3462607995/