Service Fabric 应用程序和服务清单

本文介绍如何使用 ApplicationManifest.xml 和 ServiceManifest.xml 文件定义 Service Fabric 应用程序和服务并对其进行版本控制。 有关更多详细示例,请参阅应用程序和服务清单示例。 这些清单文件的 XML 架构记录在 ServiceFabricServiceModel.xsd 架构文档中。

警告

清单 XML 文件架构强制对子元素进行正确排序。 作为局部解决方法,创作或修改任何 Service Fabric 清单时,请在 Visual Studio中打开“C:\Program Files\Microsoft SDKs\Service Fabric\schemas\ServiceFabricServiceModel.xsd”。 这样一来,可以检查子元素的排序并提供 intelli-sense。

使用 ServiceManifest.xml 描述服务

服务清单以声明方式定义服务类型和版本。 它指定服务元数据,例如服务类型、运行状况属性、负载均衡度量值、服务二进制文件和配置文件。 换言之,它描述了组成一个服务包以支持一个或多个服务类型的代码、配置和数据包。 服务清单可以包含多个代码、配置和数据包,可以独立进行版本控制。 以下是投票示例应用程序的 ASP.NET Core Web 前端服务的服务清单(以下是一些更详细的示例):

<?xml version="1.0" encoding="utf-8"?>
<ServiceManifest Name="VotingWebPkg"
                 Version="1.0.0"
                 xmlns="http://schemas.microsoft.com/2011/01/fabric"
                 xmlns:xsd="https://www.w3.org/2001/XMLSchema"
                 xmlns:xsi="https://www.w3.org/2001/XMLSchema-instance">
  <ServiceTypes>
    <!-- This is the name of your ServiceType. 
         This name must match the string used in RegisterServiceType call in Program.cs. -->

    <StatelessServiceType ServiceTypeName="VotingWebType" />
  </ServiceTypes>

  <!-- Code package is your service executable. -->

  <CodePackage Name="Code" Version="1.0.0">
    <EntryPoint>
      <ExeHost>
        <Program>VotingWeb.exe</Program>
        <WorkingFolder>CodePackage</WorkingFolder>
      </ExeHost>
    </EntryPoint>
  </CodePackage>

  <!-- Config package is the contents of the Config directory under PackageRoot that contains an 
       independently-updateable and versioned set of custom configuration settings for your service. -->

  <ConfigPackage Name="Config" Version="1.0.0" />

  <Resources>
    <Endpoints>
      <!-- This endpoint is used by the communication listener to obtain the port on which to 
           listen. Please note that if your service is partitioned, this port is shared with 
           replicas of different partitions that are placed in your code. -->

      <Endpoint Protocol="http" Name="ServiceEndpoint" Type="Input" Port="8080" />
    </Endpoints>
  </Resources>
</ServiceManifest>

Version 特性是未结构化的字符串,并且不由系统进行分析。 版本特性用于对每个组件进行版本控制,以进行升级。

ServiceTypes 声明此清单中的 CodePackages 支持哪些服务类型。 当一种服务针对这些服务类型之一进行实例化时,可激活此清单中声明的所有代码包,方法是运行这些代码包的入口点。 生成的进程应在运行时注册所支持的服务类型。 在清单级别而不是代码包级别声明服务类型。 因此,当存在多个代码包时,每当系统查找任何一种声明的服务类型时,它们都会被激活。

EntryPoint 指定的可执行文件通常是长时间运行的服务主机。 SetupEntryPoint 是特权入口点,以与 Service Fabric(通常是 LocalSystem 帐户)相同的凭据先于任何其他入口点运行。 提供单独的设置入口点可避免长时间使用高特权运行服务主机。 由 EntryPoint 指定的可执行文件在 SetupEntryPoint 成功退出后运行。 如果进程总是终止或出现故障,则监视并重启所产生的过程(再次从“SetupEntryPoint”开始)。

“SetupEntryPoint”的典型使用场景是在服务启动之前运行可执行文件,或使用提升的权限来执行操作时。 例如:

  • 设置和初始化服务可执行文件所需的环境变量。 这并不限于通过 Service Fabric 编程模型编写的可执行文件。 例如,npm.exe 需要配置一些环境变量来部署 Node.js 应用程序。
  • 通过安装安全证书设置访问控制。

有关如何配置 SetupEntryPoint 的详细信息,请参阅配置服务设置入口点的策略

EnvironmentVariables(上一示例中未设置),提供为此代码包设置的环境变量列表。 环境变量可以在 ApplicationManifest.xml 中重写,以便为不同的服务实例提供不同的值。

DataPackage(上一示例中未设置),声明一个由 Name 属性命名的文件夹,该文件夹中包含进程会在运行时使用的任意静态数据

ConfigPackage 声明一个由 Name 特性命名的文件夹,该文件夹中包含 Settings.xml 文件。 此设置文件包含用户定义的键值对设置部分,进程可在运行时读回这些设置。 在升级期间,如果仅更改了 ConfigPackage 版本,则不重启正在运行的进程。 相反,一个回调会告知进程配置设置已更改,以便动态重新加载。 下面是 Settings.xml 文件的一个示例:

<Settings xmlns:xsd="https://www.w3.org/2001/XMLSchema" xmlns:xsi="https://www.w3.org/2001/XMLSchema-instance" xmlns="http://schemas.microsoft.com/2011/01/fabric">
  <Section Name="MyConfigurationSection">
    <Parameter Name="MySettingA" Value="Example1" />
    <Parameter Name="MySettingB" Value="Example2" />
  </Section>
</Settings>

Service Fabric 服务“终结点”是 Service Fabric 资源的一个示例。 无需更改已编译的代码,即可声明/更改 Service Fabric 资源。 可以通过应用程序清单中的 SecurityGroup 控制对服务清单中指定 Service Fabric 资源的访问。 在服务清单中定义了终结点资源时,如果未显式指定端口,则 Service Fabric 从保留的应用程序端口范围中分配端口。 详细了解指定或替代终结点资源

警告

根据设计,静态端口不应与 ClusterManifest 中指定的应用程序端口范围重叠。 如果指定静态端口,请将其分配到应用程序端口范围外,否则会导致端口冲突。 对于版本 6.5CU2,当我们检测到此类冲突时,我们将发出运行状况警告,但让部署继续与已发布的 6.5 行为同步。 但是,我们可能会在下一个主要版本中阻止应用程序部署。

使用 ApplicationManifest.xml 描述应用程序

应用程序清单以声明方式描述应用程序类型和版本。 它指定服务组合元数据(如稳定名称、分区方案、实例计数/复制因子、安全/隔离策略、布置约束、配置替代和成分服务类型)。 此外还描述了会在其中放置应用程序的负载均衡域。

因此,应用程序清单在应用程序级别描述元素,并引用了一个或多个服务清单,以组成应用程序类型。 以下是投票示例应用程序的应用程序清单(以下是一些更详细的示例):

<?xml version="1.0" encoding="utf-8"?>
<ApplicationManifest xmlns:xsd="https://www.w3.org/2001/XMLSchema" xmlns:xsi="https://www.w3.org/2001/XMLSchema-instance" ApplicationTypeName="VotingType" ApplicationTypeVersion="1.0.0" xmlns="http://schemas.microsoft.com/2011/01/fabric">
  <Parameters>
    <Parameter Name="VotingData_MinReplicaSetSize" DefaultValue="3" />
    <Parameter Name="VotingData_PartitionCount" DefaultValue="1" />
    <Parameter Name="VotingData_TargetReplicaSetSize" DefaultValue="3" />
    <Parameter Name="VotingWeb_InstanceCount" DefaultValue="-1" />
  </Parameters>
  <!-- Import the ServiceManifest from the ServicePackage. The ServiceManifestName and ServiceManifestVersion 
       should match the Name and Version attributes of the ServiceManifest element defined in the 
       ServiceManifest.xml file. -->

  <ServiceManifestImport>
    <ServiceManifestRef ServiceManifestName="VotingDataPkg" ServiceManifestVersion="1.0.0" />
    <ConfigOverrides />
  </ServiceManifestImport>
  <ServiceManifestImport>
    <ServiceManifestRef ServiceManifestName="VotingWebPkg" ServiceManifestVersion="1.0.0" />
    <ConfigOverrides />
  </ServiceManifestImport>
  <DefaultServices>
    <!-- The section below creates instances of service types, when an instance of this 
         application type is created. You can also create one or more instances of service type using the 
         ServiceFabric PowerShell module.

         The attribute ServiceTypeName below must match the name defined in the imported ServiceManifest.xml file. -->

    <Service Name="VotingData">
      <StatefulService ServiceTypeName="VotingDataType" TargetReplicaSetSize="[VotingData_TargetReplicaSetSize]" MinReplicaSetSize="[VotingData_MinReplicaSetSize]">
        <UniformInt64Partition PartitionCount="[VotingData_PartitionCount]" LowKey="0" HighKey="25" />
      </StatefulService>
    </Service>
    <Service Name="VotingWeb" ServicePackageActivationMode="ExclusiveProcess">
      <StatelessService ServiceTypeName="VotingWebType" InstanceCount="[VotingWeb_InstanceCount]">
        <SingletonPartition />
         <PlacementConstraints>(NodeType==NodeType0)</PlacementConstraints
      </StatelessService>
    </Service>
  </DefaultServices>
</ApplicationManifest>

类似于服务清单,Version 特性是未结构化的字符串,不由系统进行分析。 版本特性也用于对每个组件进行版本控制,以进行升级。

Parameters,定义整个应用程序清单中使用的参数。 当应用程序已实例化并可替代应用程序或服务配置设置时,可以提供这些参数的值。 如果在应用程序实例化期间该值未更改,则使用默认参数值。 若要了解如何维护不同的应用程序和用于单个环境的服务参数,请参阅管理多个环境的应用程序参数

ServiceManifestImport 包含对组成此应用程序类型的服务清单的引用。 应用程序清单可以包含多个服务清单导入,每个导入都可独立进行版本控制。 导入的服务清单将确定此应用程序类型中哪些服务类型有效。 在 ServiceManifestImport 中,可以重写 Settings.xml 中的配置值和 ServiceManifest.xml 文件中的环境变量。 Policies(上一示例中未设置),用于终结点绑定、安全性和访问以及包共享,可以在导入的服务清单上进行设置。 有关详细信息,请参阅配置应用程序的安全策略

DefaultServices 声明每当一个应用程序依据此应用程序类型进行实例化时自动创建的服务实例。 默认服务只是提供便利,创建后,它们的行为在每个方面都与常规服务类似。 它们与应用程序实例中的任何其他服务一起升级,并且也可以将它们删除。 应用程序清单可以包含多个默认服务。

警告

DefaultServices 已弃用,取而代之的是 StartupServices.xml。 可以在 Service Fabric 应用程序中的 StartupServices.xml 简介中了解 StartupServices.xml。

Certificates(上一示例中未设置),声明用于设置 HTTPS 终结点或用于加密应用程序清单中的机密的证书。

放置约束是定义服务运行位置的语句。 这些语句将附加到你为一个或多个节点属性选择的各个服务。 有关详细信息,请参阅放置约束和节点属性语法

Policies(在前面的示例中未设置)描述要在应用程序级别设置的日志收集、默认运行方式帐户运行状况安全访问策略,包括服务是否可以访问 Service Fabric 运行时。

备注

根据设计,Service Fabric 群集是单租户,托管应用程序被视为受信任。 如果你正在考虑托管不受信任的应用程序,请参阅在 Service Fabric 群集中托管不受信任的应用程序

Principals(上一示例中未设置),描述运行服务并确保服务资源安全所需的安全主体(用户或组)。 Policies 部分中会引用 Principals。

后续步骤