Azure Functions のローカルにあるファイルを Logic Apps で Blob Storage に移動する
経緯
なんか思いついたのでやってみた
前準備
- Storage Account を作成
- Azure Functions を作成
/LogFiles/Application/Functions以下にtext1.txt~text7.txtを配置
構築手順
- 従量課金プランでロジックアプリを作成する
- Logic Apps デザイナーで、空のロジックアプリを選択する
- 今回は試したいだけなので、トリガーはテキトーに 1 日間隔のスケジュールにした

↓

↓

- App Service で使えるのは FTPS なので、[ + 新しいステップ ] から、[ FTP ] -> [ フォルダー内のファイルのリスト ] を選択

- 接続を聞かれるので、先に作った Functions の [ デプロイセンター ] -> [ FTPS の資格情報 ] 内にある情報をセットする

※ここで少しハマったのが、🔗Logic Apps のコネクタは暗黙的な暗号化(Implicit)には対応してない ので注意 - フォルダーは
/LogFiles/Application/Functionsとする

- [ + 新しいステップ ] から、[ 制御 ] -> [ For each ] -> 動的なコンテンツから [ 本文 ] を選択

↓

↓

- For each 右上の [・・・] をクリックして、設定を開き、今カレンシー制御をオンにして、並列処理の次数を 1 にして、[ 完了 ] をクリック

- [ アクションの追加 ] から、[ 制御 ] -> [ 条件 ] を選択

↓

- 条件の左辺に IsFolder 、右辺に false を設定

- True の [ アクションの追加 ] から、[ FTP ] -> [ ファイルコンテンツの取得 ] -> 動的なコンテンツから [ Path ] を選択

↓

- ファイルコンテンツの取得右上の [・・・] をクリックして、設定を開き、非同期パターンをオフにして、[ 完了 ] をクリック

- [ アクションの追加 ] から、[ Azure Blob Storage ] -> [ BLOB を作成する ] を選択

- 接続名はテキトーに入れて、認証の種類を Access Key にして、必要情報をセットして [ 作成 ] をクリック

- フォルダのパスは最初に作ったコンテナー名の
/testに、BLOB 名はフォルダー内ファイルリストを取得した時の Name、BLOB コンテンツはファイルコンテンツの取得の時のファイルコンテンツをセットして保存する

- ファイルコンテンツの取得右上の [・・・] をクリックして、設定を開き、非同期パターンをオフにして、[ 完了 ] をクリック

- 保存して、実行してみる
Host フォルダのときは空振り

ファイルのときは退避成功

考察
ここまで、色々躓いて調べて、エラー処理とか無しで 1 日かかったし、Functions とか Web Apps 使っているってことは、
プログラムを書いているのだから、ファイルの移動もプログラムでやればよいんだよ
わざわざ FTP の口を開けて、エラー処理も面倒で別途お金がかかる Logic Apps を使う意味が全く判らない
ただ、FTPS を使って接続する辺りは誰かの役に立つといいな

ディスカッション
コメント一覧
まだ、コメントがありません