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
pixivにおけるHHVMとPHP7 と、高速化事例紹介
Search
Sponsored
·
Ship Features Fearlessly
Turn features on and off without deploys. Used by thousands of Ruby developers.
→
Atsushi Takayama
April 15, 2016
Technology
4.3k
2
Share
pixivにおけるHHVMとPHP7 と、高速化事例紹介
PHP7 Casual Talks #2で発表した内容です。
Atsushi Takayama
April 15, 2016
More Decks by Atsushi Takayama
See All by Atsushi Takayama
最高の開発者体験の追求が開発生産性を改善し続ける文化を生み出した話
edvakf
3
1.6k
NeurIPS 2021 論文読み会: How Modular should Neural Module Networks Be for Systematic Generalization?
edvakf
0
220
8年物のJavaのシステムをKotlinに変えていく選択に至るまで
edvakf
2
1.1k
ピクシブ社内のImageFlux利用事例紹介
edvakf
2
3.1k
学びの文化を育む社内読書会のススメ
edvakf
0
320
フルCDNアーキテクチャでサービス設計した話
edvakf
5
4.1k
Goでバイナリを読む+α
edvakf
1
1k
お前はこれまでに作ったAPIの数を覚えているのか?
edvakf
0
2.7k
「ふつうのRailsアプリケーション」についての考え方
edvakf
2
940
Other Decks in Technology
See All in Technology
新規事業を牽引する技術選定 〜フルスタックTypeScript開発の実践事例〜
nullnull
2
310
「コーディング」しない人のための Claude Code 入門 ChatGPT の次の一歩 — 業務に組み込む 育成・共有・自動化
rfdnxbro
2
1.2k
Sony_KMP_Journey_KotlinConf2026
sony
2
210
BigQuery の Cross-cloud Lakehouse への歩み
phaya72
2
540
Oracle AI Database@Azure:サービス概要のご紹介
oracle4engineer
PRO
6
1.9k
そのPoC、何を検証したつもりでしたか? AIプロダクトの価値検証で陥った落とし穴
techtekt
PRO
0
140
「速く作る」から「正しく作る」へ ─ 生成AI時代の開発フロー改革の ロードマップと実行 ─
starfish719
0
6.9k
正解のないAIプロダクトをどう導くか?dodaが挑む、ユーザーの『本音』を構造化する評価設計と検証のリアル
techtekt
PRO
0
180
新規ゲーム開発におけるAI駆動開発のリアル
202409e2
0
2.4k
タクシーアプリ『GO』の実践的データ活用
mot_techtalk
2
120
Diagnosing performance problems without the guesswork
elenatanasoiu
0
160
ブロックチェーン / Blockchain
ks91
PRO
0
100
Featured
See All Featured
The Organizational Zoo: Understanding Human Behavior Agility Through Metaphoric Constructive Conversations (based on the works of Arthur Shelley, Ph.D)
kimpetersen
PRO
0
350
Reflections from 52 weeks, 52 projects
jeffersonlam
356
21k
職位にかかわらず全員がリーダーシップを発揮するチーム作り / Building a team where everyone can demonstrate leadership regardless of position
madoxten
62
54k
Getting science done with accelerated Python computing platforms
jacobtomlinson
2
220
[RailsConf 2023 Opening Keynote] The Magic of Rails
eileencodes
31
10k
Building a Scalable Design System with Sketch
lauravandoore
463
34k
The Illustrated Guide to Node.js - THAT Conference 2024
reverentgeek
1
370
Leveraging Curiosity to Care for An Aging Population
cassininazir
1
260
Collaborative Software Design: How to facilitate domain modelling decisions
baasie
1
240
SERP Conf. Vienna - Web Accessibility: Optimizing for Inclusivity and SEO
sarafernandez
2
1.5k
Believing is Seeing
oripsolob
1
140
The Curse of the Amulet
leimatthew05
1
13k
Transcript
pixivʹ͓͚ΔHHVMͱPHP7 ͱɺߴԽࣄྫհ PHP7 Casual Talks #2
www.pixiv.net
ࣗݾհ • ߴࢁ Թ @edvakf • ϐΫγϒͰϦʔυΤϯδχΞ • pixivͷອըࣄۀͷ։ൃऀ •
ձࣾͷٕज़બΛԁʹਐΊΔͨΊͷମ੍ͮ͘Γ • Α͘ॻ͘ݴޠPHP, Ruby, Go, Scala, JavaScript • ʮࣾͷΤϯδχΞ͕ͤʹಇͨ͘ΊʹʯΛߟ࣮͑ݱ͢Δۀ
pixiv.git www.pixiv.net ͱෳͷؔ࿈αʔϏεΛؚΉڊେϦϙδτϦ find . -name '*.php' | xargs cat
| wc -l 69ສߦ ϑΝʔετίϛοτ20079݄ PHP5.2 → 5.3 → 5.5ͱมભ ίʔυϕʔεશମʹؔΘΔϦϑΝΫλϦϯάΛزܦݧ
pixivͱߴԽ ඵؒ1ສϦΫΤετΛ30Ͱࡹ͘ ചΓ্͛ͷແ͍࣌ʹٸͨ͜͠ͱ͔Βɺαʔόʔ ΛݮΒ͢͜ͱʹࣥ೦Λ೩͖ͯͨ͠ྺ࢙తܦҢ ϑϨʔϜϫʔΫͱݴ͑ͳ͍͙Β͍ബ͍ಠࣗϑϨʔϜϫʔ ΫΛ༻͢Δ͜ͱͰΦʔόʔϔουΛճආ
HHVM
ฏۉϨεϙϯελΠϜΛ20%ॖ
※Ұ෦ͷϖʔδͷΈͰಋೖ
HHVMͷར༻ ಛఆͷύεͷϦΫΤετͷҰ෦ΛϦόʔεϓϩΩγͰHHVMʹ ྲྀ͢ pixivͷϦΫΤετͷ3ʙ4ׂΛΊΔϖʔδ ͨͩ͠ίʔυͷׂ߹0.003% ΤΫεςϯγϣϯ·ΘΓҎ֎ͰಛʹHHVMରԠͷमਖ਼͠ͳ ͔ͬͨ ͙Β͍ຊ൪ڥͰݕূ͍ͯͨ͠
શҠߦ͠ͳ͔ͬͨཧ༝ ͍͔ͭ͘ͷpeclΤΫεςϯγϣϯ͕ରԠݟࠐΈ͕ແ ͔ͬͨ ಛʹςετͰͷΈ͍ͬͯΔͷ HHBC͕σϓϩΠͷͨͼʹΕଓ͚ΔͷͰɺఆظతʹ ࠶ىಈ͍ͯͨ͠ PHP7Λͭ͜ͱʹ
PHP7Խͷಓ PHP7։ൃڥͰݕূத ΄΅ͳ͘ಈ͍͍ͯΔ HHVMͱಉ༷ɺະରԠͷpeclΤΫεςϯγϣϯ͕՝ ि̍ճͷϦϑΝΫλϦϯάࡇΓͰPHP7Խ pixiv.gitͷ΄ͱΜͲͷ։ൃऀ݄͙̍Β͍ͷϖʔεͰ λʔϯ͕·Θͬͯ͘Δ
͜Ε·ͰͷՌ mysql_* ؔͷഇࢭ ઍՕॴΛ̍ͰPDOʹஔ pecl solrͷഇࢭ file_get_contentsͰHTTPϦΫΤετԽ ࠷ۙʹͳͬͯPHP7ରԠ͕׆ൃʹ ςετΛtimecopඇґଘʹ ͜Ε࠷ۙʹͳͬͯhnw͞Μ͕ରԠ
ΛਐΊ͍ͯΔ php7ccͰҾ͔͔ͬΔՕॴͷमਖ਼ runkitʹґଘ͍ͯͨ͠ςετΛrunkit7ʹ runkitͷ͏ͪ1͔͍ؔͬͯ͠ͳ͔ͬͨ memcacheϞδϡʔϧΛmemcachedϞ δϡʔϧʹஔ͖͑ ෭࣍ޮՌͱͯ͠ɺE_STRICTΛࠓ·Ͱແࢹ ͍͕ͯͨ͠ɺͯͭ͢Ϳͯ͠ΊͰͨ͘Τϥʔ ϨϕϧΛ্͛Δ͜ͱ͕Ͱ͖ͨ ͞Βʹ෭࣍ޮՌͰશ໘తʹautoloaderΛಋೖ
pixivͷߴԽࣄྫհ
pixivͷߴԽͷऔΓΈ ʢਖ਼֬ʹαʔόʔΛݮΒͨ͢Ίͷ࠷దԽʣ جຊతʹపఈతʹΩϟογϡ͠·͘Δઓུ KyotoTycoonͱAPCuͷೋஈΩϟογϡ ͔͠͠ϩϯάςʔϧͳαʔϏεͷ᠘… CPUDBϦΫΤετʹൺͯϘτϧωοΫͰͳ͍͜ͱ͕ଟ͍ ͷͰɺΑͬΆͲͷ͜ͱ͕ແ͍ͱPHPϨϕϧͰͷߴԽʹखΛग़ ͞ͳ͍
ࣄྫ̍ ϒϧʔϜϑΟϧλ ΫΤϦͷछྨ͕େ͕ͩɺ΄ͱΜͲώοτ͠ͳ͍ύλʔϯ ಛʹ̍ϖʔδ͋ͨΓෳճΫΤϦ͕Δ߹ ώοτ͠ͳ͍ͷʹDBΛҾ͘ͷ͕ແବײ ʮϨίʔυ͕ଘࡏ͠ͳ͍ʯͱ͍͏ΩϟογϡʢωΨςΟϒΩϟογϡʣΛ APCuʹ࣋ͭʁ APCuͷϝϞϦ͕େྔʹඞཁ ͦ͜ͰϒϧʔϜϑΟϧλ inside.pixiv.net/entry/2014/07/22/132103
ࣄྫ̎ fast_str_replace ϨεϙϯεͷதͰɺಛఆͷϫʔυΛͯ͢ஔ ྫɿಛఆͷࠃͰݕӾ͞Ε͍ͯΔ୯ޠΛۭͯ͢จࣈʹ fast_str_replace ͱ͍͏ΤΫεςϯγϣϯΛ࡞ pixivͷϢʔεέʔεͰ str_replace ͷ5ഒߴ ۃྗΤΫεςϯγϣϯʹґଘͨ͘͠ͳ͍ͷͰɺ͍ͭͰ
str_replace ʹͤΔΑ͏ʹAPIΛἧ͑ͨ ͨͩ͠ୈҰҾʹιʔτࡁΈྻ͔ͤ͠ͳ͍
ࣄྫ̏ ϧʔςΟϯά mod_rewriteΛΊ͍ͯ͘ྲྀΕ PHPͰϧʔςΟϯάͯ͠Έͨˠ͍ˠߴԽ͠Α͏ inside.pixiv.net/entry/2015/12/13/145741 ڞ௨͢Δ಄ࣙΛ࿈ྻԽʢύτϦγΞʣͯ͠ߴʹ୳ࡧ FastRouteͷΑ͏ʹɺϧʔςΟϯάͷΩϟογϡΛ࡞Βͳͯ͘ ेʹߴͩͬͨͷͰɺ͍উखͷ໘Ͱ࠾༻
ࣄྫ̐ ςϯϓϨʔτΤϯδϯJingu pixivͷCPU࣌ؒͷ͙Β͍Smarty͕Ί͍ͯΔ ύʔαɾδΣωϨʔλʹΑΔςϯϓϨʔτΤϯδϯΛࣗ࡞ͯ͠Έͨ ςϯϓϨʔτΤϯδϯNightͰൃද http://pirosikick.hateblo.jp/entry/2014/10/18/113907 https://github.com/atsumu/jingu ؔݺͼग़͠ΛݮΒͯ͠10ഒ͙Β͍ͨ͘͠ͳͲ HHVMPHP7Ͱؔݺͼग़͕͘͠ͳͬͨͷͰࠓͩͱҧ࣮ͬͨʹͳΔ͔ʁ ·ͩಋೖʹࢸΒͣ
·ͱΊ pixivͰHHVMΛ΄Ͳ࣮ӡ༻ͯ͠ݕূ͍ͯͨ͠ ϨεϙϯελΠϜΛ20%ॖ͢Δ͜ͱ͕Ͱ͖ͨ ݱࡏPHP7ԽΛਐΊ͍ͯΔ ͦͷଞpixivͷPHPϨϕϧͷߴԽࣄྫΛհͨ͠