次の方法で共有


Service Fabric でパラメーターを使用してサービスのポート番号を指定する方法

この記事では、Visual Studio を使い、Service Fabric でパラメーターを使ってサービスのポート番号を指定する方法について説明します。

パラメーターを使ってサービスのポート番号を指定する手順

この例では、パラメーターを使って ASP.NET Core Web API のポート番号を設定します。

  1. Visual Studio を開き、新しい Service Fabric アプリケーションを作成します。

  2. ステートレス ASP.NET Core テンプレートを選びます。

  3. Web API を選びます。

  4. ServiceManifest.xml ファイルを開きます。

  5. サービスに指定されているエンドポイントの名前を書き留めておきます。 既定値は ServiceEndpoint です。

  6. ApplicationManifest.xml ファイルを開きます。

  7. ServiceManifestImport 要素に新しい RessourceOverrides 要素を追加し、ServiceManifest.xml ファイル内のエンドポイントを参照するように指定します。

      <ServiceManifestImport>
        <ServiceManifestRef ServiceManifestName="Web1Pkg" ServiceManifestVersion="1.0.0" />
        <ResourceOverrides>
          <Endpoints>
            <Endpoint Name="ServiceEndpoint"/>
          </Endpoints>
        </ResourceOverrides>
        <ConfigOverrides />
      </ServiceManifestImport>
    
  8. Endpoint 要素で、パラメーターを使って任意の属性をオーバーライドできるようになります。 次の例では、Port を指定し、角かっこを使ってパラメーター名に設定しています (例: [MyWebAPI_PortNumber])。

      <ServiceManifestImport>
        <ServiceManifestRef ServiceManifestName="Web1Pkg" ServiceManifestVersion="1.0.0" />
        <ResourceOverrides>
          <Endpoints>
            <Endpoint Name="ServiceEndpoint" Port="[MyWebAPI_PortNumber]"/>
          </Endpoints>
        </ResourceOverrides>
        <ConfigOverrides />
      </ServiceManifestImport>
    
  9. ApplicationManifest.xml ファイルの Parameters 要素でパラメーターを指定します。

      <Parameters>
        <Parameter Name="MyWebAPI_PortNumber" />
      </Parameters>
    
  10. DefaultValue を定義します。

      <Parameters>
        <Parameter Name="MyWebAPI_PortNumber" DefaultValue="8080" />
      </Parameters>
    
  11. ApplicationParameters フォルダーの Cloud.xml ファイルを開きます。

  12. リモート クラスターに公開するときに使う別のポートを指定するには、そのポート番号のパラメーターをこのファイルに追加します。

      <Parameters>
        <Parameter Name="MyWebAPI_PortNumber" Value="80" />
      </Parameters>
    

Cloud.xml 発行プロファイルを使って Visual Studio からアプリケーションを発行すると、サービスはポート 80 を使うように構成されます。 MyWebAPI_PortNumber パラメーターを指定しないでアプリケーションを展開すると、サービスはポート 8080 を使います。

次のステップ

この記事で説明されている主要な概念の一部について詳しくは、「複数の環境のアプリケーション パラメーターを管理する」をご覧ください。

Visual Studio で使用可能なその他のアプリケーション管理機能については、 Visual Studio での Service Fabric アプリケーションの管理に関する記事をご覧ください。