前回は、イミュータブルインフラストラクチャについて説明しました。今回は、Kubernetesでも使用される、宣言型APIについて説明します。
宣言型APIとは
クラウドネイティブで使用されるマイクロサービスでは、サービス同士をAPIを使用して連携します。このAPIとして使用されるのが、宣言型APIです。
これまで使用されたAPI、サービスへ具体的に実行すべきコマンドを命令しています。このようなAPIは、命令型APIとも呼ばれます。宣言型APIは、サービスのあるべき状態、つまり最終的に得たい結果を指示します。宣言型APIを使用することで、すべてのコマンドをコントローラが制御せず、サービス側が自律的に目的の状態になるように動作します。命令型APIでは、コマンド実行時のエラーなど、意図した結果が得られない場合もあります。
Kubernetesの宣言型API
クラウドネイティブで良く使用されるKubernetesも宣言型APIを使用しています。例えば、「サービスのPod数を5にする」と命令すると、Kubernetesはコンテナ数を5にするため、自動的にコンテナの追加もしくは削除します。これを命令型APIで行うには、ユーザ側で常にコンテナ数を把握し、コンテナ数を手動で増減しすることになります。状態を宣言するため、Podが異常終了して想定の状態より少なくなった時でも、自動的にPod数を元の状態に戻します。
この続きは以下をご覧ください
(リンク »)
お問い合わせにつきましては発表元企業までお願いいたします。

