URI

<buildindex_uri>/grid[.<format>]

支持的方法

GETPOSTHEAD

父资源

buildIndex

子资源

gridJob

介绍

创建格网索引作业资源目录。通过对 grid 执行GET 请求,可获取当前系统的创建格网索引作业列表。通过 POST 请求可创建一个分析任务。

支持的方法:

  • GET:获取当前系统的创建格网索引作业列表。
  • POST:创建一个带格网空间索引的hdfs的数据目录。
  • HEAD:检查 grid 资源是否存在,或权限是否可以访问 grid 资源。

支持的表述格式:RJSON、JSON、HTML、XML。

资源层次

HTTP 请求方法

对如下 URI 执行 HTTP 请求,以 rjson 输出格式为例加以说明,其中,supermapiserver 是服务器名。

http://supermapiserver:8090/iserver/services/distributedanalyst/rest/v1/jobs/dataprocessing/buildindex/grid.rjson     

GET 请求

获取当前系统的创建格网索引作业列表

响应结构

对 grid 资源执行 GET 请求,在响应消息的实体主体里是一个格网索引资源描述集,其中单个资源描述的结构如下:  

名称 类型 含义
id String 应用ID。
state SparkJobState 该任务的状态。包括执行状态、起止时间、耗时等。
setting SparkJobSetting 列举了任务配置的详细信息。

响应示例

对 grid 资源执行 GET 请求,返回 rjson 格式的资源描述如下:

[{

  "id": "6acafdac_f5f3_4c76_9ae5_b5a9625e69cd",

  "state": {

    "errorStackTrace": null,

    "endState": true,

    "startTime": 1513748139147,

    "endTime": 1513748170478,

    "publisherelapsedTime": 0,

    "runState": "FINISHED",

    "errorMsg": null,

    "elapsedTime": 30318

  },

  "setting": {

    "output": {

      "outputPath": null,

      "datasourcePath": "hdfs://192.168.112.126:9000/data/test123",

      "datasetName": "analystResult",

      "type": "INDEXEDHDFS"

    },

    "args": null,

    "input": {

      "datasetName": "samples_processing_newyorkZone_R",

      "numSlices": 36,

      "specField": null,

      "datasetInfo": {

        "fieldInfos": [

          {

            "isRequired": true,

            "defaultValue": "",

            "name": "SmID",

            "caption": "SmID",

            "type": "INT32",

            "maxLength": 4,

            "isZeroLengthAllowed": true,

            "isSystemField": true

          },

          {

            "isRequired": true,

            "defaultValue": "0",

            "name": "SmSdriW",

            "caption": "SmSdriW",

            "type": "SINGLE",

            "maxLength": 4,

            "isZeroLengthAllowed": true,

            "isSystemField": true

          },

          {

            "isRequired": true,

            "defaultValue": "0",

            "name": "SmSdriN",

            "caption": "SmSdriN",

            "type": "SINGLE",

            "maxLength": 4,

            "isZeroLengthAllowed": true,

            "isSystemField": true

          },

          {

            "isRequired": true,

            "defaultValue": "0",

            "name": "SmSdriE",

            "caption": "SmSdriE",

            "type": "SINGLE",

            "maxLength": 4,

            "isZeroLengthAllowed": true,

            "isSystemField": true

          },

          {

            "isRequired": true,

            "defaultValue": "0",

            "name": "SmSdriS",

            "caption": "SmSdriS",

            "type": "SINGLE",

            "maxLength": 4,

            "isZeroLengthAllowed": true,

            "isSystemField": true

          },

          {

            "isRequired": true,

            "defaultValue": "0",

            "name": "SmUserID",

            "caption": "SmUserID",

            "type": "INT32",

            "maxLength": 4,

            "isZeroLengthAllowed": true,

            "isSystemField": false

          },

          {

            "isRequired": true,

            "defaultValue": "0",

            "name": "SmArea",

            "caption": "SmArea",

            "type": "DOUBLE",

            "maxLength": 8,

            "isZeroLengthAllowed": true,

            "isSystemField": true

          },

          {

            "isRequired": true,

            "defaultValue": "0",

            "name": "SmPerimeter",

            "caption": "SmPerimeter",

            "type": "DOUBLE",

            "maxLength": 8,

            "isZeroLengthAllowed": true,

            "isSystemField": true

          },

          {

            "isRequired": false,

            "defaultValue": "0",

            "name": "SmGeometrySize",

            "caption": "SmGeometrySize",

            "type": "INT32",

            "maxLength": 4,

            "isZeroLengthAllowed": true,

            "isSystemField": true

          },

          {

            "isRequired": true,

            "defaultValue": "-1",

            "name": "SmGeoPosition",

            "caption": "SmGeoPosition",

            "type": "INT64",

            "maxLength": 8,

            "isZeroLengthAllowed": true,

            "isSystemField": true

          },

          {

            "isRequired": false,

            "defaultValue": "",

            "name": "OBJECTID",

            "caption": "OBJECTID",

            "type": "INT32",

            "maxLength": 4,

            "isZeroLengthAllowed": true,

            "isSystemField": false

          },

          {

            "isRequired": false,

            "defaultValue": "",

            "name": "Shape_Leng",

            "caption": "Shape_Leng",

            "type": "DOUBLE",

            "maxLength": 8,

            "isZeroLengthAllowed": true,

            "isSystemField": false

          },

          {

            "isRequired": false,

            "defaultValue": "",

            "name": "Shape_Area",

            "caption": "Shape_Area",

            "type": "DOUBLE",

            "maxLength": 8,

            "isZeroLengthAllowed": true,

            "isSystemField": false

          },

          {

            "isRequired": false,

            "defaultValue": "",

            "name": "zone",

            "caption": "zone",

            "type": "WTEXT",

            "maxLength": 254,

            "isZeroLengthAllowed": true,

            "isSystemField": false

          },

          {

            "isRequired": false,

            "defaultValue": "",

            "name": "LocationID",

            "caption": "LocationID",

            "type": "INT32",

            "maxLength": 4,

            "isZeroLengthAllowed": true,

            "isSystemField": false

          },

          {

            "isRequired": false,

            "defaultValue": "",

            "name": "borough",

            "caption": "borough",

            "type": "WTEXT",

            "maxLength": 254,

            "isZeroLengthAllowed": true,

            "isSystemField": false

          }

        ],

        "epsgCode": 4326,

        "datasetName": "newyorkZone_R",

        "bounds": "Left=-74.25551784310493,Bottom=40.496084221255856,Right=-73.70014827248451,Top=40.91538866049913",

        "available": true,

        "name": "samples_processing_newyorkZone_R",

        "readOnly": false,

        "datasetType": "REGION",

        "type": "UDB",

        "url": "../../samples/data/ProcessingData/processing.udb"

      }

    },

    "DEFAULT_MASTER_ADRESS": "local[*] ",

    "referToken": "dZWm9aJqJbEYKkVEZyc8qKPdVK0oVIh9p-UzDxZTEFUH_o9rEPcqAKl7s-tfkS4euGyUAm6jUbA5S1JWpaeuiQ..",

    "mainClass": null,

    "sparkLogFile": null,

    "appName": null,

    "analyst": {

      "bounds": "-74.050,40.650,-73.850,40.850",

      "indexFile": "",

      "interval": "0",

      "isSer": true,

      "rows": "10",

      "cols": "10"

    },

    "contextSetting": null,

    "serviceInfo": {

      "targetDataPath": null,

      "targetServiceInfos": null

    },

    "referServicesAddress": "http://supermapiserver:8090/iserver"

  }

}]

POST 请求

创建一个带格网空间索引的hdfs的数据目录。

请求参数

对grid  资源执行 POST 请求,创建一个 数据处理作业任务,请求体需包含参数如下:

名称 类型 含义

input

【必填参数】

DatasetInputDataSetting
  • 数据集输入设置,当输入数据是一个数据目录服务中已存在的数据集时,用该设置。其中包含如下字段
    • datasetName:数据集名称。其中数据集的来源包括通过数据目录服务导入的数据、注册到 iServer 的数据对应的数据集以及 DataStore 中存储的数据集。
  • 数据集信息输入设置,当输入数据集文件路径及信息时,用该设置。其中包含如下字段
    • datasetInfo:数据集信息。其中数据集的来源包括:csv文件、udb文件、空间数据库。详细参数说明请参考:大数据分析输入参数设定
 FileCSVInputDataSetting
  • 文件路径输入设置。 当输入数据集文件路径时,用该设置。其中包含如下字段。
    • filePath:文件所在路径。其中路径包括:csv文件路径、hdfs文件路径。 详细参数说明请参考:大数据分析输入参数设定
    • metaInfo:数据文件的元信息。若该数据存放目录下包含 .meta 文件,则此参数可不填。

analyst

BuildGridIndexAnalystSetting 【必填参数】分析配置。传入时,需指定:
  1. 通过配置参数的形式,可传以下参数:
    • bounds:计算范围。选填参数。默认:输入数据的全幅范围
    • rows:格网索引行数目。必填参数。
    • cols:格网索引列数目。必填参数。
    • interval:对象计算分区时向外扩充的容限值。选填参数。默认:0
  1. 通过已有的索引文件的形式,可传以下参数:
    • indexFile:索引文件所在路径。(必填参数)

output

FileSystemOutputSetting 【选填参数】分析结果的输出。只支持输出到hdfs目录。(注:仅支持新创建的hdfs目录,已存在暂不支持。且该目录必须允许其他用户写入,建议将该hdfs目录的权限设置为777。)

 

示例1:通过配置参数的形式

对示例 grid 资源:http://supermapiserver:8090/iserver/services/distributedanalyst/rest/v1/jobs/dataprocessing/buildindex/grid .rjson 通过配置参数的形式,执行POST 请求,创建一个数据处理作任务。请求体中的参数如下:

{

    "input": {

        "datasetName": "samples_processing_newyorkZone_R"

    },

    "analyst": {

        "indexFile": "",

        "bounds": "-74.050,40.650,-73.850,40.850",

        "rows": "10",

        "cols": "10",

        "interval": "0"

    },

    "output": {

        "datasourcePath": "hdfs://192.168.112.126:9000/data/test1",

        "type": "INDEXEDHDFS"

    }

}

返回 rjson 格式的操作结果表述如下:

{

  "newResourceID": "6acafdac_f5f3_4c76_9ae5_b5a9625e69cd",

  "newResourceLocation":"http://localhost:8090/iserver/services/distributedanalyst/rest/v1/jobs/dataprocessing/buildindex/grid/6acafdac_f5f3_4c76_9ae5_b5a9625e69cd",

  "postResultType": "CreateChild",

  "succeed": true

}

 

示例2:通过已有的索引文件的形式

对示例 grid 资源:http://supermapiserver:8090/iserver/services/distributedanalyst/rest/v1/jobs/dataprocessing/buildindex/grid .rjson 通过已有的索引文件的形式,执行POST 请求,创建一个数据处理作任务。请求体中的参数如下:

{

    "input": {

        "datasetName": "samples_processing_newyorkZone_R"

    },

    "analyst": {

        "indexFile": "hdfs://192.168.112.126:9000/data/test1",

        "bounds": "-74.050,40.650,-73.850,40.850",

        "rows": "",

        "cols": "",

        "interval": ""

    },

    "output": {

        "datasourcePath": "hdfs://192.168.112.126:9000/data/test",

        "type": "INDEXEDHDFS"

    }

}

返回 rjson 格式的操作结果表述如下:

{

  "newResourceID": "0799bf7b_6010_4c12_bbf3_647152d53e7b",

  "newResourceLocation": "http://supermapiserver:8090/iserver/services/distributedanalyst/rest/v1/jobs/spatialanalyst/overlay/0799bf7b_6010_4c12_bbf3_647152d53e7b",

  "postResultType": "CreateChild",

  "succeed": true

}

HEAD 请求

返回跟 GET 请求一样的 HTTP 响应头,但是没有响应实体。可以在不必传输整个响应内容的情况下,获取包含在响应消息头中的元数据信息。元数据信息包括媒体类型,字符编码,压缩编码,实体内容长度等。

HEAD 请求可以用来判断 grid 资源是否存在,或者客户端是否有权限访问 grid 资源。通过对加.<format>的 URI 执行 HEAD 请求,还可以快速判断 grid 资源是否支持<format>格式的表述。

请参见