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
Laravelのセッション管理でフレームワークの オーバーライドが必要になった話
Search
TaikiKawamura
October 11, 2021
Programming
600
0
Share
Embed
Copy iframe code
Copy JS code
Copy link
Start on current slide
Laravelのセッション管理でフレームワークの オーバーライドが必要になった話
TaikiKawamura
October 11, 2021
More Decks by TaikiKawamura
See All by TaikiKawamura
Laravelでのキャッシュの持ち方とAWS Fargateやイミュータブルインフラとの向き合い方
taikikawamura
1
630
Other Decks in Programming
See All in Programming
Lessons from Spec-Driven Development
simas
PRO
0
170
Make SRE Operations Easier with Azure SRE Agent
kkamegawa
0
5.3k
RTSPクライアントを自作してみた話
simotin13
0
530
「AIで開発し、AIを届ける」をEvalでつなぐ 〜AIネイティブに始めるプロダクト開発の実践〜 / Connecting "Develop with AI, deliver AI" with Eval
rkaga
4
4.9k
肥大化するレガシーコードに立ち向かうためのインターフェース分離と依存の逆転 / JJUG CCC 2026 Spring
hirokunimaeta
0
530
Vue × Nuxt × Oxc どこまで使える?実運用の現在地
andpad
0
170
Oxlintのカスタムルールの現況
syumai
6
1.1k
技術記事、 専門家としてのプログラマ、 言語化
mizchi
2
540
ユニットテストの先へ:テスト技法で要求・仕様を整理するJava開発実践 / Beyond_Unit_Testing_Practical_Java_Development_Techniques_for_Organizing_Requirements_and_Specifications
shimashima35
0
390
TypeScript+Orvalで実現する型安全かつ堅牢でスケーラブルなマルチチャネル通知基盤 / TSKaigi Night talks ~after conference~
d0riven
0
320
AI時代のUIはどこへ行く?その2!
yusukebe
21
7k
Swiftのレキシカルスコープ管理
kntkymt
0
220
Featured
See All Featured
The Hidden Cost of Media on the Web [PixelPalooza 2025]
tammyeverts
2
330
What Being in a Rock Band Can Teach Us About Real World SEO
427marketing
0
250
Producing Creativity
orderedlist
PRO
348
40k
Building the Perfect Custom Keyboard
takai
2
790
The #1 spot is gone: here's how to win anyway
tamaranovitovic
2
1.1k
Six Lessons from altMBA
skipperchong
29
4.3k
Self-Hosted WebAssembly Runtime for Runtime-Neutral Checkpoint/Restore in Edge–Cloud Continuum
chikuwait
0
580
Performance Is Good for Brains [We Love Speed 2024]
tammyeverts
12
1.7k
Applied NLP in the Age of Generative AI
inesmontani
PRO
4
2.3k
Fantastic passwords and where to find them - at NoRuKo
philnash
52
3.7k
AI Search: Where Are We & What Can We Do About It?
aleyda
0
7.6k
Beyond borders and beyond the search box: How to win the global "messy middle" with AI-driven SEO
davidcarrasco
3
150
Transcript
© Copyright 2021 Relic Inc. All rights reserved. -BSBWFMͷηογϣϯཧͰϑϨʔϜϫʔΫͷ ΦʔόʔϥΠυ͕ඞཁʹͳͬͨ
גࣜձࣾ3FMJDՏଜ ଠथ
ࣗݾհ • 河村 太樹(かわむら たいき) • 株式会社Relic テクノロジープラットフォームグループ マネージャー
• 主としている開発業務 • バックエンド開発 • インフラ構築・SRE • まれにVuexの部分も書いたり • 趣味 • バイク・ドライブ • 酒 • マンガ • キャンプ・BBQ • 軽い登⼭←New!!
ޠͷ࢝·Γ • ある⽇河村くんは某社にジョインし、2,3カ⽉後にリリースされる案件のPJに配属され ました • ⾯談では「インフラ構築得意です」と⾔っていたので検証環境と本番環境の構築も頼ま れました • 検証環境を作ったのでいじってもらったのですが、なんかセッションが保持されない!
と⾔われました。確かに河村くんはインフラ構築やってきた⼈ですが、久しぶりに1か らのサービスで作ったので、「あぁ、ローカルじゃない複数台構成のときにどうするか 抜けてたわ」となったのでした・・・
-BSBWFM ʹݶΒͣ ͷηογϣϯσʔλཧํ๏ • file • cookie • database
• memcached/redis • array • (Laravelにあるだけでリクエスト間で保持されないため、除外)
ͲΕΛ͍·͔͢ʁ • file • 本番等で複数台サーバがあるときに、特定のサーバに⾏かないといけない • スティッキーセッションを使えば解決するけれども、インフラエンジニアとして は、そもそもWebサーバがステートフルである状態に精神が耐えられない •
cookie • ⼀⾒楽そうだが、サイズに上限がある&実際に簡単に到達したので本番⽤途では 不適 • ブラウザによって異なるらしいが、4096byteが上限なのもあり、あてにはで きない • database • 無難案ではある • インフラエンジニアとしてはリレーショナルでもないデータをRDBで管理したく ない • memcached/redis • 難が⼀番なく、個⼈的におすすめ。
͡Ό͋3FEJTΛ͓͏ʂ • 使えれば問題なかったが、のっぴきならない?事情で使えなかった
͡Ό͋EBUBCBTFΛ͓͏ • 苦悩の始まりだった
Τϥʔ͕ग़ͨ
Կ͕ىͬͨ͜ʁ • Databaseでセッションを管理するときだけ、なぜか頑張ってセッションには必要な さそうなデータを取得しようとする • このサービスではユーザと管理者のセッションを両⽅管理していた • 取りたいデータがとれなかった •
どちらかがなければ・・・
ࢀߟɿ$BDIF#BTFE'JMF4FTTJPO)BOEMFS
ࢀߟɿݩͷ%BUBCBTF4FTTJPO)BOEMFS
Ͳ͏ͬͯղܾͨ͠ʁ • DatabaseSessionHandlerをオーバーライド • SessionServiceProvidorを作り、オーバーライドしたSessionHandlerを使うように指 定する • configのprovidersに登録する •
sessionのドライバーにオーバーライドしたドライバーを指定する
DatabaseSessionHandlerをオーバーライド
DatabaseSessionHandlerをオーバーライド(元)
SessionServiceProvidorを作り、オーバーライ ドしたSessionHandlerを使うように指定する
configのprovidersに登録する
sessionのドライバーにオーバーライドしたドラ イバーを指定する
·ͱΊ • セッションデータ管理はRedisとかを使いましょう(笑) • のっぴきならない事情があったらオーバーライドしたドライバを依存性注⼊しま しょう!
͓Βͤ ൪એ • Relicのテクノロジープラットフォームグループ絶賛募集中です!! • バックエンドアプリケーション開発の経験がある⽅ • ミドルウェアセットアップ、チューニングの経験がある⽅ •
AWSの経験がある⽅ • フロントも触れます、な⽅ • SREの領域だけでなく共通基盤開発、開発⽀援システムを作ったり作ろうとしたり • ⾯⽩ポイント • Relicはまだまだ成⻑途中で課題がいっぱいいっぱい • 解決したらきっと⼤幅⼯数減、売上増が⾒込める! • どこか特定の領域だけでなく、全体最適を求めます • X: 全部の知識を詳しく知ってほしい、フルスタックエンジニア • O: 抽象的に必要なことを求める思考⼒ • O: 問題定義、解決能⼒ • 割とチームができたばかりで、どういうチームにしていきたいか、していく べきか、から議論可能
͝ਗ਼ௌ͋Γ͕ͱ͏͍͟͝·ͨ͠