ドキュメント定義マトリクス

ドキュメント何を定義するか誰が使うか変更コスト最重要度
変更管理記録全変更要求の内容・申請者・影響評価・承認者・実施日の記録PM・PMO・監査時・ポストモーテム時◎ 最重要
マイグレーションスクリプトDB状態の変更定義(スキーマ変更・データ変換・ロールバック)DBA・BE・インフラ・本番リリース時○ 重要
IaCコード(Terraform等)インフラ構成の宣言的定義(サーバ・NW・ストレージ・権限)インフラ・全環境構築時○ 重要
CI/CDパイプライン定義ビルド・テスト・デプロイの自動化フロー全開発者・インフラ○ 重要
ログ設計書(実装仕様)ログレベル・フォーマット・出力先・含めるフィールド定義BE(実装)・インフラ(収集)・運用(参照)○ 重要
進捗報告書(定期)進捗状況・課題・予測完了日PM・ステークホルダー△ 記録
課題エスカレーション記録エスカレーション経緯・判断根拠・対応結果PM・PMO△ 記録

◎最重要ドキュメントの詳細

変更管理記録

何を定義するか:プロジェクト期間中に発生したすべての変更要求を追跡可能な形で記録する。変更の内容・申請者・申請日・影響評価(工数・スコープ・スケジュールへの影響)・承認者・承認日・実施結果の7項目が最低限必要だ。

なぜ変更コストが高いか:記録のないまま実施された変更は「なぜその機能が存在するのか」「誰が承認したのか」を後から追跡できなくなる。プロジェクト後半でスコープが膨らんだとき、変更管理記録がなければ誰も責任を取れない状態になる。

⚠️ 「小さな変更」こそ必ず記録する

スコープクリープは常に「小さな変更のつもり」から始まる。「ちょっとUIを変えるだけ」「フィールドを1つ追加するだけ」という変更が記録されず積み重なり、開発フェーズ後半で工数が跳ね上がるのが典型的なパターンだ。規模に関係なく全変更要求を変更管理記録に残す習慣を徹底する。

ログ設計は「ドキュメント」である

ログ設計書は「コードに埋め込まれる仕様」として、開発フェーズで必ず文書化する必要がある。

定義項目内容なぜ重要か
ログレベル定義ERROR/WARN/INFO/DEBUGの使い分け基準レベルが統一されないと運用時にアラートが機能しない
出力フォーマットJSON構造・タイムスタンプ形式・文字コードログ収集ツール(Fluentd等)の設定に影響
必須フィールドリクエストID・ユーザーID・処理時間・エラーコード障害時のトレーサビリティに直結
出力先ファイル/標準出力/ログサービス(CloudWatch等)インフラの収集設定に影響
保持期間ログの保存期間・アーカイブポリシー法令・コンプライアンス要件と連動

💡 ログ設計をコードより先に書く

「ログは実装しながら考える」というアプローチは失敗する。実装者によってログの粒度・フォーマット・フィールドがバラバラになり、運用フェーズで障害解析に使えないログが大量に出力される。ログ設計書を先に書き、実装者が参照しながらログを埋め込む順序を守る。