LoginSignup
17
1

1. きっかけ

2023年2月に開催されたSpringOne EssentialsのセッションでAzure Spring Appsの紹介がありました。
そのセッションにてリモートデバッグの説明があり、おもしろい機能だな~と思っていたのですが、当時はAzure経験ゼロだったので、なかなか踏み出せずにいました。

業務でAzureを使い始めてやっと慣れてきたので、今回のアドベントカレンダー執筆を機にAzure Spring Appsを使ってみようと思い立ちました。

2. リモートデバッグ機能とは

Azure環境に配置されているアプリケーションをデバッグする機能のことです。
AzureにデプロイされたSpringBootに対し、下記のようなデバッグが可能となります。

  • ブレークポイントで処理を止める
  • 変数の値を参照する
  • etc..

3. この記事のゴール

  • Azure Spring AppsにSpringBootアプリをデプロイする
  • リモートデバッグ機能を動かす

4. Azure環境の構築

Azure Portal上でAzure Spring Appsを構築してみます。
リモートデバッグのお試しが今回の目的であるため、必要最低限のAzureリソースで構築したいと思います。

4.1. Azure Spring Appsの構築

  1. 「Azure Spring Apps」をクリック
    image.png

  2. 「作成」をクリック
    image.png

  3. 設定値を入力

    • 基本

      項目 設定値 備考
      サブスクリプション - (各環境に合わせる)
      リソースグループ - (各環境に合わせる)
      名前 remote-debug-sample
      リージョン Japan East
      ホスティング オプションとプラン Standard Basicではリモートデバッグが利用不可
      ゾーン冗長 無し
      サンプル プロジェクトのデプロイ 無し

    image.png

    • 診断設定 : ログを収集したい場合は有効にする
    • Application Insights : Application Insightsで監視/分析等したい場合は有効にする
    • ネットワーク : 特に設定しないでOK
    • タグ : 特に設定しないでOK
  4. 確認と作成タブで、「作成」をクリック

  5. 作成完了まで待つ (数分かかります)
    image.png

4.2. アプリの構築

  1. 3.1.で作った「remote-debug-sample」をクリック
    image.png

  2. 設定 > アプリ タブの「アプリの作成」をクリック
    image.png

  3. 設定値を入力し、「作成」をクリック

    項目 設定値
    アプリ名 greeting-app
    デプロイの種類 成果物(Java/.Net Core)
    ランタイム プラットフォーム Java 17
    vCPU (デフォルト値)
    メモリ (デフォルト値)
    インスタンス数 1

    image.png

  4. 作成完了まで待つ
    image.png

4.3. ロールの付与

  1. アクセス制御(IAM)タブの「追加」>「ロールの割り当ての追加」をクリック
    image.png
  2. 「Azure Spring Apps Remote Debugging Role」 の選択
    image.png
  3. ロールの割り当て先を選択する
    image.png
  4. 「レビューと割り当て」をクリックし、割り当て完了まで待つ

以上で、Azure環境の構築は完了です。

5. SpringBootアプリのデプロイ & 動作確認

Azure Spring Appsに、SpringBootのサンプルアプリをデプロイし、動作確認を行います。

サンプルアプリは下記に置いてあります。
https://github.com/YukiYamagata/azure-spring-apps-sample

デプロイ & リモートデバッグには、IntelliJ IDEAを利用します。

筆者の動作環境はこちら

アプリ バージョン
IntelliJ IDEA Community Edition 2023.1.2
Azure Toolkit for IntelliJ 3.82.0-2023.1

5.1. デプロイ

  1. IntelliJ IDEAに、プラグイン「Azure Toolkit for IntelliJ」を追加する
    image.png
  2. 「Azure Explorer」タブで「Sign In...」ボタンをクリック
    image.png
  3. 各環境に合わせて、サインインする。
    image.png
  4. 「プロジェクト」タブで、プロジェクトを右クリックし、「Azure」>「Deploy To Azure Spring Apps..」を選択する
    image.png
  5. 各環境に合わせた値を入力し、実行する
    image.png
  6. デプロイが完了するまで待つ
    image.png

5.2. 動作確認

  1. Azure > Deployment Targets > アプリ(greeting-app)を右クリックし、「Access Test Endpoint」を選択する
    image.png
  2. ブラウザでテストエンドポイントが表示される
    image.png
  3. テストエンドポイントの末尾に、「/greet」を追記して、サンプルアプリを動かす
    image.png

以上で、デプロイ & 動作確認は完了です。

6. リモートデバッグを試す

下記の手順で、デバッガーへアタッチします。

  1. デバッグ機能を有効にする
    image.png
  2. デバッガーにアタッチする
    image.png
  3. 各環境に合わせてインスタンスを選択する
    image.png
  4. 下記のようなコンソールが表示されれば、アタッチ成功です
    image.png

デバッガーにアタッチできれば、後はローカルでデバッグする方法と同じようにデバッグすることが可能です。

  • ブレークポイントでの処理Stop & 変数の値参照
    image.png
  • 変数の値変更
    image.png

7. まとめ

今回は、Azure Spring Appsのリモートデバッグ機能を試してみました。
リモートデバッグ機能の使い道として、障害調査時のデバッグにはもちろん、複雑な異常系テスト(変数操作をして、リトライ1回目は失敗しリトライ2回目は成功させる etc..)を行うときにも活用できそうに思いました。

AWSにも「AWS Toolkit for Eclipse」なるものがありますが、Java開発ではIntelliJ利用者も多い(筆者も最近EclipseからIntelliJに利用を変えました)と思うので、普段使っているIDEでデバッグできるのは良いですね。

参考

17
1
0

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
17
1