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
[2023/09/15]ER図クエスト 過ぎ去りしドキュメントを求めて 〜複雑性に眠る秘宝〜
Search
Sponsored
·
Your Podcast. Everywhere. Effortlessly.
Share. Educate. Inspire. Entertain. You do you. We'll handle the rest.
→
tosite
September 21, 2023
Programming
900
0
Share
[2023/09/15]ER図クエスト 過ぎ去りしドキュメントを求めて 〜複雑性に眠る秘宝〜
7th長崎QDG
https://nagasaki-it-engineers.connpass.com/event/263690/
tosite
September 21, 2023
More Decks by tosite
See All by tosite
[2026-03-07]あの日諦めたスクラムの答えを僕達はまだ探している。〜守ることと、諦めることと、それでも前に進むチームの話〜
tosite
0
570
[2026-02-26]Road to NEXT CRE 〜SRE活動を通して見つけた、次世代CRE組織の在り方SP〜
tosite
0
180
[2026-12-12]あの日僕が見た胡蝶の夢 〜人の夢は終わらねェ AIによるパフォーマンスチューニングのすゝめ〜
tosite
0
940
[2025-02-07]生成AIで変える問い合わせの未来 〜チームグローバル化の香りを添えて〜
tosite
1
1.3k
[2024/10/25]CREの守護者たち 〜DevOps×シフトレフト - 俺またプロダクト救っちゃいました!?〜
tosite
0
1.9k
[2024/07/11]Guardianとして生まれ変わった俺は攻めと守りの運用で無双する 〜守りの天才が考える、攻めの運用術〜
tosite
0
1.4k
[2024/04/23]tbls活用事例 〜 ビューポイントから データベースを整理してみた話 〜
tosite
0
690
[2022/12/07]この素晴らしいアプリケーションにテストコードを
tosite
0
81
[2022/03/25]コミュニティから学ぶエンジニアリング
tosite
0
550
Other Decks in Programming
See All in Programming
10 Tips of AWS ~Gen AI on AWS~
licux
5
390
Claude Code × Gemini × Ebitengine ゲーム制作素人WebエンジニアがGoでゲームを作った話
webzawa
0
130
PDI: Como Alavancar Sua Carreira e Seu Negócio
marcelgsantos
0
120
KagglerがMixSeekを触ってみた
morim
0
380
PicoRuby for IoT: Connecting to the Cloud with MQTT
yuuu
2
150
의존성 주입과 모듈화
fornewid
0
140
AIベース静的検査器の偽陽性率を抑える工夫3選
orgachem
PRO
3
160
Kingdom of the Machine
yui_knk
2
210
CDK Deployのための ”反響定位”
watany
4
760
実用!Hono RPC2026
yodaka
2
210
Oxlintとeslint-plugin-react-hooks 明日から始められそう?
t6adev
0
260
ファインチューニングせずメインコンペを解く方法
pokutuna
0
310
Featured
See All Featured
Lightning Talk: Beautiful Slides for Beginners
inesmontani
PRO
1
520
Jess Joyce - The Pitfalls of Following Frameworks
techseoconnect
PRO
1
130
Understanding Cognitive Biases in Performance Measurement
bluesmoon
32
2.9k
A Soul's Torment
seathinner
6
2.7k
Heart Work Chapter 1 - Part 1
lfama
PRO
5
35k
GraphQLの誤解/rethinking-graphql
sonatard
75
12k
Docker and Python
trallard
47
3.8k
Paper Plane (Part 1)
katiecoart
PRO
0
6.6k
Unlocking the hidden potential of vector embeddings in international SEO
frankvandijk
0
770
The Cost Of JavaScript in 2023
addyosmani
55
9.8k
Organizational Design Perspectives: An Ontology of Organizational Design Elements
kimpetersen
PRO
1
680
"I'm Feeling Lucky" - Building Great Search Experiences for Today's Users (#IAC19)
danielanewman
231
23k
Transcript
ER図クエスト 過ぎ去りしドキュメントを求めて 〜複雑性に眠る秘宝〜 株式会社マネーフォワード クラウド経費本部 プロダクト開発部 手島 尚人 /
tosite 2023-09-15 7th長崎QDG DEJIMAメッセ長崎
初めまして ER図クエスト 過ぎ去りしドキュメントを求めて 〜複雑性に眠る秘宝〜
None
株式会社マネーフォワード クラウド経費本部 プロダクト開発部 バックエンドエンジニア 手島 尚人 / tosite
趣味: キャンプ・登山・料理・ドライブ・温泉 三線 ← New!
福岡から来ました! 前々職の関係で5年ほど長崎に住んでいました ER図クエスト 過ぎ去りしドキュメントを求めて 〜複雑性に眠る秘宝〜
JaSST'23 Kyushu の実行委員長やってます! https://www.jasst.jp/symposium/jasst23kyushu.html
2023-11-02に 福岡で開催 予定なので興味ある方はぜひ! https://www.jasst.jp/symposium/jasst23kyushu.html
本題: 起 ここまで0:45
今年の8月 からマネーフォワードでの キャリアをスタートしました ER図クエスト 過ぎ去りしドキュメントを求めて 〜複雑性に眠る秘宝〜
皆さんは入社して まず何をしますか? ER図クエスト 過ぎ去りしドキュメントを求めて 〜複雑性に眠る秘宝〜
ER図クエスト 過ぎ去りしドキュメントを求めて 〜複雑性に眠る秘宝〜
times芸人業ですね ER図クエスト 過ぎ去りしドキュメントを求めて 〜複雑性に眠る秘宝〜 チームリーダーからの評価
…ですが 今日話したいのはその話ではなく… ER図クエスト 過ぎ去りしドキュメントを求めて 〜複雑性に眠る秘宝〜
まずやることは ドメイン知識を身につける ところからだと思います ER図クエスト 過ぎ去りしドキュメントを求めて 〜複雑性に眠る秘宝〜
では皆さんはどうやって ドメインを理解しますか? ER図クエスト 過ぎ去りしドキュメントを求めて 〜複雑性に眠る秘宝〜
仕様書やドキュメントを読む!
ドキュメントが充実している プロダクトならいざしらず、必要十分な ドキュメントがない場合もあります 理想と現実 ER図クエスト 過ぎ去りしドキュメントを求めて 〜複雑性に眠る秘宝〜
コードから全てを理解する
配属当初から全てのコードを網羅的に 読み込むのはなかなかに厳しいと思います 木は見えるけど森は見えない ER図クエスト 過ぎ去りしドキュメントを求めて 〜複雑性に眠る秘宝〜
じゃあどうするの?
データベースから 仕様を理解する ことが早いと思っています 私の経験に基づいた一例ですが… ER図クエスト 過ぎ去りしドキュメントを求めて 〜複雑性に眠る秘宝〜
そんな私がマネーフォワードに入社して1ヶ月 どのような取り組みをしてきたかを お話ししようと思います ER図クエスト 過ぎ去りしドキュメントを求めて 〜複雑性に眠る秘宝〜
本題: 承 ここまで2:00
データベースの仕様書と言えば 真っ先に思い浮かぶものがありますね ER図クエスト 過ぎ去りしドキュメントを求めて 〜複雑性に眠る秘宝〜
そう、ER図ですね ER図クエスト 過ぎ去りしドキュメントを求めて 〜複雑性に眠る秘宝〜
でも作るの大変だし 何よりメンテが大変… 大変じゃない? https://github.com/k1LoW/tbls
私は tblsというOSS をこの上なく愛しています https://github.com/k1LoW/tbls
端的に言えば データベースドキュメント 自動生成ツール 開発者の方は「Document as Code」というキーワードを使われています https://speakerdeck.com/k1low/phpconfuk-2023
https://github.com/k1LoW/tbls 参考: 出力イメージ
仕様理解・開発スピードの向上 を目的としてこのツールの導入を進めました ER図クエスト 過ぎ去りしドキュメントを求めて 〜複雑性に眠る秘宝〜
実装イメージ https://github.com/k1LoW/tbls
Phase 1. ローカルに ドキュメント生成環境を準備 https://github.com/k1LoW/tbls
Phase 1. ローカルにドキュメント生成環境を準備 ER図クエスト 過ぎ去りしドキュメントを求めて 〜複雑性に眠る秘宝〜 tblsのインストールと ymlファイルを準備しただけ!
あとはMakefileに便利コマンドを 追加した程度の開発 1.ローカルのDBをマイグレーション ファイルから構築 2.tbls.ymlを作成 3.コマンドを実行してデータベース ドキュメントを生成
Phase 2. CIでドキュメントの ビハインドを検知する https://github.com/k1LoW/tbls
Phase 2. CIでドキュメントのビハインドを検知する ER図クエスト 過ぎ去りしドキュメントを求めて 〜複雑性に眠る秘宝〜 CIで利用されるテーブルは常に 最新になることを利用
コミットされているドキュメントと 最新のドキュメントに差分がある 場合はCIを落とすようにした 1.CIのDBをマイグレーション ファイルから構築 2.CIのデータベースドキュメントを生成 3.CIとコミットしたデータベース ドキュメントの差分を検知
ER図が作られただけではなく データベースドキュメントが 最新の状態に保たれる 仕組みが構築できました ER図クエスト 過ぎ去りしドキュメントを求めて 〜複雑性に眠る秘宝〜
ドキュメントを最新の状態に 維持し続けていくのが一番難しい… ここを仕組みで解決しました ER図クエスト 過ぎ去りしドキュメントを求めて 〜複雑性に眠る秘宝〜
更にビハインド発生時の マニュアルを整備する ことで他の開発者向けに情報を残しました ER図クエスト 過ぎ去りしドキュメントを求めて 〜複雑性に眠る秘宝〜
これでデータベース ドキュメントについては完璧! ER図クエスト 過ぎ去りしドキュメントを求めて 〜複雑性に眠る秘宝〜
本題: 転 ここまで4:00
…というわけではなく、 まだまだ課題は残っています ER図クエスト 過ぎ去りしドキュメントを求めて 〜複雑性に眠る秘宝〜
テーブルごとの意味を持つまとまりを どう表現するかが課題です 例えばユーザーの基本情報が格納されているテーブル群だったり 契約情報がまとまっているテーブル群だったり… ER図クエスト 過ぎ去りしドキュメントを求めて 〜複雑性に眠る秘宝〜
tblsには「ラベル」 という概念があります ER図クエスト 過ぎ去りしドキュメントを求めて 〜複雑性に眠る秘宝〜
テーブルにラベルを付与して ラベル単位でもドキュメントを出力する 仕組みを検討しています 更に開発者フレンドリーなドキュメントが生成できますね ER図クエスト 過ぎ去りしドキュメントを求めて 〜複雑性に眠る秘宝〜
他にも「Viewpoints」という 概念を用いてドキュメントを追加する こともできるでしょう https://speakerdeck.com/k1low/phpconfuk-2023?slide=34
また、他のアプローチとして モデルに定義されている 定義を機械的に収集した上で 反映させることもできそうです https://speakerdeck.com/k1low/phpconfuk-2023?slide=34
ツールを入れて終わり ではなく ドキュメントを整備し続ける ことが大事ですね https://speakerdeck.com/k1low/phpconfuk-2023?slide=34
本題: 結 ここまで4:30
以上の取り組みによって アプリケーションの仕様を データベースから理解する ことができるようになりました ER図クエスト 過ぎ去りしドキュメントを求めて 〜複雑性に眠る秘宝〜
ドキュメントは宝の山 だと思っています ER図クエスト 過ぎ去りしドキュメントを求めて 〜複雑性に眠る秘宝〜
今回取り入れた仕組みを通して オンボーディングの高速化などに 役立てばいいなと思っています ER図クエスト 過ぎ去りしドキュメントを求めて 〜複雑性に眠る秘宝〜
みなさんもドキュメント化 やっていきましょう💪 ER図クエスト 過ぎ去りしドキュメントを求めて 〜複雑性に眠る秘宝〜
終わりに ここまで4:50
マネーフォワード福岡拠点では 一緒に働ける仲間を募集しています! https://hrmos.co/pages/moneyforward/jobs?category=1666323298559537153 ER図クエスト 過ぎ去りしドキュメントを求めて 〜複雑性に眠る秘宝〜
福岡開発拠点のサイトもあるので ぜひご覧ください! https://fukuoka.moneyforward.com ER図クエスト 過ぎ去りしドキュメントを求めて 〜複雑性に眠る秘宝〜
一緒にドキュメント化を 進めていきたいという方は ぜひお声がけください ER図クエスト 過ぎ去りしドキュメントを求めて 〜複雑性に眠る秘宝〜
ご清聴ありがとう ございました! ER図クエスト 過ぎ去りしドキュメントを求めて 〜複雑性に眠る秘宝〜