<目次>
(1) Azure FunctionsのPythonローカル開発をVS Codeで行うためのセットアップ手順
(1-1) STEP1:Node.js(含むnmp)のインストール
(1-2) STEP2:Azure Functions Core Toolsの取得
(1-3) STEP3:Visual Studio Code用のAzure Functions拡張機能をインストール
(1-4) STEP4:Azureとの疎通(サインイン)
(1-5) STEP5:Azure Functionsプロジェクト&関数を作成
(1-6) STEP6:Visual Studio Codeでローカル実行(F5)
(1-7) STEP7:Azureへデプロイ
(1) Azure FunctionsのPythonローカル開発をVS Codeで行うためのセットアップ手順
Azure FunctionsでPythonの開発を行おうとすると、2022年1月現在ではOSがLinuxのみ選択可能になっています。
そしてLinuxの場合はGUI上での関数プログラムの編集がサポートされていないため(図100)、VS Code等でローカル開発を行い、Azure上にデプロイする必要があります。
(図100)
関数を作ろうとして、以下のような画面(図101)に遭遇した方もいらっしゃると思いますが、本記事ではこの設定手順をご紹介します(画面キャプチャ付き)。
(図101)
data:image/s3,"s3://crabby-images/66c8e/66c8e721edf6b6f9d8c4231e018ebbd3d8480431" alt=""
(1-1) STEP1:Node.js(含むnmp)のインストール
本来はnvmによるバージョン管理が望ましいが、今回は直接ダウンロードします。
・①Node.jsのサイトからインストーラをダウンロード
(図111①)Windows 64bit OSの例
data:image/s3,"s3://crabby-images/4985f/4985f9a371f4236ef867dd1b99131993b865a6eb" alt=""
↓
・②インストーラの指示に沿ってインストールします。
(図112①)
data:image/s3,"s3://crabby-images/f1868/f1868ca05ab59e05ecd5bbb96a48b096da8fb9f9" alt=""
↓
(図112②)
data:image/s3,"s3://crabby-images/5cb84/5cb842c47f9e3110dd74c7c4ac313c8e29eecf1b" alt=""
↓
・Destination Folder:インストール先のフォルダ
(図112③)
data:image/s3,"s3://crabby-images/8dd62/8dd62c3e8faa9defcdd0152891aa57038cf6fccb" alt=""
↓
・Custom Setup:インストールする機能のカスタマイズ
(図112④)
data:image/s3,"s3://crabby-images/06b83/06b83c3d89993bf0e957e68600ead4f584c6d9ab" alt=""
↓
・Tools for Native Modules:npm(Node Package Manager)はパッケージ管理(≒インストールや依存性解決)のツールで、一部はC/C++からのコンパイルが必要なため、必要なツールを合わせて自動インストールしてよいか?
(図112⑤)
data:image/s3,"s3://crabby-images/ee4e2/ee4e2e8da23fb9d5ae1de343f388b2cfda40e3ac" alt=""
↓
(図112⑥)
data:image/s3,"s3://crabby-images/93359/933595dfe5a637b4f61eacbf22954f7467eea6ed" alt=""
↓
・インストール完了
(図112⑦)
data:image/s3,"s3://crabby-images/b30ad/b30ad06e43f5bb804e8ffa1dabf8cbbecbe6b0ed" alt=""
↓
・③Python及びVisual Studio Build Toolsのインストール(スクリプトによる自動インストール)
インストーラを閉じると、自動的にNode.jsのネイティブモジュールをコンパイルするために必要な「Python」及び「Visual Studio Build Tools」をインストールする為のウィンドウが開きます。
(図113①)適当なキーを押下するとインストールが進行します
↓
(図113②)適当なキーを押下するとインストールが進行します
data:image/s3,"s3://crabby-images/806d9/806d9238140d07622df0c7d591831b755638063b" alt=""
↓
(図113③)Power Shellのスクリプトが起動し、各種インストールが実行されます。
↓
(図113④)インストールが終了したら、下記コマンドで正常にインストールされたか?をチェックします
(1-2) STEP2:Azure Functions Core Toolsの取得
「Azure Functions Core Tools 」はAzure Functionsのローカル実行環境を作るために必要です。コマンドライン経由で実行が可能になります。Windowsの場合、Node.js経由でインストールします。
・①次のコマンドで「Azure Functions Core Tools」をインストールします。
(コマンド)
> npm install -g azure-functions-core-tools@3 --unsafe-perm true
(実行結果例)
added 51 packages, and audited 52 packages in 50s
found 0 vulnerabilities
npm notice
npm notice New patch version of npm available! 8.1.0 -> 8.1.4
npm notice Changelog: https://github.com/npm/cli/releases/tag/v8.1.4
npm notice Run npm install -g npm@8.1.4 to update!
npm notice
(図121①)
↓
・②「func -version」コマンドで正常にインストール出来た事を確認します。
(図121②)
(1-3) STEP3:Visual Studio Code用のAzure Functions拡張機能をインストール
・①VS Codeの左メニューから「□4個のマーク(拡張機能)」を選択します。
(図131①)
↓
・②検索窓に「Azure Function for Visual Studio Code」を入力し、「Azure Functions」と表示されている行を選択します。
(図131②)
data:image/s3,"s3://crabby-images/64b86/64b868121a162ce864e69d82acd05d352d0bf566" alt=""
↓
・③「Install」を押下します。
(図131③)
data:image/s3,"s3://crabby-images/c2931/c29311df2091a3e65d14c90dce80fe803c868c0b" alt=""
↓
・④正常に導入されると「INSTALLED」の欄に表示されます。
(図131④)
(1-4) STEP4:Azureとの疎通(サインイン)
・①左メニューから、先程インストールしたAzure Functions拡張機能のボタンを押下します。
(図141①)
↓
・②メニューのいずれか(例:「INTEGRATION ACCOUNTS」)の欄から「Sign in to Azure」を押下します。
(図141②)
data:image/s3,"s3://crabby-images/2536f/2536f3d78c759921926b0b12d98eafae5e219499" alt=""
↓
・③Microsoftの認証を実施。
(図141③)
data:image/s3,"s3://crabby-images/ea54c/ea54cb914c82654117f0e4dd5650a92ce3751927" alt=""
↓
・認証が完了すると次のような画面が表示されます。
(図141④)
data:image/s3,"s3://crabby-images/2044c/2044c4b5d1a73b412aa8f28534eea53ad97a6269" alt=""
↓
・VS Codeで各メニュー(例:「INTEGRATION ACCOUNTS」)の欄にサブスクリプションの一覧が表示されます。
(図141⑤)
(1-5) STEP5:Azure Functionsプロジェクト&関数を作成
・①VS Codeの「WORKSPACE」欄で「+」のアイコン(Create Function)を押下
(図151①)
data:image/s3,"s3://crabby-images/bf985/bf985d87e433bbc03f6de5f818f0646b98ca1c05" alt=""
↓
・②Pythonの開発用フォルダを指定します(どこでもOK)。
↓
・③言語はPythonを選択
(図151③)
data:image/s3,"s3://crabby-images/ea909/ea909860d4e649ac6b7c913f9afb04a0ccc66946" alt=""
↓
・④Pythonのインタープリタを選択
(図151④)
data:image/s3,"s3://crabby-images/4bb08/4bb082d1b9f58c9b22626e0b17b7380832bcc47f" alt=""
(図151④2)
data:image/s3,"s3://crabby-images/dbe4c/dbe4cf0b2a5a65f57732652c5e8d0b0fbf97d852" alt=""
↓
・⑤Azure Functionsの関数を起動する際の「トリガー」を選択します。
今回はHello Worldも兼ねて簡単あAPIを作りたいため「Http tigger」を選択します。
(図151⑤)
data:image/s3,"s3://crabby-images/6b361/6b361dcec7b55ffc1374e3d73bb410bd6defd3bd" alt=""
↓
・⑥関数の名前を入力します。
(図151⑥)
data:image/s3,"s3://crabby-images/8d767/8d7675f2a0103b8953704992623e3584ce256e7d" alt=""
↓
・⑦Authorization Level(認証レベル)の選択。
(表)
承認レベル |
説明 |
Anonymous |
認証不要。
有効なHTTPリクエストは全て通す。 |
Function |
keyベースの認証。
下記のいずれのkeyでも認証可能。
①Host key (Azure Fucntionリソースのレベル)
②Function key (リソース配下の各関数レベル) |
Admin |
keyベースの認証。
Host keyでのみ認証可能。 |
(図152①)
data:image/s3,"s3://crabby-images/aaebf/aaebf63f52832d6e072309dbb0f24a4765590e18" alt=""
↓
・⑧開き方の選択
(図152③)
data:image/s3,"s3://crabby-images/8f388/8f388911619274f386da7a95536b084eca3efa9e" alt=""
↓
・⑨ローカルプロジェクトの作成完了
自動的にローカルのAzure Function用Pythonプロジェクトを作成します。
(図152②)
data:image/s3,"s3://crabby-images/bdc7d/bdc7d9ebf40e66a73904ae4d8a46e9b2b9f9b0de" alt=""
(1-6) STEP6:Visual Studio Codeでローカル実行(F5)
次に関数アプリをローカルでデバッグしてみます。
・①左メニューから「デバッグ」ボタンを押下
(図161①)
・②「RUN AND DEBUG」の右横のプルダウンが「Attach to Python Function」になっている事を確認し、△マークのボタンを押下します。
(図161②)
data:image/s3,"s3://crabby-images/7d60a/7d60a9b823f24fc5c88fc7e6de864a2098b1864e" alt=""
⇒これにより、ローカルで仮想環境(.venv)が起動して、指定のURLから関数を実行できるようになります。
・③コンソールに「Worker process started and initialized.」等のメッセージが表示され、下の帯も「オレンジ色」に変化して「Attached to Python Functions」と表示された事を確認します。
(図161③)
・④疎通確認
コンソールに表示されているURL(Azure Functionの関数のURL)をブラウザに入力して、疎通確認します。
「http://localhost:7071/api/SampleHttpTrigger1」
正常に処理されれば、下記の”This HTTP~”のメッセージがブラウザに表示されるはずです。
return func.HttpResponse(
"This HTTP triggered function executed successfully. Pass a name in the query string or in the request body for a personalized response.",
status_code=200
)
(図161④)
ちなみに、このデバッグは通常Visual Studio等のデバッグで行う、ブレークポイントを張ってのデバッグも可能です。
>目次にもどる
(1-7) STEP7:Azureへデプロイ
・①VS Codeの「WORKSPACE」欄で「Create Function App in Azure)を押下します。
(図171①)
・②デプロイ先のAzure Functionsアプリを選択します。
(図171②)
data:image/s3,"s3://crabby-images/41429/41429d09983b9908d50ef777b656acc7fc8488c7" alt=""
↓
・③「Deploy」を押下
(図171④)
data:image/s3,"s3://crabby-images/f61e5/f61e5420398b81a043a88c2161e6eea1c108b602" alt=""
↓
・④少し待ち「Deployment to XXXX completed」のポップアップを確認します。
(図171⑤)
↓
・⑤疎通確認
Azure Functions側を見ると、先ほどまで無かった関数(ローカルで作った「SampleHttpTrigger1」)がデプロイされている事が確認できます。
(図172①)
・⑥単体テスト
ここでは詳しく触れませんが、Azure Functionsの機能で単体テストもできます。
(図172②)
>目次にもどる