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
Hunting Vulnerabilities in Symfony with LLMs
vinceamstoutz
0
540
過去最大のMCPアップデート! 2026-07-28 RC版の謎に迫る
licux
6
240
JavaDoc 再入門
nagise
0
320
The ROI of Quarkus for Spring Boot Applications
hollycummins
0
110
LLM Plugin for Node-REDの利用方法と開発について
404background
0
170
Spec Driven Development | AI Summit Lisbon
danielsogl
PRO
0
180
[2026年度第1回ORセミナー] 計画最適化ベンチャーと競技プログラミング人材
terryu16
0
260
運用エージェントは "作る" から "育てる" へ - 記憶と自己進化の3層設計パターン / self-evolving-agents-three-layer-agent-design
gawa
12
3.6k
TypeScript+Orvalで実現する型安全かつ堅牢でスケーラブルなマルチチャネル通知基盤 / TSKaigi Night talks ~after conference~
d0riven
0
320
コンテキストの使い捨てをやめる — ビジネスルール駆動開発と miko —
ioki
0
190
Signal Forms: Beyond the Basics @ngBaguette 2026 in Paris
manfredsteyer
PRO
0
240
Spring Security 実践 ─ GraphQL APIで実務に役立つ 認証・認可 を学ぶ
wagyu
0
210
Featured
See All Featured
SEO for Brand Visibility & Recognition
aleyda
0
4.6k
sira's awesome portfolio website redesign presentation
elsirapls
0
280
The Web Performance Landscape in 2024 [PerfNow 2024]
tammyeverts
12
1.2k
The Power of CSS Pseudo Elements
geoffreycrofte
82
6.3k
Evolution of real-time – Irina Nazarova, EuRuKo, 2024
irinanazarova
9
1.4k
Build your cross-platform service in a week with App Engine
jlugia
234
18k
Being A Developer After 40
akosma
91
590k
Responsive Adventures: Dirty Tricks From The Dark Corners of Front-End
smashingmag
254
22k
Lightning talk: Run Django tests with GitHub Actions
sabderemane
0
200
The Impact of AI in SEO - AI Overviews June 2024 Edition
aleyda
5
1.1k
A Guide to Academic Writing Using Generative AI - A Workshop
ks91
PRO
1
320
What's in a price? How to price your products and services
michaelherold
247
13k
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: 問題定義、解決能⼒ • 割とチームができたばかりで、どういうチームにしていきたいか、していく べきか、から議論可能
͝ਗ਼ௌ͋Γ͕ͱ͏͍͟͝·ͨ͠