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
4.7k
6
Share
ログの設計してますか?PSR3とログ設計の話
PHPカンファレンス福岡2018 #phpconfuk #hall_fu
Ryo Tomidokoro
June 16, 2018
More Decks by Ryo Tomidokoro
See All by Ryo Tomidokoro
あるアーキテクチャ決定と その結果/architecture-decision-and-its-result
hanhan1978
2
620
開発者が知っておきたい複雑さの正体/where-the-complexity-comes-from
hanhan1978
8
3.5k
Spec Driven Development入門/spec_driven_development_for_learners
hanhan1978
2
1.8k
フロントエンドがTypeScriptなら、バックエンドはPHPでもいいじゃない/php-is-not-bad
hanhan1978
8
14k
どうすると生き残れないのか/how-not-to-survive
hanhan1978
17
15k
100分で本番デプロイ!Laravelで作るWebアプリケーション作成/100min_web_app_cicd
hanhan1978
1
260
PHPerのための計算量入門/Complexity101 for PHPer
hanhan1978
8
3.6k
集中して作業する技術/how_to_work_deeply
hanhan1978
65
56k
PHPでデータベースを作ってみた/create-data-with-php
hanhan1978
11
11k
Other Decks in Programming
See All in Programming
t *testing.T は どこからやってくるの?
otakakot
1
530
Vibe하게 만드는 Flutter GenUI App With ADK , 박제창, BWAI Incheon 2026
itsmedreamwalker
0
550
Laravel Nightwatchの裏側 - Laravel公式Observabilityツールを支える設計と実装
avosalmon
1
330
PCOVから学ぶコードカバレッジ #phpcon_odawara
o0h
PRO
0
260
AIエージェントで業務改善してみた
taku271
0
520
GNU Makeの使い方 / How to use GNU Make
kaityo256
PRO
16
5.6k
JAWS-UG横浜 #100 祝・第100回スペシャルAWS は VPC レスの時代へ
maroon1st
0
130
ハーネスエンジニアリングにどう向き合うか 〜ルールファイルを超えて開発プロセスを設計する〜 / How to approach harness engineering
rkaga
22
12k
10年分の技術的負債、完済へ ― Claude Code主導のAI駆動開発でスポーツブルを丸ごとリプレイスした話
takuya_houshima
0
2.5k
ハーネスエンジニアリングとは?
kinopeee
9
4.2k
CDK Deployのための ”反響定位”
watany
4
750
Kubernetes上でAgentを動かすための最新動向と押さえるべき概念まとめ
sotamaki0421
3
490
Featured
See All Featured
Designing Experiences People Love
moore
143
24k
Ecommerce SEO: The Keys for Success Now & Beyond - #SERPConf2024
aleyda
1
1.9k
Prompt Engineering for Job Search
mfonobong
0
270
Music & Morning Musume
bryan
47
7.2k
Getting science done with accelerated Python computing platforms
jacobtomlinson
2
180
Building a Scalable Design System with Sketch
lauravandoore
463
34k
Reflections from 52 weeks, 52 projects
jeffersonlam
356
21k
Helping Users Find Their Own Way: Creating Modern Search Experiences
danielanewman
31
3.2k
Paper Plane
katiecoart
PRO
1
49k
Mind Mapping
helmedeiros
PRO
1
150
We Analyzed 250 Million AI Search Results: Here's What I Found
joshbly
1
1.2k
RailsConf & Balkan Ruby 2019: The Past, Present, and Future of Rails at GitHub
eileencodes
141
35k
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ϒϩοΩϯά͠ͳ͍ํ๏ ಉ͡༰ͷΤϥʔϩάͷग़ྗ੍
·ͣ࠷ݶ͔Β ग़དྷͨͯͷΞϓϦͰᘳΛࢦ͢ͷແཧ ΞϓϦͷϑΣʔζʹ߹ΘͤͯɺϦεΫͱ্ खʹௐ͍ͯ͘͜͠ͱ͕ॏཁ
·ͱΊ एखΤϯδχΞͷํ ϩάग़ྗΤϥʔͷݕͱղੳΛߦ͏ڧྗͳखஈ ࡞๏ʹͷͬͱΓͭͭੵۃతʹ׆༻͠·͠ΐ͏
·ͱΊ தݎΤϯδχΞͷํ ͋ͳͨͷΞϓϦέʔγϣϯͷϩάେৎͰ͔͢ʁ υΩυΩͯͨ͠Βਅͳӡ༻Λߟ͑·͠ΐ͏ɻ
ૉఢͳϩάग़ྗੜ׆Λʂ