3
3

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

Azure Web Apps に Gradio をローカル Git でデプロイする方法

Last updated at Posted at 2023-11-18

Azure Web Apps に Gradio を LocalGit でデプロイする

  • Azure Web Apps で Gradio を動かす手順の紹介です。
  • Docker を使った方法などは紹介されているので、そちらの方が楽かもしれないです。
  • streamlit についてもスタートアップコマンドを変更すれば同じ方法で起動出来ると思います。(未確認)

環境

言語など バージョンなど
Python 3.10.11
Gradio 4.4.1
Azure Web Appsプラン F1(無料)

手順1 Azure Web Apps のサービスを作成

  1. 「App Service」→「作成」→「Web アプリ」
    image.png
  2. それぞれ入力します。
    • プロジェクトの詳細
      • 「サブスクリプション」は特に変更していません。
      • 「リソースグループ」は「rg-rrr」を新規作成しました。
    • インスタンスの詳細
      • 「名前」は「webapp-rrr」にしました。
      • 「公開」は「コード」、
        「ランタイムスタック」は「Python 3.10」、
        「地域」は「Japan East」を選択しました。
    • 価格プラン
      • 「Linux プラン」は特に変更していません。
      • 「価格プラン」は「Free F1」を選択しました。
        image.png
  3. 「データベース」「デプロイ」「ネットワーク」「監視」「タグ」は特に変更しないのでスキップします。
  4. 「作成」します。
    image.png
  5. 「リソースグループ(rg-rrr)」に Azure Web Apps 「webapp-rrr」が作成されている事を確認出来ます。
    image.png
  6. 作成した Azure Web Apps にタグを設定しておきます。
    デプロイする際の目印になるものです。
    azd-service-name: web
    image.png

手順2 Azure Web Apps に「ローカル Git」を作成してローカルに clone

  1. 作成した Azure Web Apps を開く。
    「デプロイ センター」→「設定」→「ソース」→「ローカル Git」を選択して「保存」する。
    image.png
    「保存」後に「Git Clone URI」が表示されるのでコピーしておく。
    image.png
  2. 「ローカルGitまたはFTPSの資格情報」で「ユーザー名」「パスワード」を入力して「保存」する。
    image.png
  3. 先ほどの「Git Clone URI」を使ってローカルに git clone する。
    その際に「ユーザー名」「パスワード」を聞かれるので、「ローカルGitまたはFTPSの資格情報」で保存した値を入力する。
    image.png
  4. 自身のローカル環境に空の git リポジトリが clone されます。
    image.png
  5. 適当なフォルダ・ファイルを作成する。
    下記はプロジェクト直下に「webapp」フォルダと
    「app.py」「requirements.txt」「start.sh」を作成した
    image.png

手順3 Azure Web Apps にデプロイする準備(azd provision, deploy の実行直前まで)

  1. プロジェクトフォルダで azd init を実行して、
    Use code in the current directory を選択
    image.png
    Confirm and continue initializing my app を選択
    image.png
    environment name を入力
    image.png
    「.azure」「infra」「.gitignore」「azure.yaml」「next-steps.md」が作成される
    image.png

  2. main.bicep をすべてコメントアウトする
    image.png

  3. デプロイするアプリを作成します。

    • 「webapp」フォルダの中に作った「app.py」「requirements.txt」「start.sh」を編集しています。
    • 「start.sh」は Azure Web Apps のスタートアップコマンドで実行するものです。
    • demo.launch(server_port=8000, server_name='0.0.0.0') の
      server_port、server_name の設定を忘れずにして下さい。
    app.py
    import gradio as gr
    
    def main():
        images = ["https://th.bing.com/th?id=ORMS.5a4b9e59fc9f308d4774524f3b204333&pid=Wdp&w=240&h=129&qlt=90&c=1&rs=1&dpr=1&p=0",
                "https://www.bing.com/th?id=OAIP.acf748777338864b33a2b246ee848bdc&pid=AdsNative&c=3&w=300&h=157&dynsize=1&qlt=90"]
    
        def on_select(evt: gr.SelectData):  # SelectData is a subclass of EventData
            return f"You selected {evt.value} at {evt.index} from {evt.target}"
    
        with gr.Blocks() as demo:
            with gr.Row():
                gallery = gr.Gallery(value=images,
                                    columns=4,
                                    show_download_button=False,
                                    allow_preview=False)
                
            text = gr.Textbox(interactive=True)
            gallery.select(fn=on_select, inputs=None, outputs=text)
        demo.launch(server_port=8000, server_name='0.0.0.0')
    
    if __name__ == "__main__":
        main()
    
    requirements.txt
    gradio==4.36.1
    
    start.sh
    #!/bin/sh
    # TZ の変更
    cp /usr/share/zoneinfo/Asia/Tokyo /etc/localtaime
    echo '仮想環境の作成'
    python -m venv venv
    echo 'ライブラリのインストール'
    ./venv/bin/python -m pip install -r requirements.txt
    echo 'アプリの実行'
    ./venv/bin/python app.py
    
  4. azure.yaml でデプロイの設定をする
    azd init で作成されたものを編集する
    変更箇所は「host: containerapp」→「host: appservice」
    Azure Developer CLI の azure.yaml スキーマ

    azure.yaml
    # yaml-language-server: $schema=https://raw.githubusercontent.com/Azure/azure-dev/main/schemas/v1.0/azure.yaml.json
    
    name: webapp-rrr
    metadata:
        template: azd-init@1.9.3
    services:
        web:
            project: webapp
            host: appservice
            language: python
    

手順4 ウェブアプリの設定

  1. 「構成」→「全般設定」を開く。
    「スタートアップコマンド」に以下のコマンドを登録する。
    start.sh
    
    image.png

手順5 azd provision, azd deploy を実行してデプロイ

(以下の provision, deploy をまとめて実行してくれる azd up コマンドもあります。)

  1. azd auth login を実行する。

  2. azd provision を実行する。

    • 「サブスクリプション」「ロケーション」「リソースグループ」を問われるので全て選択する。
      image.png
  3. azd deploy を実行する。
    image.png

手順6 ウェブサイトの確認

  • 「概要」→「既定のドメイン」の URL を参照するとデプロイした Gradio アプリを確認する事が出来ます。
    image.png
    image.png

その他

  • パブリックアクセスが有効になっている場合、
    Azure Web Apps の「ネットワーク」→「アクセス制限」から任意のアクセス制限をかけて下さい。
    image.png
3
3
2

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
3
3

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?