可以通过 Service Fabric 客户端 API 在 Service Fabric 群集中部署和管理基于微服务的应用程序和容器,不管该群集的位置是 Azure、本地、本地开发计算机还是其他云。 本文介绍如何在 Service Fabric 客户端 REST API 基础上生成和使用 Service Fabric Java 客户端 API

使用 AutoRest 生成客户端代码

AutoRest 是一项工具,可生成用于访问 RESTful Web 服务的客户端库。 “AutoRest 输入”是一项使用 OpenAPI 规范格式描述 REST API 的规范。 Service Fabric 客户端 REST API 遵循此规范。

请执行下述步骤,使用 AutoRest 工具生成 Service Fabric Java 客户端代码。

  • 在计算机上安装 nodejs 和 NPM

    如果使用 Linux,则执行以下命令:

    sudo apt-get install npm
    sudo apt install nodejs
    

    如果使用 Mac OS X,则执行以下命令:

    brew install node
    
  • 使用 NPM 安装 AutoRest。

    npm install -g autorest
    
  • 在本地计算机中创建 azure-rest-api-specs 存储库的分支并进行克隆,然后从计算机终端转到克隆的位置。

  • 转到已克隆存储库中的下述位置。

    cd specification\servicefabric\data-plane\Microsoft.ServiceFabric\stable\6.0
    

    如果群集版本不是 6.0.*,则转到稳定文件夹中的相应目录。

  • 运行以下 autorest 命令以生成 Java 客户端代码。

    autorest --input-file= servicefabric.json --java --output-folder=[output-folder-name] --namespace=[namespace-of-generated-client]
    

    下面是一个示例,演示了如何使用 AutoRest。

    autorest --input-file=servicefabric.json --java --output-folder=java-rest-api-code --namespace=servicefabricrest
    

    以下命令使用 servicefabric.json 规范文件作为输入,在 java-rest-api-code 文件夹中生成 Java 客户端代码,然后将代码封装在 servicefabricrest 命名空间中。 执行此步骤后,会生成 modelsimplementation 两个文件夹,并会在 java-rest-api-code 文件夹中生成 ServiceFabricClientAPIs.javapackage-info.java 两个文件。

    在项目中包括和使用生成的客户端

  • 将生成的代码正确地添加到项目中。 建议使用生成的代码创建一个库,然后将该库包括到项目中。

  • 如果创建库,则请在库的项目中包括以下依赖项。 如果使用其他方法,则请采用相应的格式包括依赖项。

    GroupId:  com.microsoft.rest
    Artifactid: client-runtime
    Version: 1.2.1
    

    例如,如果使用 Maven 生成系统,则请在 pom.xml 文件中包括以下内容:

        <dependency>
          <groupId>com.microsoft.rest</groupId>
          <artifactId>client-runtime</artifactId>
          <version>1.2.1</version>
        </dependency>
    
  • 使用以下代码创建 RestClient:

        RestClient simpleClient = new RestClient.Builder()
            .withBaseUrl("http://<cluster-ip or name:port>")
            .withResponseBuilderFactory(new ServiceResponseBuilder.Factory())
            .withSerializerAdapter(new JacksonAdapter())
            .build();
        ServiceFabricClientAPIs client = new ServiceFabricClientAPIsImpl(simpleClient);
    
  • 使用此客户端对象,根据需要进行相应的调用。 下面是一些演示如何使用客户端对象的示例。 假设在使用下面的 API 之前,应用程序包已生成并上传到映像存储区。

  • 预配应用程序

        ApplicationTypeImageStorePath imageStorePath = new ApplicationTypeImageStorePath();
        imageStorePath.withApplicationTypeBuildPath("<application-path-in-image-store>");
        client.provisionApplicationType(imageStorePath);
    
  • 创建应用程序

        ApplicationDescription applicationDescription = new ApplicationDescription();
        applicationDescription.withName("<application-uri>");
        applicationDescription.withTypeName("<application-type>");
        applicationDescription.withTypeVersion("<application-version>");
        client.createApplication(applicationDescription);
    

    你会发现每个 API 有四个实现重载。 如果有可选参数,你会发现另外还有四个包含这些可选参数的变体。 这里以 API removeReplica 为例。

  • public void removeReplica(String nodeName, UUID partitionId, String replicaId, Boolean forceRemove, Long timeout)
  • 这是 removeReplica API 调用的同步变体
  • public ServiceFutureVoid> removeReplicaAsync(String nodeName, UUID partitionId, String replicaId, Boolean forceRemove, Long timeout, final ServiceCallback<Void> serviceCallback)
  • 若要使用基于未来的异步编程并使用回调,则可使用 API 调用的此变体
  • public ObservableVoid> removeReplicaAsync(String nodeName, UUID partitionId, String replicaId)
  • 若要使用反应式异步编程,则可使用 API 调用的此变体
  • public ObservableServiceResponse<Void>> removeReplicaWithServiceResponseAsync(String nodeName, UUID partitionId, String replicaId)
  • 若要使用反应式异步编程并处理原始 REST 响应,则可使用 API 调用的此变体
  • 了解 Service Fabric REST APIs(Service Fabric REST API)
  •