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
ログの設計してますか?PSR3とログ設計の話
Search
Ryo Tomidokoro
June 16, 2018
Programming
6
4.2k
ログの設計してますか?PSR3とログ設計の話
PHPカンファレンス福岡2018 #phpconfuk #hall_fu
Ryo Tomidokoro
June 16, 2018
Tweet
Share
More Decks by Ryo Tomidokoro
See All by Ryo Tomidokoro
集中して作業する技術/how_to_work_deeply
hanhan1978
58
38k
PHPでデータベースを作ってみた/create-data-with-php
hanhan1978
10
8.7k
ADRを一年運用してみた/adr_after_a_year
hanhan1978
8
3.3k
B+木入門:PHPで理解する データベースインデックスの仕組み/b-plus-tree-101
hanhan1978
5
4.3k
ADRを一年運用してみた/our_story_about_adr
hanhan1978
5
1.8k
PHPで学ぶ Session の基本と応用 / web-app-session-101-2024
hanhan1978
12
5.3k
レガシー回避のPHP開発術/avoid_php_legacy
hanhan1978
16
12k
Laravel Collectionの計算量を調べてみた2023/laravel_collection_time_complexity_2023
hanhan1978
1
1.3k
PHP で学ぶ Cache の距離の話 / study_cache_with_php
hanhan1978
7
2k
Other Decks in Programming
See All in Programming
connect-go で面倒くささと戦う / 2024-08-27 #newmo_layerx_go
izumin5210
2
620
Android開発以外のAndroid開発経験の活かしどころ
konifar
2
440
月間4.5億回再生を超える大規模サービス TVer iOSアプリのリアーキテクチャ戦略 - iOSDC2024
techtver
PRO
1
760
エラーレスポンス設計から考える、0→1開発におけるGraphQLへの向き合い方
bicstone
5
1.5k
Modular Monolith Go Server with GraphQL Federation + gRPC
110y
1
580
実践!難読化ガイド
mitchan
0
110
ドメイン駆動設計を実践するために必要なもの
bikisuke
3
320
Our Websites Need a Lifestyle Change, Not a Diet
ryantownsend
0
120
サーバーレスで負荷試験!Step Functions + Lambdaを使ったk6の分散実行
shuntakahashi
6
1.5k
事業フェーズの変化に対応する 開発生産性向上のゼロイチ
masaygggg
0
160
Amazon Neptuneで始める初めてのグラフDB ー グラフDBを使う意味を考える ー
satoshi256kbyte
2
250
REXML改善のその後
naitoh
0
180
Featured
See All Featured
CSS Pre-Processors: Stylus, Less & Sass
bermonpainter
354
29k
RailsConf & Balkan Ruby 2019: The Past, Present, and Future of Rails at GitHub
eileencodes
131
32k
The Invisible Side of Design
smashingmag
295
50k
Designing the Hi-DPI Web
ddemaree
278
34k
VelocityConf: Rendering Performance Case Studies
addyosmani
322
23k
Rails Girls Zürich Keynote
gr2m
93
13k
Scaling GitHub
holman
458
140k
Mobile First: as difficult as doing things right
swwweet
221
8.8k
Into the Great Unknown - MozCon
thekraken
28
1.4k
The Art of Programming - Codeland 2020
erikaheidi
48
13k
Producing Creativity
orderedlist
PRO
340
39k
Automating Front-end Workflow
addyosmani
1365
200k
Transcript
*OOPWBUPS+BQBO*OD ॴ྄ &OHJOFFS ϩάͷઃܭͯ͠·͔͢ʁPSR3ͱϩάઃܭͷ PHPΧϯϑΝϨϯεԬ2018
͓Βͤ εϥΠυSpeakerDeckʹΞοϓ͠·͕͢… ࡱӨࣗ༝ʹ͍ͯͯ͋͠Γ·ͤΜ !IBOIBO
͜ͷτʔΫͷඪ एखΤϯδχΞ தݎΤϯδχΞ ˠϩάग़ྗʹ͍ͭͯͷ͡ΊͷҰา ˠυΩυΩͯ͠Β͏
ࠓճ͓͢Δϩάग़ྗ ΞϓϦέʔγϣϯϩά ߦಈϩάΣϒαʔόͷϩάର֎ ओॲཧʹӨڹΛ༩͑ͣɺόονΣϒΞϓϦ ͷॲཧ్தͰԿΒ͔ͷใΛ֎෦ʹग़ྗ͢Δ
ࠓճͷείʔϓ֎ͷ 'MVFOUE -PHTUBTI ϩάऩू ϩάՄࢹԽ ,JCBOB &MBTUJD4FBSDI
ಋೖ
ಋೖ ͋Δ
ಋೖ εϐʔσΟʔʹ WBS@EVNQ Λॻ͍ͨΓফͨ͠Γ͢ΔएखΛܸɻ
ಋೖ
ಋೖ
ಋೖ
ಋೖ ఆৗతͳͱ͔ͷνΣοΫ ϩάग़ྗͷ͕ศརΑͱ͑Δɻ
ಋೖ ·ͬͨ͘ϐϯͱདྷͯͳ͍ͷΛ؍ଌ
ಋೖ ϩάग़ྗʹ͍ͭͯतͤͶʂ
ಋೖ ࢥ͍ฦͯ͠ΈΔͱɻ ࣗϩάग़ྗͷํ๏ͱ͔शͬͨ͜ͱͳ͍ɻ งғؾͰग़ྗ͍ͯ͠Δʜ
ಋೖ ϩάग़ྗͷΞϨίϨΛ·ͱΊͯ νʔϜͷڞ௨ೝࣝΛ࡞Γ͍ͨ σόοάγεςϜӡ༻ʹ͓͚Δڧ͍ثʹͳΔ
0VUMJOF 8IBUJTMPHHJOH 8IZZPVMPH )PXZPVMPH 3JTLPGMPHHJOH 8IBUZPVTIPVMEQSFQBSF
0VUMJOF 8IBUJTMPHHJOH 8IZZPVMPH )PXZPVMPH 3JTLPGMPHHJOH 8IBUZPVTIPVMEQSFQBSF
ϩάग़ྗͱʁ -PHHJOHJTUIFBDUPGLFFQJOHBMPH -PHpMF8JLJQFEJB ใMPH ΛͲ͔͜ʹग़ྗ͢Δ͜ͱ ఆٛ؇͍ʜ
ϩάग़ྗʹؔΘΔ༷ 3'$ TZTMPHͷ༷͔͜͜Β৭ʑͱੜ 143 -PHHFS*OUFSGBDF
ϩάग़ྗʹؔΘΔ༷ 3'$ TZTMPHͷ༷͔͜͜Β৭ʑͱੜ 143 -PHHFS*OUFSGBDF 1)1FS.VTU3FBE
143ͷ֓ཁ ͭͷ༷ ͍ͷͰͥͻ࣮ࡍʹಡΜͰ΄͍͠ IUUQTXXXQIQpHPSHQTSQTS
143ͷ֓ཁ #BTJDT 3'$४ڌͭͷϩάϨϕϧ ͭͷग़ྗϝιου
ϩάϨϕϧͱʁ EFCVH JOGP OPUJDF XBSOJOH FSSPS DSJUJDBM BMFSU FNFSHFODZ ॏେ
ϩάϨϕϧͱʁ EFCVH JOGP OPUJDF XBSOJOH FSSPS DSJUJDBM BMFSU FNFSHFODZ -0(@-&7&-XBSOJOH
ग़ྗ͞Εͳ͍
143ͷ֓ཁ .FTTBHF ϝοηʔδTUSJOH͔@@UP4USJOH Λ࣮ͨ͠PCKFDU ͦ͏Ͱͳ͚ΕɺதΛTUSJOHʹΩϟετ ϝοηʔδิ
143ͷ֓ཁ $POUFYU DPOUFYUʹԿΛ͞Ε͍͔ͯͳΔྫ֎UISPX͠ ͳ͍ɻ·ͨFSSPSXBSOJOHOPUJDFग़͞ͳ͍ &YDFQUJPOΦϒδΣΫτAFYDFQUJPOAͱ͍͏LFZ ໊Ͱηοτ͢Δ
143ͷ֓ཁ )FMQFSDMBTTFTBOEJOUFSGBDF 1TS४ڌͷ-PHΫϥεɺΠϯλϑΣʔεɺτϨΠτ ͷઆ໌
0VUMJOF 8IBUJTMPHHJOH 8IZZPVMPH )PXZPVMPH 3JTLPGMPHHJOH 8IBUZPVTIPVMEQSFQBSF
Կނϩάग़ྗΛߦ͏ͷ͔ʁ QSJOUσόοά͡Όବͳͷ͔ʁ
QSJOUσόοά ൃݟతख๏ ώϡʔϦεςΟοΫ ݟ͕͍͍ͭͯΔݪҼͷߜࠐ 5SZ&SSPSͷͯͬͱΓૣ͍ํ๏
QSJOUσόοάͷ ࠶ݱੑʹ͍͠ QSJOUফ͠Ε ͖ͬ͞ॻ͍ͨWBS@EVNQ͏ແ͍ ͳΜ͔ը໘ͷࠨ্ʹग़ͯΔʜ
QSJOUσόοάͷ ಉ͜͡ͱͷ܁ฦ ຊ൪ڥͰແཧ -B[JOFTTҧͷ෮QSJOU WBS@EVNQग़ͤ·ͤΜʜ
QSJOUσόοάͷ ΞϓϦέʔγϣϯͷӨڹ QSJOUͱFYJUͷ߹ͤ 'SBNF8PSLͷऴॲཧΛ ։ൃڥʹ͓͍ͯɺ࠶ݱͮ͠Β͍ඍົͳόάΛੜΈग़͢
ϩάग़ྗͷಛ ࠶ݱੑ͕͋Δ ղੳతͳσόοά ઃஔՕॴৗʹಉ༷ʹϩάग़ྗ มߋʹΑΔࠩҟΛޙ͔ΒղੳՄೳ
͜Μͳ࣌ϩάग़ྗ ৗʹ֬ೝ͍ͨ͠ใ όονͷ࣮ߦใ ຊ൪ڥͰݟ͍ͨใ
ৗʹ֬ೝ͍ͨ͠ใ WJFXςϯϓϨʔτʹͨ͠ "1*ݺͼग़͠ͷ։࢝ɾऴྃ ࣮ߦͨ͠42-ͱύϥϝʔλ
ຊ൪ڥͰݟ͍ͨใ ։ൃڥͰ࠶ݱ͠ͳ͍ෆ۩߹ͷݕূϩά ߈ܸݕϩά -PHJO߈ܸ ܦྼԽ͕༧ଌ͞ΕΔՕॴͷܭଌϩά
όονͷ࣮ߦใ ։࢝࣌ؒɾऴྃ࣌ؒ "#&/%࣌ͷఀࢭՕॴ ॲཧ݅ ࠶࣮ߦίϚϯυ ͜ΕຊʹΦεεϝɻ
0VUMJOF 8IBUJTMPHHJOH 8IZZPVMPH )PXZPVMPH 3JTLPGMPHHJOH 8IBUZPVTIPVMEQSFQBSF
Ͳ͏ͬͯϩάग़ྗΛߦ͏ͷ͔ʁ 143४ڌՄೳͳϥΠϒϥϦʔ .POPMPH ;FOE-PHHFS ϑϨʔϜϫʔΫ͕ఏڙ͢ΔϩΨʔ ϩάΛૉʹग़ͤΔͳΒɺ143ඇ४ڌͰྑ͍
Ͳ͏ͬͯϩάग़ྗΛߦ͏ͷ͔ʁ ΦϨΦϨϩΨʔବ͔ʁ ษڧͷͨΊͷंྠͷ࠶ൃ໌0, Ͱຊ൪ར༻Ί·͠ΐ͏
Ͳ͏ͬͯϩάग़ྗΛߦ͏ͷ͔ʁ ੜͰFSSPS@MPHؔͱ͔/( ͨͩ͠ɺօʹ߹ͬͯͷ͕͋Δ͜ ͱࢲཧղ͍ͯ͠Δ ͍Θ͕ͣͳ ͔ΓΈ͕͋Δ
Ͳ͏ͬͯϩάग़ྗΛߦ͏ͷ͔ʁ ͓ߦّͷѱ͍ϩάग़ྗఫڈ͕جຊ ඃ͕গͳ͍͏ͪʹखΛଧ͍ͬͯ͜͏ ͱ͍͑ ͷϑΥʔϚοτͱ͔ͰϞχϣΓͨ͘ͳ͍
0VUMJOF 8IBUJTMPHHJOH 8IZZPVMPH )PXZPVMPH 3JTLPGMPHHJOH 8IBUZPVTIPVMEQSFQBSF
ϩάग़ྗͷϦεΫ ϩάग़ྗʹཱͭ ͨͩ͠ɺϦεΫΛ಄ʹೖΕ͓ͯ͘ ඞཁ͕͋Δ
ϦεΫ ใ࿙͍͑ ΞϓϦέʔγϣϯ࣮ߦͷ ϩάग़ྗͷઃఆϛε ҙਤ͠ͳ͍ݸਓใऩू
ใ࿙͍͑ εϥυ IUUQTTFDVSJUZTSBEKQTUPSZ
ྫ͑͜Μͳίʔυ %#Ͱύεϫʔυ҉߸Խͯͯ͠ແ͠
ΞϓϦέʔγϣϯ࣮ߦͷ Τϥʔൃੜ࣌ͷϩάΛϝʔϧૹ৴ όάϦϦʔεͰେྔͷΤϥʔϝʔϧ ϝʔϧૹ৴Ͱ٧·ͬͯʜ Τϥʔൃੜ࣌ͷϩάΛ4MBDLͰૹ৴ όάϦϦʔεͰSZ ·͞ʹΧΦε
ઃఆϛε EFCVHϩά͕ຊ൪Ͱग़ͬͺͳ͠ େͳྔͷϩάग़ྗ ΫΤϦύϥϝʔλʔʜ ૠೖɾߋ৽σʔλ͕શ෦࿙Ӯ͍ͯ͠ΔͷͱҰॹ
ઃఆϛε ϩάΛ༗ޮ׆༻͢Δ ϩάϨϕϧͷઃఆϛε͕க໋ই
ઃఆϛε ݟ͍ͨ࣌ʹϩά͕ͳ͍ ϦϦʔεͰϩάϑΝΠϧ͕ॻ όάमਖ਼ޙʹݕূෆՄೳ ϩάͷग़ྗઌΞϓϦσΟϨΫτϦ֎ʹ
ઃఆϛε Πϯϑϥͷ͓͡͞Μ ΞϓϦέʔγϣϯϩάकඋൣғ֎ ࣗͷࣗͰकΕ
ݸਓใ ݸਓใ͕ϩάʹग़ྗ͞Ε͍ͯΔ߹ (%13ͷേଇॏ͍ͨ ϓϥΠόγʔϙϦγʔͷهࡌʁ Ϣʔβ͕ಉҙͯ͠ͳ͍ར༻/(
ݸਓใ ҙਤͤͣʹߦಈϩάΛऩूͯ͠͠·͍ͬͯ ͳ͍͔ʁόϨͳ͚Εྑ͍ͱ͍͏Ͱ ͳ͍ɻ
ҙ͖ࣝ͢ॏཁࣄ߲ ϩάग़ྗͰ͍͔ͳΔσʔλ࿙ӮՄೳ ϩάϑΝΠϧͷةݥੑΛཧղ͍ͯ͠ͳ͍ͱॏେ ͳଛࣦΛҾ͖ى͜͢Մೳੑ ͍ͯ͠ΔΞϓϦಛʹҙ
͜͏͍͏ίʔυʹԠ͢ΔΑ͏ʹʂ ͍ใΛEFCVHҎ֎Ͱग़ྗ
͜͏͍͏ίʔυʹԠ͢ΔΑ͏ʹʂ ઃఆϛεͰҰൃπϞͦ͠͏ͳϩά
ͰͲ͏͠Ζͱʁ ͏ϩάͳΜͯग़ྗ͠ͳ͍΄͏͕ʜ ͦΕҰͭͷਖ਼ղͱͯ͠ΞϦ
0VUMJOF 8IBUJTMPHHJOH 8IZZPVMPH )PXZPVMPH 3JTLPGMPHHJOH 8IBUZPVTIPVMEQSFQBSF
ԿΛܾΊ͓͚͍͍ͯͷ͔ʁ ΞϓϦέʔγϣϯ։ൃ࣌ ΞϓϦέʔγϣϯӡ༻࣌ ͦΕͧΕͷܾΊ͝ͱϩάઃܭ
ΞϓϦέʔγϣϯ։ൃ࣌ͷܾΊ͝ͱ -PHHFSͷબఆ .FTTBHFͷϧʔϧ جຊػೳʹେࠩແ͍ͷͰɺঢ়گʹ߹Θͤͯॊೈʹɻ -PHHFS͍ͬͯΕେ·͔ͳϑΥʔϚοτ߹͍ͬͯΔ ·ͣ։ൃऀͤͰྑ͍͔
ΞϓϦέʔγϣϯ։ൃ࣌ͷܾΊ͝ͱ ڞ௨ग़ྗ༰ όονϩάͷग़ྗϑΥʔϚοτ 3FBENFʹॻ͍͓͍ͯͯ͋͛·͠ΐ͏ɻ ΫΤϦϩάɺWJFXύϥϝʔλ మ൘ͰཱͭͷͰ࡞Γ·͠ΐ͏ɻ
ΞϓϦέʔγϣϯӡ༻࣌ͷܾΊ͝ͱ ڥຖͷϩάϨϕϧ ϩάϑΝΠϧͷϩʔςʔγϣϯɺӬଓԽํ๏ ։ൃڥEFCVH ຊ൪ڥXBSOJOH ΞϓϦέʔγϣϯΤϯδχΞͷʂ ޙͰղੳͰ͖ΔΑ͏ʹ͓ͯ͘͜͠ͱ
ΞϓϦέʔγϣϯӡ༻࣌ͷܾΊ͝ͱ ϩάϨϕϧઃఆͷϑΣʔϧηʔϑ Ϗϧυ࣌ʹEFCVHϨϕϧͷϩάΛআ %*Ͱۭϩάग़ྗ࣮ʹସ ϩάग़ྗઌͱग़ྗํ๏ ϝʔϧ4MBDLϒϩοΩϯά͠ͳ͍ํ๏ ಉ͡༰ͷΤϥʔϩάͷग़ྗ੍
·ͣ࠷ݶ͔Β ग़དྷͨͯͷΞϓϦͰᘳΛࢦ͢ͷແཧ ΞϓϦͷϑΣʔζʹ߹ΘͤͯɺϦεΫͱ্ खʹௐ͍ͯ͘͜͠ͱ͕ॏཁ
·ͱΊ एखΤϯδχΞͷํ ϩάग़ྗΤϥʔͷݕͱղੳΛߦ͏ڧྗͳखஈ ࡞๏ʹͷͬͱΓͭͭੵۃతʹ׆༻͠·͠ΐ͏
·ͱΊ தݎΤϯδχΞͷํ ͋ͳͨͷΞϓϦέʔγϣϯͷϩάେৎͰ͔͢ʁ υΩυΩͯͨ͠Βਅͳӡ༻Λߟ͑·͠ΐ͏ɻ
ૉఢͳϩάग़ྗੜ׆Λʂ