このページでは、SaaS サービスのデプロイ単位をモデル化してパッケージ化する方法について説明します。SaaS ランタイムでは、デプロイの単位はユニットの種類と呼ばれます。
個別に管理する SaaS サービスのコンポーネントごとに、1 つのユニットの種類を作成します。詳細については、次のセクション SaaS サービスのモデルを決定するをご覧ください。
必要に応じて、SaaS サービス全体に単一の単位タイプを使用して SaaS サービスを作成できます。
ユニットの種類は、ブループリントによって定義されます。ブループリントは、OCI イメージとしてパッケージ化された Terraform 構成です。ユニットの種類を作成する前に、ユニットの種類ごとにブループリントを作成する必要があります。ブループリントの作成の詳細については、ブループリントを作成してアップロードするをご覧ください。
始める前に
- SaaS アプリケーションの SaaS サービスを定義していることを確認します。
- Artifact Registry リポジトリを作成していることを確認します。
- 必要な権限を持つサービス アカウントがあることを確認します。詳細については、SaaS ランタイム サービス アカウントをご覧ください。
- 作成するユニットの種類ごとに、Terraform 構成があり、ブループリントが準備されていることを確認します。詳細については、次のセクション SaaS サービスのモデルを決定するをご覧ください。
SaaS サービスのモデルを決定する
SaaS サービスをモデル化するには、作成するユニットの種類と、これらのユニットの種類間の関係を決定する必要があります。
たとえば、VM などのインフラストラクチャ用のユニットの種類と、インフラストラクチャにデプロイされたアプリケーション用のユニットの種類の 2 つを作成できます。必要に応じて、SaaS サービス全体に単一のユニットの種類を使用して SaaS サービスを作成できます。
ユニットの種類を使用して SaaS サービスをモデル化する方法を決定するには、次の点を考慮してください。
- SaaS サービスのコンポーネント間の依存関係を確認します。たとえば、SaaS サービスに共有 Kubernetes クラスタにデプロイされたアプリケーションが含まれている場合は、ユニットの種類を使用してこの共有クラスタをモデル化することを検討してください。
- SaaS サービスのコンポーネントのリリースとメンテナンスのサイクルを検討します。インフラストラクチャなど、まとめて管理されるコンポーネントがある場合は、これらのコンポーネントを 1 つのユニットの種類でモデル化することを検討してください。
このモデルを決定したら、ユニットの種類ごとにブループリントを作成する必要があります。そのためには、次のことを行う必要があります。
- このユニットの種類に接続する Terraform 構成を特定します。必要な Terraform 構成の詳細については、SaaS ランタイムのブループリントをご覧ください。
- Terraform 構成が OCI イメージとしてパッケージ化され、Artifact Registry に push されているか、zip アーカイブまたは Git リポジトリにあることを確認します。詳細については、ブループリントを作成してアップロードするをご覧ください。
ユニットの種類ごとにブループリントがある場合は、このページの手順に沿ってユニットの種類を作成できます。
ユニットの種類を作成
ユニットの種類は、次の方法で提供される Terraform 構成を使用して作成できます。
- ZIP アーカイブ。
- Git リポジトリ。
- OCI イメージとしてパッケージ化されています。
zip アーカイブを使用してユニットの種類を作成する
zip アーカイブにある Terraform 構成を使用して単位の種類を作成するには、次の操作を行います。
ZIP アーカイブの準備の詳細については、ZIP アーカイブをアップロードするをご覧ください。
ユニットの種類を作成するには:
コンソールで、[SaaS ランタイム] > [単位の種類] に移動します。
[作成] を選択します。
[ブループリントを作成] で、[アップロード] を選択して、Terraform 構成を含む ZIP アーカイブをアップロードします。
[Browse] をクリックして、このユニットの種類の一部であるリソースまたはアプリケーションを定義する Terraform 構成を含む zip アーカイブを見つけます。
[次へ: ブループリントを構成] をクリックします。
[ブループリントの保存] ページで、次の操作を行います。
[Artifact Registry からリポジトリを選択] で、[参照] をクリックし、作成したリポジトリを選択します。
[Artifact image name] に、OCI イメージの名前を入力します。
[Infrastructure Manager terraform version] で、デプロイに使用する Terraform のバージョンを選択します。サポートされている Terraform バージョンのリストについては、サポートされている Terraform バージョンをご覧ください。
[Cloud Build サービス アカウント] で、イメージをビルドする権限を持つサービス アカウントを選択します。詳細については、アーティファクト作成サービス アカウントをご覧ください。
[次へ: ユニットの種類の詳細] をクリックします。
[ユニットの種類のプロパティを構成する] ページで、次の操作を行います。
[単位の種類名] に、単位の種類の名前を入力します。名前に使用できるのは、英小文字、数字、ハイフンのみです。
[SaaS サービス] で、このユニットの種類に関連付ける SaaS サービスを選択します。
依存関係の場合:
SaaS サービス用に作成する最初のまたは唯一の単位の種類である場合は、依存関係を追加しないでください。
このユニットの種類に依存する他のユニットの種類を作成した場合は、[依存関係を追加] を選択します。
[ユニットの種類] で、作成するユニットの種類に依存する既存のユニットの種類を選択します。
[エイリアス] に、入力変数マッピングに使用できる名前を入力します。
[完了] をクリックします。
変数のマッピングを定義する場合は、次の手順を行います。変数マッピングの詳細については、変数マッピングをご覧ください。
[入力変数と出力変数のマッピングを定義する] を選択します。
[入力変数のマッピング] の場合:
- [入力変数のマッピングを追加] を選択します。
- [変数] に、入力変数の名前を入力します。
- [マッピング タイプ] で、次のいずれかを選択します。
- 他の単位の種類からのマップへの From。
- To: 他の単位の種類にマッピングします。
- [依存関係] で、変数をマッピングする既存の単位の種類を選択します。
- [出力変数] に、出力変数の名前を入力します。
- [完了] を選択します。
別の入力変数を追加するには、[入力変数マッピングを追加] を選択して、手順を繰り返します。
出力変数のマッピングを追加する手順は次のとおりです。
- [出力変数のマッピング] タブを選択します。
- [出力変数のマッピングを追加] を選択し、入力変数のマッピングで行った手順を繰り返します。
[次へ: リリース構成] をクリックします。
[リリース名] に、リリースの名前を入力します。
省略可: デプロイするリソースにラベルを追加します。ラベルの詳細については、ラベルの概要をご覧ください。
ラベルを追加するには:
[ラベル] で [ラベルを追加] を選択します。
[キー 1] と [値 1] に、目的の Key-Value ペアを入力します。
追加するラベルごとに手順を繰り返します。
[作成] をクリックします。
これで、ユニットの種類が作成されました。別のユニットの種類を作成するには、同じ手順を繰り返し、この次のユニットの種類の Terraform 構成を含む zip アーカイブを使用します。
SaaS サービスに必要なすべてのユニットの種類を作成したら、ユニット インスタンスをデプロイできます。
Git リポジトリを使用してユニットの種類を作成する
Git リポジトリにある Terraform 構成を使用してユニットの種類を作成するには、次の手順を行います。
Terraform ファイルに Git リポジトリを使用する方法の詳細については、Git リポジトリに接続するをご覧ください。
コンソールで、[SaaS ランタイム] > [単位の種類] に移動します。
[作成] を選択します。
[ブループリントを作成] で [外部リポジトリをリンク] を選択します。
[リポジトリ] で、Terraform 構成を含む Git リポジトリを選択します。
Git リポジトリがリンクされている場合は、リストから選択します。
リポジトリがリンクされていない場合は、[新しいリポジトリをリンク] をクリックして、Developer Connect を使用してリポジトリをリンクします。
[新しい接続を作成] を選択します。
[リージョン] で、Developer Connect 接続のリージョンを選択します。Artifact Registry リポジトリに使用したリージョンと同じリージョンを使用することをおすすめします。
省略可: [KMS key] で、暗号化用の KMS 鍵を指定できます。
[Branch] に、この単位の種類に関連付ける Terraform 構成を含む Git ブランチを指定します。
[ブループリントの保存] ページで、次の操作を行います。
[Artifact Registry からリポジトリを選択] で、[参照] をクリックして、SaaS サービスで使用している Artifact Registry リポジトリを選択します。
[Artifact image name] に、OCI イメージの名前を入力します。
[Infrastructure Manager terraform version] で、デプロイに使用する Terraform のバージョンを選択します。サポートされている Terraform バージョンのリストについては、サポートされている Terraform バージョンをご覧ください。
[Cloud Build サービス アカウント] で、イメージをビルドする権限を持つサービス アカウントを選択します。詳細については、アーティファクト作成サービス アカウントをご覧ください。
[次へ: ユニットの種類の詳細] をクリックします。
[ユニットの種類のプロパティを構成する] ページで、次の操作を行います。
[単位の種類名] に、単位の種類の名前を入力します。名前に使用できるのは、英小文字、数字、ハイフンのみです。
[SaaS サービス] で、このユニットの種類に関連付ける SaaS サービスを選択します。
依存関係の場合:
SaaS サービス用に作成する最初のまたは唯一の単位の種類である場合は、依存関係を追加しないでください。
このユニットの種類に依存する他のユニットの種類を作成した場合は、[依存関係を追加] を選択します。
[ユニットの種類] で、作成するユニットの種類に依存する既存のユニットの種類を選択します。
[エイリアス] に、入力変数マッピングに使用できる名前を入力します。
[完了] をクリックします。
変数のマッピングを定義する場合は、次の手順を行います。変数マッピングの詳細については、変数マッピングをご覧ください。
[入力変数と出力変数のマッピングを定義する] を選択します。
[入力変数のマッピング] の場合:
- [入力変数のマッピングを追加] を選択します。
- [変数] に、入力変数の名前を入力します。
- [マッピング タイプ] で、次のいずれかを選択します。
- 他の単位の種類からのマップへの From。
- To: 他の単位の種類にマッピングします。
- [依存関係] で、変数をマッピングする既存の単位の種類を選択します。
- [出力変数] に、出力変数の名前を入力します。
- [完了] を選択します。
別の入力変数を追加するには、[入力変数マッピングを追加] を選択して、手順を繰り返します。
出力変数のマッピングを追加する手順は次のとおりです。
- [出力変数のマッピング] タブを選択します。
- [出力変数のマッピングを追加] を選択し、入力変数のマッピングで行った手順を繰り返します。
[次へ: リリース構成] をクリックします。
[リリース名] に、リリースの名前を入力します。
省略可: デプロイするリソースにラベルを追加します。ラベルの詳細については、ラベルの概要をご覧ください。
ラベルを追加するには:
[ラベル] で [ラベルを追加] を選択します。
[キー 1] と [値 1] に、目的の Key-Value ペアを入力します。
追加するラベルごとに手順を繰り返します。
[作成] をクリックします。
これで、ユニットの種類が作成されました。別のユニットの種類を作成するには、同じ手順を繰り返し、この次のユニットの種類の Terraform 構成を含む Git リポジトリを使用します。
SaaS サービスに必要なすべてのユニットの種類を作成したら、ユニット インスタンスをデプロイできます。
既存のイメージを使用してユニットの種類を作成する
既存のブループリント(OCI イメージ)を使用してユニットの種類を作成する手順は次のとおりです。
OCI イメージのビルドの詳細については、以下をご覧ください。
コンソールで、[SaaS ランタイム] > [単位の種類] に移動します。
[作成] を選択します。
[ブループリントを作成] で、[Artifact Registry から既存のイメージを選択する] を選択します。
[次へ: ブループリントを構成] をクリックします。
[ブループリントの保存] ページで、次の操作を行います。
[Artifact Registry から既存のブループリントを選択または入力する] の場合:
[参照] をクリックします。
Terraform 構成を含むイメージに移動します。
[選択] をクリックします。
[次へ: ユニットの種類の詳細] をクリックします。
[ユニットの種類のプロパティを構成する] ページで、次の操作を行います。
[単位の種類名] に、単位の種類の名前を入力します。名前に使用できるのは、英小文字、数字、ハイフンのみです。
[SaaS サービス] で、このユニットの種類に関連付ける SaaS サービスを選択します。
依存関係の場合:
SaaS サービス用に作成する最初のまたは唯一の単位の種類である場合は、依存関係を追加しないでください。
このユニットの種類に依存する他のユニットの種類を作成した場合は、[依存関係を追加] を選択します。
[ユニットの種類] で、作成するユニットの種類に依存する既存のユニットの種類を選択します。
[エイリアス] に、入力変数マッピングに使用できる名前を入力します。
[完了] をクリックします。
変数のマッピングを定義する場合は、次の手順を行います。変数マッピングの詳細については、変数マッピングをご覧ください。
[入力変数と出力変数のマッピングを定義する] を選択します。
[入力変数のマッピング] の場合:
- [入力変数のマッピングを追加] を選択します。
- [変数] に、入力変数の名前を入力します。
- [マッピング タイプ] で、次のいずれかを選択します。
- 他の単位の種類からのマップへの From。
- To: 他の単位の種類にマッピングします。
- [依存関係] で、変数をマッピングする既存の単位の種類を選択します。
- [出力変数] に、出力変数の名前を入力します。
- [完了] を選択します。
別の入力変数を追加するには、[入力変数マッピングを追加] を選択して、手順を繰り返します。
出力変数のマッピングを追加する手順は次のとおりです。
- [出力変数のマッピング] タブを選択します。
- [出力変数のマッピングを追加] を選択し、入力変数のマッピングで行った手順を繰り返します。
[次へ: リリース構成] をクリックします。
[リリース名] に、リリースの名前を入力します。
省略可: デプロイするリソースにラベルを追加します。ラベルの詳細については、ラベルの概要をご覧ください。
ラベルを追加するには:
[ラベル] で [ラベルを追加] を選択します。
[キー 1] と [値 1] に、目的の Key-Value ペアを入力します。
追加するラベルごとに手順を繰り返します。
[作成] をクリックします。
これで、ユニットの種類が作成されました。別のユニットの種類を作成するには、同じ手順を繰り返し、この次のユニットの種類の Terraform 構成を含む OCI イメージを使用します。
SaaS サービスに必要なすべてのユニットの種類を作成したら、ユニット インスタンスをデプロイできます。
次のステップ
- SaaS サービスをモデル化したら、ユニット インスタンスをデプロイできます。
- SaaS ランタイムの詳細については、SaaS ランタイムの概要をご覧ください。
- SaaS Runtime の使用時に必要なサービス アカウントの詳細については、サービス アカウントをご覧ください。