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
フレームワークのソースコードから知識を深める
Search
Sponsored
·
SiteGround - Reliable hosting with speed, security, and support you can count on.
→
Tomoki Kawajiri
September 21, 2022
Technology
840
0
Share
Embed
Copy iframe code
Copy JS code
Copy link
Start on current slide
フレームワークのソースコードから知識を深める
https://rakus.connpass.com/event/256456/
Tomoki Kawajiri
September 21, 2022
More Decks by Tomoki Kawajiri
See All by Tomoki Kawajiri
プロダクトの成長に伴うAWSの利用サービスとアーキテクチャの変遷
weistom
0
840
Other Decks in Technology
See All in Technology
関西に縁あるMicrosoft MVPsが語るCopilotの未来
kasada
0
1.2k
Platform Engineering as a Product: Criteria for Improvement and Multi-Tenant Design
kumorn5s
0
520
もりもり新機能を一挙紹介! AgentCoreに入門して、AWS上にAIエージェントを構築しよう
minorun365
PRO
6
850
新アーキテクチャ「TiDB X」解説とDedicated比較 TiDB Cloud Premiumのゲーム運用活用を検証
staffrecruiter
0
120
個人の発見を、組織の知恵に 〜生成AI活用を"探索"から"組織の仕組み"へ〜
kintotechdev
3
1.1k
AI駆動開発が変える、大規模開発の前提 ーHuman in the Loop から Human on the Loop へ / AIE2026
visional_engineering_and_design
28
19k
OCI Oracle AI Database Services新機能アップデート(2026/03-2026/05)
oracle4engineer
PRO
0
290
トークン数だけでは測れない — Claude Code 組織展開の効果検証から学んだこと
makikub
0
140
AI活用を推進するために ファインディが下した、一つの小さな決断
starfish719
0
270
React、まだ楽しくて草
uhyo
7
4.2k
データ基盤をDataformで整えた話 〜 開発環境を添えて 〜
takapy
0
130
「気づいたら仕事が終わっている」バクラクAIエージェント本番運用の裏側 / layerx-bakuraku-aie2026
yuya4
19
11k
Featured
See All Featured
The Hidden Cost of Media on the Web [PixelPalooza 2025]
tammyeverts
2
330
The #1 spot is gone: here's how to win anyway
tamaranovitovic
2
1.1k
Redefining SEO in the New Era of Traffic Generation
szymonslowik
1
330
How to build an LLM SEO readiness audit: a practical framework
nmsamuel
1
770
Leveraging LLMs for student feedback in introductory data science courses - posit::conf(2025)
minecr
1
280
Design in an AI World
tapps
1
230
HDC tutorial
michielstock
2
690
Deep Space Network (abreviated)
tonyrice
0
170
Jamie Indigo - Trashchat’s Guide to Black Boxes: Technical SEO Tactics for LLMs
techseoconnect
PRO
0
160
ReactJS: Keep Simple. Everything can be a component!
pedronauck
666
130k
Measuring & Analyzing Core Web Vitals
bluesmoon
9
860
Designing for Performance
lara
611
70k
Transcript
フレームワークのソースコードから 知識を深める 株式会社おてつたび 川尻智樹
株式会社おてつたび リードエンジニア 川尻 智樹 @tomoki_kawajiri 前職の楽天のアクセラレーションプログラムを きっかけに代表の永岡と出会い、創業当初か らプロダクト開発全般に携わる。 現在は Rails
と React、楽天時代はバックエンド メインで Java や Python で開発
短期的・季節的な人手不足で困っている地域の方々と、地域に 興味がある方が出会えるマッチングプラットフォーム おてつたび 登録ユーザー数は2.3万人、 受入先は全国47都道府県 700事業者に拡大
こんなこと思ったことありませんか? • 大規模アプリや長期的にアプリを運用するためには、どのよう な設計がベストなのか • 既存システムやフレームワークに慣れて、同じような設計や コーディングスタイルになっている
参考書や記事を読んでも知識は広がるが 実運用をあまりイメージできない。。 こんなこと思ったことありませんか?
フレームワークのコードを追う フレームワークは情報の宝庫 何が得られるのか • 設計パターンの参考になる • 可読性について考えさせられる • フレームワークの知識が深まる •
デバッグスキルが上がる
設計パターンの参考になる • 依存関係 ◦ クラス同士の依存関係から、責務の分離の単位や継承の 関係性を探る • 全体像から把握 ◦ 点ではなく線でデータの受け渡しの流れを追えるので、新
たなレイヤーや概念に出会える • 新しい概念に出会えて実装方法もイメージもつけられる
設計パターンの参考になる 明確な責務の分離 ビジネスロジックのカプセル化 MVCと豊富な機能を提供 最低限の下地で柔軟性が高い おてつたびでは、ビジネスロジックがモデルやコントローラーに散らばっていた り、Fat化により保守性が下がっていた実情をTrailblazerの思想を一部導入する ことで改善しました
可読性について考えさせられる • ワンラインで書けるが、敢えて意味が分かる変数に代入して 複数行にしている • 行数は増えても、使用頻度の低いメソッドよりは高いメソッドを 使っている • 用途が違う場合は共通化していない などなど
フレームワークの知識が深まる • 新たなメソッドや応用パターンの出会い • コメントから正しい使い方を知る • 知らない設定値や継承できるクラス・メソッドが見つかり、選択 の幅が広がる
デバッグスキルが上がる • エラー内容から原因箇所へ早く辿り着けるようになる ◦ エラーメッセージやエラーが発生したクラス名に見覚えが ある ◦ データの流れを把握しているので、最短ルートで追うことが できる
デバッグスキルが上がる ひいてはこれを使うとこのエラーハンドリングも必要だと事前に気 づけるようになり未然に防げるようになる
まとめ 答えは全てソースコードの中にある • フレームワークは大きなソースコードの塊と捉える、スケール できる設計にするために大事な責務の分離や可読性の参考・ 反面教師になる • 将来発生しそうな問題点を知ることができる
まとめ 可読性 • 大規模アプリをチームで運用するにあたり可読性を下げる要因 • 深すぎる継承や依存によるブラックボックス化 保守性 • 最小限でコード修正できる書き方 •
ユースケースが違う場合は冗長を許容する • フレームワークの理解が深まりるので、多くの選択肢からソリューションを 提供できる
おてつたびでは、新しい旅の形を一緒に作っていく仲間を募集中です まずはカジュアルにお話ししましょう! 会社概要 Meety ありがとうございました