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.
→
bayashi
April 13, 2023
Programming
320
0
Share
商用アプリケーション開発基本のキ
社内の勉強会で発表した雑な資料です。
bayashi
April 13, 2023
More Decks by bayashi
See All by bayashi
複雑さを受け入れるか、拒むか? - 事業成長とともに育ったモノリスを前に私が考えたこと #RSGT2026
murabayashi
1
3.9k
エンジニアに事業やプロダクトを理解してもらうためにやってること
murabayashi
0
470
自分がLinc’wellで提供しているプロダクトを理解するためにやったこと
murabayashi
1
600
エンジニアとして関わる要件と仕様(公開用)
murabayashi
0
580
個人事業主型開発からの脱却
murabayashi
14
10k
スクラムフェスを支える配信の仕組み
murabayashi
1
1.2k
締切とはなにか、どういう効果があるのか #scrummikawa
murabayashi
0
1.6k
(新米)エンジニアリングマネージャーのしごと #RSGT2023
murabayashi
11
11k
Active Recordについてわかったことを説明するよ
murabayashi
0
530
Other Decks in Programming
See All in Programming
[2026年度第1回ORセミナー] 計画最適化ベンチャーと競技プログラミング人材
terryu16
0
200
GitHub Copilot CLIのいいところ
htkym
2
1.2k
気づいたらRubyで100作品 ー クリエイティブコーディングが生活の一部になるまで / 100 Ruby Sketches Later: How Creative Coding Became Part of My Life
chobishiba
3
500
TSKaigi 2026 TypeScriptバックエンドのオブザーバビリティ戦略 — Datadog × NestJSの実践
taiseiyamamotoan
1
210
「エンジニアインターン、どうやって取った?」準備のリアルを語るLT会 Progate BAR
akiomatic
0
100
プラグインで拡張される Context をtype-safe にする難しさと設計判断
kazupon
2
480
RailsTokyo 2026#4: AI様があれば、 Hotwireの弱点は消えるか?
naofumi
5
1k
開発体験を左右するライブラリの API 設計 - GraphQL スキーマ構築ライブラリから考える #tskaigi
izumin5210
2
1.4k
Agentic UI beyond Chats Architecture Patterns & Open Standards @ngMunich 05/2026
manfredsteyer
PRO
0
180
ECR拡張スキャンでSBOMを収集して サプライチェーン攻撃の影響調査を 爆速で終わらせてみた
akihisaikeda
2
210
OCRを使ってゲームのアイテムをデータ化する
kishikawakatsumi
0
120
プロパティの順序で型推論が壊れる!? TypeScript6.0の修正からContext-Sensitivityの仕組みを追う
bicstone
2
1.3k
Featured
See All Featured
Max Prin - Stacking Signals: How International SEO Comes Together (And Falls Apart)
techseoconnect
PRO
0
170
Performance Is Good for Brains [We Love Speed 2024]
tammyeverts
12
1.7k
Building an army of robots
kneath
306
46k
The Web Performance Landscape in 2024 [PerfNow 2024]
tammyeverts
12
1.2k
Exploring anti-patterns in Rails
aemeredith
3
380
What’s in a name? Adding method to the madness
productmarketing
PRO
24
4.1k
The Art of Programming - Codeland 2020
erikaheidi
57
14k
Agile Leadership in an Agile Organization
kimpetersen
PRO
0
160
Cheating the UX When There Is Nothing More to Optimize - PixelPioneers
stephaniewalter
287
14k
Navigating Team Friction
lara
192
16k
Java REST API Framework Comparison - PWX 2021
mraible
34
9.3k
Reflections from 52 weeks, 52 projects
jeffersonlam
356
21k
Transcript
商用アプリケーション開発 基本のキ
アプリケーション アプリケーション
アプリケーション アプリケーション みんなとデータ共有したい ...
クライアントとサーバ 通信 クライアント サーバ クライアント クライアント クライアントアプリケーション サーバアプリケーション 専用線 イントラネット
クライアントとサーバ 通信 クライアント サーバ クライアント クライアント クライアントアプリケーション サーバアプリケーション クライアントアプリケーション作るの大変 ...
みんなに配るの大変 ... 専用線 イントラネット
Webシステム(うちだとこんな感じ) 通信 AWS上の EC2とかECS ブラウザ クライアント サーバ インターネット
Webシステム
クライアントでは何でもできる 変なリクエスト送っちゃおー 生年月日0000年00 月00日ですね! はい、言われた通り 動きます!
役割の違い クライアント側の バリデーション(制御)は ユーザの補助のための機能 サーバ側の バリデーション(制御)のみが不正 なデータやリクエストを防ぐことが できる
他にも
ネットワーク通信 ネットワーク通信は色んなところで失敗する 通信障害!!! PCが落ちた!! サーバが壊れた!!
上手く動かない時のことを考える ネットワーク通信は基本的に失敗する可能性がある また他のサービスを使う場合、 失敗する可能性が結構高い確率である (メンテ時間とか)
処理が失敗したときにどう振る舞うか? 考えてみよう slackに投稿してみよう
処理が失敗したときにどう振る舞うか? - リトライ処理をする - 人間に通知をして直してもらう - ログを吐く - 勝手に直るようにする -
何もせず処理を終了する あたりが出た? どれが正解?
処理が失敗したときにどう振る舞うか? - 何もせず処理を終了する - リトライ処理をする - 人間に通知をして直してもらう あたりが出た? どれが正解? 場合による!!
処理を成功させるためにどうすればいいか 確率で失敗する(Flakey)ならリトライ処理をすれば良い 人間が対応する必要があれば通知をする 自動で回復できるなら自動で回復する できることが何もないけど把握しておきたいならログを吐く できることが何もなく把握する必要もないなら何もせず終了する 次の行動を考えて失敗時の処理を考えよう
失敗した時のことについて考える概念(一部) フェイルセーフ フェイルソフト
フェイルセーフ 故障しても大変なことにならないようにしようね → 倒れると止まるストーブ → 踏切の遮断機(故障時は重力で下がる=踏切に立ち入れないようにする)
フェイルセーフじゃない例 調光フィルムを貼ったガラス張りで、利用者がいな いときはフィルムに電気を流すことでガラスが透明 となり、トイレ内に入り鍵を閉めることで電気が流れ なくなりガラスが不透明になる仕組みとなっている。 https://encount.press/archives/394259/
フェイルソフト 故障しても(多少しょぼくなっても)動くようにしようね → エンジンが壊れたら予備エンジンが動く飛行機
テストでも テストの観点にも失敗した時のことを考えよう 正常系 準正常系 異常系
仕様 本を借りるシステム 一回に5冊まで借りれる 借りる際にはアカウント登録が必要 一日1回のみ借りれる
正常系 1冊借りたら借りれる 5冊借りたら借りれる
準正常系 0冊借りたら失敗する。ユーザに借りれない旨をメッセージで伝える 6冊借りたら失敗する。ユーザに1回5冊しか借りれないことをメッセージで伝える 会員じゃなかったら失敗する。 余談: 失敗時のエラーメッセージはユーザの次の行動につながるようにしようね
異常系 アプリケーションが動いているサーバがぶっ壊れたときに - DBへのアクセスができなくなること - 他のサーバが自動的に復旧してくれること - 500画面が正常に表示されること
前職で聞いた格言 正常系が動くようになって、ようやく2割