はじめに
OCI FunctionsはOracle Cloud Infrastructureが提供する、フルマネージド、高スケーラビリティ、実行時のみ課金のサーバレス実行環境(Function-as-a-Services)です。
OCI Functionsがイメージをpushするコンパートメント
Fnコマンドでは通常、存在しないリポジトリの名前でFunctionsをデプロイした場合には、ルート・コンパートメントに新規レポジトリが自動的に作成されます。
イメージをプッシュする場合は、通常、docker push .ocir.io//:というフォーマットのコマンドを使用します。ただし、「ルート・コンパートメントの初回プッシュ時にリポジトリを作成」オプションを選択し、存在しないリポジトリの名前を含むコマンドを使用してイメージをプッシュすると、新規プライベート・リポジトリがルート・コンパートメントに自動的に作成されます。
また、Fn contextによるFunctionイメージのpush先のコンパートメントについてはこちらのドキュメントに詳細が記載されています。
OCI Fucntionsの入門的な手順を解説しているOCIチュートリアルではコンパートメントを指定していないため、上記のドキュメントの通りrootコンパートメントにリポジトリが作成され、Functionイメージがpushされます。
今回は、OCIチュートリアルの内容にコンパートメントの指定を加える形で任意のコンパートメントにFunctionイメージをpushする手順を解説します。
前提
- Functionイメージのデプロイに必要なコンパートメント、VCN、認証トークンは事前に作成済とする
- オブジェクト・ストレージ・ネームスペース、コンパートメントID、認証トークンの文字列は取得済とする
- 今回使用する各種情報
- Compartment: functionsdemo
- Functionsアプリケーション: helloworld-app
- OCIRリポジトリ: demo-repo
VCNの作成や各種情報を取得する手順については今回省きますが、詳しく知りたい方はOCIチュートリアルをご参照ください。
手順
1. Functionsアプリケーションの作成
2. 特定のコンパートメントにFunctionイメージをpushする
Cloud Shellを利用して、Fn contextの設定およびFunctionの作成、デプロイをします。
4つ目のコマンドでoracle.image-compartment-id
を設定することで、リポジトリのコンパートメントを指定できます。
# --- Fn Contextの設定、OCIRへのログイン ---
# 現在使用されているcontextを確認
fn list context
# 利用しているリージョンのconextを選択する(今回は東京リージョン)
fn use context ap-tokyo-1
# FuncionがデプロイされることになるコンパートメントIDを設定する
fn update context oracle.compartment-id <compartment-ocid>
# この設定がOCIチュートリアルにはないので追加する
# OCI FunctionsがイメージのpushおよびpullするリポジトリのコンパートメントOCIDを設定する
fn update context oracle.image-compartment-id <compartment-ocid>
# OCIRを設定する
fn update context registry nrt.ocir.io/<オブジェクト・ストレージ・ネームスペース>/demo-repo
# OCI Functionsで使用するprofile名を設定する
fn update context oracle.profile "DEFAULT"
# contextの情報を確認する
fn list context
# OCIRへのログイン
docker login nrt.ocir.io
# --- Functionを作成、デプロイする ---
# 'helloworld-func'ボイラープレート・ファンクションを生成
fn init --runtime java helloworld-func
# cd hello-java
cd helloworld-func
# Functionをデプロイ
fn -v deploy --app helloworld-app
# Functionを呼び出す
fn invoke helloworld-app helloworld-func
Functionsアプリケーション、OCIRリポジトリの両方において、ちゃんと指定したコンパートメントにFunctionイメージがデプロイ出来ていることが確認できました。
参考
Fn Projectの各種コンテキストの設定やデプロイされるコンパートメントの解説はこちら
OCIチュートリアルでOCI Functionsの基本的なデプロイ方法が詳しく解説されています