こんにちは。cloud.config Divの神田です。
今回は構築中に遭遇した、App Service Environment(ASE)にデプロイしたFunction Appが、
バックアップから復元できなかった問題について書きます。
インフラ構成
今回のインフラ構成は以下の画像の通りです。
内部ASEにFunction Appを作成し、ASEが割り当てられているサブネットから外部へのアクセスを、
Route Tableを用いてAzure Firewall経由で行うように構成します。
また、Function AppのバックアップをStorage Accountに格納するようにします。
data:image/s3,"s3://crabby-images/8e4a6/8e4a66fc0175f9008249baaef5edf11ab0955a6b" alt=""
data:image/s3,"s3://crabby-images/58c99/58c99baad7c6d3c59f89963605b3479c0c244351" alt=""
data:image/s3,"s3://crabby-images/d9a2d/d9a2d4ee8a7083b0f62ed5359bd4ec25a9447ca8" alt=""
data:image/s3,"s3://crabby-images/8df5e/8df5efe0125986b5dba734907e3c570e4e480383" alt=""
data:image/s3,"s3://crabby-images/ba38a/ba38a9637b391dbd79d21abd57dc4c4e2b9f325f" alt=""
data:image/s3,"s3://crabby-images/bd111/bd1112558c747faaa5e7d3fbf84273c72f33018b" alt=""
問題
上記の構成を行った際に、Function Appのバックアップ作成は成功しますが、
以下のエラーメッセージとともにバックアップの復元が失敗するという現象が発生します。
エラーメッセージストレージ BLOB からの復元操作に失敗しました。エラーの詳細:Error occurred while downloading meta data from the storage account.
data:image/s3,"s3://crabby-images/c7eb4/c7eb48f21fcf6c5cb6d89763d7b89987e2a908c8" alt=""
data:image/s3,"s3://crabby-images/5d64a/5d64a2d965edd3e81193c16d4d44f8dd9cc3b3bc" alt=""
対処法
上記の事象ですが、Storage AccountのFirewallに 100.64.0.0/10
からの通信を許可することで対処することができます。
こちらのIPアドレスはキャリアグレードNATと呼ばれるIPアドレスであり、
Function AppやApp Serviceではバックアップの復元にこのIPアドレスを使用しているので、
内部ASEのような閉じた環境でバックアップからの復元をする際には、
場合によっては通信を許可する必要があるそうです。
data:image/s3,"s3://crabby-images/89b87/89b87070e9552f40d59f67aec2802ee7a1da3403" alt=""
data:image/s3,"s3://crabby-images/4f26a/4f26a7096c5725023292b64d9fbe4e20dc5dc030" alt=""
data:image/s3,"s3://crabby-images/badd1/badd165347d53ad55b3b5294679fcc63a33e2647" alt=""
最後に
App Service EnvironmentはApp Serviceを仮想ネットワーク内にデプロイできるサービスですが、
他のリソースとの依存関係や、バックグラウンドで使用するために通信を許可しなければならないIPアドレスがいくつか存在しているので、
構成やセキュリティの制限が複雑になってしまいます。
IP制限をかける際は注意しましょう。