Azure Spring Apps にデプロイするアプリケーションを準備する

Note

Azure Spring Apps は、Azure Spring Cloud サービスの新しい名前です。 サービスの名前は新しくなりましたが、スクリーンショット、ビデオ、図などの資産の更新に取り組んでいる間、場所によってはしばらく古い名前が表示されます。

この記事の適用対象: ✔️ Basic または Standard ✔️ Enterprise

この記事では、Azure Spring Apps にデプロイするために既存の Steeltoe アプリケーションを準備する方法について説明します。 Azure Spring Apps は、Steeltoe アプリをホスト、監視、スケール、更新するための堅牢なサービスを提供しています。

この記事では、Azure Spring Apps で .NET Core Steeltoe アプリを実行するために必要な依存関係、構成、およびコードについて説明します。 アプリケーションを Azure Spring Apps にデプロイする方法については、初めての Spring Boot アプリを Azure Spring Apps にデプロイする方法に関するページを参照してください。

Note

Azure Spring Apps の Steeltoe のサポートは、現時点ではパブリック プレビューとして提供されています。 パブリック プレビュー オファリングにより、お客様は公式リリースの前に新機能を試すことができます。 パブリック プレビューの機能とサービスは、運用環境での使用を目的としたものではありません。 プレビュー段階のサポートの詳細については、FAQ を参照するか、サポート リクエストを提出してください。

サポートされているバージョン

Azure Spring Apps では、次のものがサポートされています。

  • .NET Core 3.1
  • Steeltoe 2.4 および 3.0

依存関係

Steeltoe 2.4 の場合は、最新の Microsoft.Azure.SpringCloud.Client 1.x.x パッケージをプロジェクト ファイルに追加します。

<ItemGroup>
  <PackageReference Include="Microsoft.Azure.SpringCloud.Client" Version="1.0.0-preview.1" />
  <PackageReference Include="Steeltoe.Discovery.ClientCore" Version="2.4.4" />
  <PackageReference Include="Steeltoe.Extensions.Configuration.ConfigServerCore" Version="2.4.4" />
  <PackageReference Include="Steeltoe.Management.TracingCore" Version="2.4.4" />
  <PackageReference Include="Steeltoe.Management.ExporterCore" Version="2.4.4" />
</ItemGroup>

Steeltoe 3.0 の場合は、最新の Microsoft.Azure.SpringCloud.Client 2.x.x パッケージをプロジェクト ファイルに追加します。

<ItemGroup>
  <PackageReference Include="Microsoft.Azure.SpringCloud.Client" Version="2.0.0-preview.1" />
  <PackageReference Include="Steeltoe.Discovery.ClientCore" Version="3.0.0" />
  <PackageReference Include="Steeltoe.Extensions.Configuration.ConfigServerCore" Version="3.0.0" />
  <PackageReference Include="Steeltoe.Management.TracingCore" Version="3.0.0" />
</ItemGroup>

Program.cs を更新する

Program.Main メソッドで、UseAzureSpringCloudService メソッドを呼び出します。

Steeltoe 2.4.4 の場合は、ConfigureWebHostDefaults の後に、および AddConfigServer が呼び出される場合はその後に UseAzureSpringCloudService を呼び出します。

public static IHostBuilder CreateHostBuilder(string[] args) =>
    Host.CreateDefaultBuilder(args)
        .ConfigureWebHostDefaults(webBuilder =>
        {
            webBuilder.UseStartup<Startup>();
        })
        .AddConfigServer()
        .UseAzureSpringCloudService();

Steeltoe 3.0.0 の場合は、ConfigureWebHostDefaults および Steeltoe 構成コードの前に UseAzureSpringCloudService を呼び出します。

public static IHostBuilder CreateHostBuilder(string[] args) =>
    Host.CreateDefaultBuilder(args)
        .UseAzureSpringCloudService()
        .ConfigureWebHostDefaults(webBuilder =>
        {
            webBuilder.UseStartup<Startup>();
        })
        .AddConfigServer();

Eureka Server サービスの検出を有効にする

Note

Eureka は Enterprise プランには適用できません。 Enterprise プランを使用している場合、サービス レジストリの使用に関するページを参照してください。

アプリが Azure Spring Apps で実行されるときに使用される構成ソースで、spring.application.name をプロジェクトのデプロイ先の Azure Spring Apps アプリと同じ名前に設定します。

たとえば、EurekaDataProvider という名前の .NET プロジェクトを planet-weather-provider という名前の Azure Spring Apps アプリにデプロイする場合、appSettings.json ファイルには次の JSON を含める必要があります。

"spring": {
  "application": {
    "name": "planet-weather-provider"
  }
}

サービス検出を使用する

Eureka Server のサービス検出を使用してサービスを呼び出すには、http://<app_name> に HTTP 要求を送信します (この app_name はターゲット アプリの spring.application.name の値です)。 たとえば、次のコードでは planet-weather-provider サービスを呼び出しています。

using (var client = new HttpClient(discoveryHandler, false))
{
    var responses = await Task.WhenAll(
        client.GetAsync("http://planet-weather-provider/weatherforecast/mercury"),
        client.GetAsync("http://planet-weather-provider/weatherforecast/saturn"));
    var weathers = await Task.WhenAll(from res in responses select res.Content.ReadAsStringAsync());
    return new[]
    {
        new KeyValuePair<string, string>("Mercury", weathers[0]),
        new KeyValuePair<string, string>("Saturn", weathers[1]),
    };
}

この記事では、Azure Spring Apps にデプロイできるように既存の Java Spring アプリケーションを準備する方法について説明します。 適切に構成すると、Azure Spring Apps によって Java Spring アプリケーションの監視、スケーリング、更新を行う堅牢なサービスが実現します。

この例を実行する前に、基本的なクイックスタートを試してみることができます。

POM ファイルが構成されているときにアプリケーションを Azure Spring Apps にデプロイする方法については、その他の例で説明しています。

この記事では、必要な依存関係とそれらを POM ファイルに追加する方法について説明します。

Java ランタイム バージョン

詳細については、Azure Spring Apps に関する FAQ の「Java ランタイムと OS バージョン」セクションを参照してください。

Spring Boot と Spring Cloud のバージョン

既存の Spring Boot アプリケーションを Azure Spring Apps にデプロイできるよう準備するには、以降のセクションに示したように、アプリケーションの POM ファイルに Spring Boot と Spring Cloud の依存関係を追加します。

Azure Spring Apps では、リリースの 30 日後から最新の Spring Boot または Spring Cloud メジャー バージョンがサポートされます。 Azure Spring Apps では、最新のマイナー バージョンがリリース直後にサポートされます。 サポートされる Spring Boot のバージョンは Spring Boot Releases から、Spring Cloud のバージョンは Spring Cloud Releases から入手できます。

サポートされている Spring Boot と Spring Cloud の組み合わせを次の表に示します。

Spring Boot のバージョン Spring Cloud のバージョン 商用サポートの終了
3.2.x 2023.0.x (Leyton とも呼ばれます) 2026-02-23
3.1.x 2022.0.3+ (Kilburn とも呼ばれています) 2025-08-18
3.0.x 2022.0.3+ (Kilburn とも呼ばれています) 2025-02-24
2.7.x 2021.0.3+ (Jubilee とも呼ばれています) 2025-08-24
2.6.x 2021.0.3+ (Jubilee とも呼ばれています) 2024-02-24

詳細については、次のページを参照してください。

サービス レジストリから分散トレースまでの Azure Spring Apps の組み込み機能を有効にするには、アプリケーションに次の依存関係も含める必要があります。 特定のアプリに対応する機能が不要な場合は、これらの依存関係の一部を削除できます。

サービス レジストリ

マネージド Azure Service Registry サービスを使用するには、次に示すように、pom.xml ファイルに spring-cloud-starter-netflix-eureka-client 依存関係を含めます。

<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
</dependency>

サービス レジストリ サーバーのエンドポイントは、アプリで環境変数として自動的に挿入されます。 アプリケーションはサービス レジストリ サーバーに登録され、他の依存アプリケーションを検出できます。

EnableDiscoveryClient 注釈

アプリケーションのソース コードに次の注釈を追加します。

@EnableDiscoveryClient

たとえば、前出の例の piggymetrics アプリケーションを見てみましょう。

package com.piggymetrics.gateway;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.client.discovery.EnableDiscoveryClient;
import org.springframework.cloud.netflix.zuul.EnableZuulProxy;

@SpringBootApplication
@EnableDiscoveryClient
@EnableZuulProxy

public class GatewayApplication {
    public static void main(String[] args) {
        SpringApplication.run(GatewayApplication.class, args);
    }
}

分散構成

Enterprise プランで分散構成を有効にするには、Application Configuration Service for VMware Tanzu を使用します。これは、プロプライエタリ VMware Tanzu コンポーネントの 1 つです。 Application Configuration Service for Tanzu は Kubernetes ネイティブであり、Spring Cloud Config Server とは異なります。 Application Configuration Service for Tanzu を使用すると、1 つまたは複数の Git リポジトリに定義されたプロパティから設定された Kubernetes ネイティブの ConfigMap リソースを管理できます。

Enterprise プランでは、Spring Cloud Config Server はありませんが、Application Configuration Service for Tanzu を使用して、集中管理された構成を管理できます。 詳細については、「Application Configuration Service for Tanzu を使用する」を参照してください。

Application Configuration Service for Tanzu を使用するには、アプリごとに次の手順を実行します。

  1. アプリで Application Configuration Service for Tanzu を使用する必要があることを宣言する明示的なアプリ バインドを追加します。

    Note

    バインドとバインド解除の状態を変更したときは、アプリを再起動または再デプロイして変更を有効にする必要があります。

  2. 構成ファイルのパターンを設定します。 構成ファイルのパターンを使用すると、アプリで使用されるアプリケーションとプロファイルを選択できます。 詳細については、「Application Configuration Service For Tanzu を使用する」の「パターン」セクションを参照してください。

    もう 1 つの方法は、次の例に示すように、アプリのデプロイと同時に構成ファイルのパターンを設定することです。

       az spring app deploy \
           --name <app-name> \
           --artifact-path <path-to-your-JAR-file> \
           --config-file-pattern <config-file-pattern>
    

メトリック

次に示すように、pom.xml ファイルの依存関係セクションに spring-boot-starter-actuator の依存関係を含めます。

<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-actuator</artifactId>
</dependency>

メトリックは JMX エンドポイントから定期的に取得されます。 メトリックを視覚化するには、Azure portal を使用します。

警告

構成プロパティに spring.jmx.enabled=true を指定する必要があります。 そうしないと、Azure portal でメトリックを視覚化できません。

関連項目

次のステップ

この記事では、Java Spring アプリケーションを Azure Spring Apps へのデプロイ用に構成する方法について学習しました。 Config Server インスタンスを設定する方法については、Config Server インスタンスの設定に関するページを参照してください。

その他のサンプルを GitHub で入手できます (Azure Spring Apps のサンプル)。