9
9

More than 1 year has passed since last update.

【第3回】ChatGPTで大規模システムは作れるか?(API設計~インフラ設計編)

Last updated at Posted at 2023-03-28

経緯

この記事は以下の記事の続き。第3回です。
第1回 全体計画~要件定義編
第2回 アーキテクチャ設計~データベース設計編

前回は設計工程の途中で終了となりましたので、その続きからやっていきます。
API設計からですね。

詳細工程 担当者 説明 インプット アウトプット
アーキテクチャ設計 システムエンジニア システム全体の構成や仕組みを設計する 要件定義書、技術仕様書、利用環境の把握 アーキテクチャ設計書、インフラ設計書
画面設計 UI/UXデザイナー 画面のレイアウトやデザインを設計する 要件定義書、技術仕様書、ユーザーインタビュー 画面設計書、画面プロトタイプ
データベース設計 データベースエンジニア データベースの構造やテーブル設計を行う 要件定義書、技術仕様書、データベース仕様書 データベース設計書、ER図
API設計 システムエンジニア APIの仕様を定義する 要件定義書、技術仕様書、利用環境の把握 API仕様書
インフラ設計 システムエンジニア システムを稼働するためのサーバー構成やネットワーク設計を行う 要件定義書、技術仕様書、利用環境の把握 インフラ設計書、ネットワーク図

API設計

前回同様に、要件定義等のドキュメントを諸々インプットしてアウトプット(API仕様書)を作ってもらいます。

ここで前回のことを思い出します。
前回画面設計書を作成したとき、大量の設計書が出力されてうざかった、ということがありました。
結果的に一覧表にまとめてすっきりした、ということがあったので、今回は詳細は後回しにしてまず一覧で全量を把握していこうと思います。

API一覧

image.png
↑一覧化されていると抜け漏れチェックがしやすいですね。
例によって、また銀行口座連携機能が考慮されてないような気がしますので指摘します。
(DBからもAPIからも漏れるとか、画面だけでAPI連携するつもりなんだろか? やっぱり銀行口座連携はスコープ外にした方がよかったかなぁ。。)
image.png
画面一覧書き直させたらAPI-IDが変わったのとAPIの並び順が変わった。。現場だと大事件だけど今回は大目に見ます。

API詳細設計

全量が確認できたので一個一個見ていきます。
image.png
続き
image.png
ユーザーアカウント周りの機能は世界中で死ぬほど作られている機能だと思うので、さすがにそれっぽいものが出来てきますね。
他の機能も見ていきます。。。と思ったら、最初に作ったAPI一覧と銀行口座連携の指摘反映版のAPI一覧で転記漏れがありました。
これは良くないですね、指摘します。
image.png
なんか色々増えました。テーブルについてのCRUDを揃えました、という感じですね。
というか、当初テーブル一覧になかったテーブルが増えてるし(notificationとか)、利用するテーブルもだいぶ変わってる。。
これはちょっといただけないなぁ。。
まぁ、直すの面倒なので、後でテーブル一覧の方を直してもらうことにしよう。

全量ループ

というわけで、先ほどのAPI一覧に基づいて全量ループをかけました。こんな感じで↓。
image.png
何も考えずに全量やったんですが、後半戦は頭が悪くなってきてすっとぼけ始めました。
image.png
仕方がないので、毎回指令の中にAPI一覧全量を含めるようにしたらすっとぼけは収まりました。
また、結果を全量載せるのは辛いので載せませんが、フォーマットは結構ズレてました。
毎回フォーマットの指示をきつめに出せば多少改善はしますが、完全一致はしなかったです。
この辺りはファインチューニングで対応できるような気はするので時間があるときにやってみたいなと思います。
何はともあれ、退屈なドキュメンテーションがループぐるぐるで作成されていく様は、なかなか可能性を感じさせるものがありました。
動画、重いのでYouTubeに上げました。

API設計は以上とします。次、インフラ設計。

インフラ設計

ネットワーク図をdotで書いてもらおうと思ったんですが駄目みたいですね。
以前もフローチャート正しく書けなかったし、この辺りは苦手なんですね。
image.png
インフラ設計書の内容はまぁ普通といえば普通。
image.png
EC2立てるほどでもないかなと思ってlambda+Cloudfrontの構成に変えてもらいました。
image.png
インフラはあっさりですけど以上にします。

まとめ

今回はAPI設計書大量作成がメインどころでしたが、何とか作ってはくれました。
ただ、一覧作成時点で内容が崩れ始めたりと、複数の情報の整合性を取って物事に対応していくところは苦手みたいで、色々と限界も露呈しつつあります。
ちなみに、GPT-4でもやってみましたが、あまり大きな差異は認められませんでした。
(そもそもGPT-4は3時間で25回しか呼べないのでぐるぐるループに向かない。。早くwaitlist進んでほしい。。)

今回で一応設計工程は終わったことになりますが、設計書間の整合性が取れていなかったり、他にも色々気になるところがあるので、
次回は開発に行く前にその辺を深堀する回にしていこうかと思います。

おまけ

  • ぐるぐるループスクリプト
    一覧の通りにループさせるのはchromeのプラグインでやりました。
    他にもChatGPTの出力をマークダウンでダウンロードする機能とか、も付けてgithubにアップしようと思ったんですが、
    何故か私のgithuアカウントが村八分状態?にされていて公開できてないです。。
    一応解除申請は出してあるのでそのうち公開します。
9
9
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
9
9