Estos contenidos se han traducido de forma automática para su comodidad, pero Huawei Cloud no garantiza la exactitud de estos. Para consultar los contenidos originales, acceda a la versión en inglés.
Actualización más reciente 2025-12-22 GMT+08:00

Creación de una regla de orquestación

Función

Esta API se utiliza para crear una regla de orquestación.

Método de invocación

Para obtener más información, véase invocación de API.

URI

POST /v2/{project_id}/apigw/instances/{instance_id}/orchestrations

Tabla 1 Parámetros de ruta

Parámetro

Obligatorio

Tipo

Descripción

project_id

String

ID del proyecto. Para obtener más información sobre cómo obtenerlo, véase Obtención de un ID de proyecto.

instance_id

String

ID de gateway, que se puede obtener de la información de gateway en la consola de APIG.

Parámetros de solicitud

Tabla 2 Parámetros de encabezado de solicitud

Parámetro

Obligatorio

Tipo

Descripción

X-Auth-Token

String

Token de usuario. Se puede obtener invocando a la API de IAM utilizada para obtener un token de usuario. El valor de X-Subject-Token en el encabezado de respuesta es un token.

Tabla 3 Parámetros del cuerpo de solicitud

Parámetro

Obligatorio

Tipo

Descripción

orchestration_name

String

Nombre de regla de mapeo de orquestación.

El nombre debe tener entre 3 y 64 caracteres, comenzar con una letra y utilizar solo letras, dígitos y guiones bajos (_). Debe ser único en el mismo gateway.

Mínimo: 3

Máximo: 64

orchestration_strategy

String

Política de orquestación. Opciones:

  • list

  • hash

  • range

  • hash_range

  • none_value

  • default

  • head_n

  • tail_n.

    Si la política de orquestación es list, el número de objetos de orchestration_map multiplicado por el de map_param_list no puede ser superior a 3,000.

orchestration_mapped_param

No

OrchestrationMappedParam object

Configuración de parámetros después de orquestación. Este parámetro es obligatorio cuando isPreprocessing se establece en false.

is_preprocessing

No

Boolean

Indica si la política es una política de preprocesamiento. Una política de preprocesamiento genera solo parámetros temporales como entrada de la regla de orquestación de parámetros subsiguiente. Y no se puede utilizar como la última regla de orquestación excepto la regla de orquestación predeterminada.

orchestration_map

No

Array of OrchestrationMap objects

Lista de reglas de mapeo de orquestación. La lista contiene de 1 a 300 caracteres.

Las reglas de mapeo de orquestación se priorizan en la misma secuencia que la lista.

Las reglas de mapeo deben ser únicas. Si orchestration_strategy es list, map_param_list no puede contener los mismos elementos.

Longitud de matriz: 1 - 300

Tabla 4 OrchestrationMappedParam

Parámetro

Obligatorio

Tipo

Descripción

mapped_param_name

String

Nombre del parámetro de solicitud después de la orquestación. El valor puede contener de 1 a 128 caracteres, incluidas letras, dígitos y guiones (-). Debe comenzar con una letra y no puede ser igual al nombre de un parámetro existente. Por defecto, el nombre del parámetro se transmite de forma transparente al backend.

Mínimo: 1

Máximo: 128

mapped_param_type

String

Tipo del parámetro después de la orquestación. El valor puede ser cadena o número.

mapped_param_location

String

Posición del parámetro orquestado. El valor puede ser consulta o encabezado.

Tabla 5 OrchestrationMap

Parámetro

Obligatorio

Tipo

Descripción

map_param_list

No

Array of strings

Lista de parámetros después de la orquestación de mapeo. Este parámetro es obligatorio cuando orchestration_strategy se establece en list. La longitud de la lista oscila entre 0 y 3000.

El valor puede contener de 1 a 128 caracteres, incluidas letras, dígitos, guiones (-) y guiones bajos (_).

Mínimo: 1

Máximo: 128

Longitud de matriz: 0 - 3000

map_param_range

No

OrchestrationMapParamRange object

Este parámetro es para el mapeo de configuraciones de rango de parámetros después de la orquestación y es obligatorio si orchestration_strategy es range o hash_range.

mapped_param_value

No

String

El valor del parámetro después de la orquestación puede contener de 1 a 128 caracteres, incluidos solo letras y dígitos.

Este parámetro es opcional solo cuando orchestration_strategy se establece en hash, head_n o tail_n, o is_preprocess se establece en false.

Mínimo: 0

Máximo: 128

intercept_length

No

Integer

Longitud del truncamiento. El valor oscila entre 1 y 100. Este parámetro es obligatorio cuando el tipo de política es head_n o tail_n. Si la longitud de truncamiento es mayor que la longitud del parámetro, el resultado de truncamiento del parámetro es un parámetro completo.

Mínimo: 1

Máximo: 100

Tabla 6 OrchestrationMapParamRange

Parámetro

Obligatorio

Tipo

Descripción

range_start

No

String

Valor inicial del rango. El valor es una cadena que se puede convertir en un entero. Después de la conversión, el valor de range_start oscila entre 0 y 9223372036854775807. Y el valor de range_start no puede ser mayor que el de range_end.

range_end

No

String

Valor final del rango. El valor es una cadena que se puede convertir en un entero. Después de la conversión, el valor de range_end oscila entre 0 y 9223372036854775807. Y el valor de range_start no puede ser mayor que el de range_end.

Parámetros de respuesta

Código de estado: 201

Tabla 7 Parámetros del cuerpo de respuesta

Parámetro

Tipo

Descripción

orchestration_name

String

Nombre de regla de mapeo de orquestación.

El nombre debe tener entre 3 y 64 caracteres, comenzar con una letra y utilizar solo letras, dígitos y guiones bajos (_). Debe ser único en el mismo gateway.

Mínimo: 3

Máximo: 64

orchestration_strategy

String

Política de orquestación. Opciones:

  • list

  • hash

  • range

  • hash_range

  • none_value

  • default

  • head_n

  • tail_n.

    Si la política de orquestación es list, el número de objetos de orchestration_map multiplicado por el de map_param_list no puede ser superior a 3,000.

orchestration_mapped_param

OrchestrationMappedParam object

Configuración de parámetros después de orquestación. Este parámetro es obligatorio cuando isPreprocessing se establece en false.

is_preprocessing

Boolean

Indica si la política es una política de preprocesamiento. Una política de preprocesamiento genera solo parámetros temporales como entrada de la regla de orquestación de parámetros subsiguiente. Y no se puede utilizar como la última regla de orquestación excepto la regla de orquestación predeterminada.

orchestration_map

Array of OrchestrationMap objects

Lista de reglas de mapeo de orquestación. La lista contiene de 1 a 300 caracteres.

Las reglas de mapeo de orquestación se priorizan en la misma secuencia que la lista.

Las reglas de mapeo deben ser únicas. Si orchestration_strategy es list, map_param_list no puede contener los mismos elementos.

Array Length: 1 - 300

orchestration_id

String

ID de regla de orquestación.

orchestration_create_time

String

Hora en la que se creó una regla de orquestación.

orchestration_update_time

String

Hora en la que se actualizó una regla de orquestación.

Tabla 8 OrchestrationMappedParam

Parámetro

Tipo

Descripción

mapped_param_name

String

Nombre del parámetro de solicitud después de la orquestación. El valor puede contener de 1 a 128 caracteres, incluidas letras, dígitos y guiones (-). Debe comenzar con una letra y no puede ser igual al nombre de un parámetro existente. Por defecto, el nombre del parámetro se transmite de forma transparente al backend.

Mínimo: 1

Máximo: 128

mapped_param_type

String

Tipo del parámetro después de la orquestación. El valor puede ser cadena o número.

mapped_param_location

String

Posición del parámetro orquestado. El valor puede ser consulta o encabezado.

Tabla 9 OrchestrationMap

Parámetro

Tipo

Descripción

map_param_list

Array of strings

Lista de parámetros después de la orquestación de mapeo. Este parámetro es obligatorio cuando orchestration_strategy se establece en list. La longitud de la lista oscila entre 0 y 3000.

El valor puede contener de 1 a 128 caracteres, incluidas letras, dígitos, guiones (-) y guiones bajos (_).

Mínimo: 1

Máximo: 128

Longitud de matriz: 0 - 3000

map_param_range

OrchestrationMapParamRange object

Este parámetro es para el mapeo de configuraciones de rango de parámetros después de la orquestación y es obligatorio si orchestration_strategy es range o hash_range.

mapped_param_value

String

El valor del parámetro después de la orquestación puede contener de 1 a 128 caracteres, incluidos solo letras y dígitos.

Este parámetro es opcional solo cuando orchestration_strategy se establece en hash, head_n o tail_n, o is_preprocess se establece en false.

Mínimo: 0

Máximo: 128

intercept_length

Integer

Longitud del truncamiento. El valor oscila entre 1 y 100. Este parámetro es obligatorio cuando el tipo de política es head_n o tail_n. Si la longitud de truncamiento es mayor que la longitud del parámetro, el resultado de truncamiento del parámetro es un parámetro completo.

Mínimo: 1

Máximo: 100

Tabla 10 OrchestrationMapParamRange

Parámetro

Tipo

Descripción

range_start

String

Valor inicial del rango. El valor es una cadena que se puede convertir en un entero. Después de la conversión, el valor de range_start oscila entre 0 y 9223372036854775807. Y el valor de range_start no puede ser mayor que el de range_end.

range_end

String

Valor final del rango. El valor es una cadena que se puede convertir en un entero. Después de la conversión, el valor de range_end oscila entre 0 y 9223372036854775807. Y el valor de range_start no puede ser mayor que el de range_end.

Código de estado: 400

Tabla 11 Parámetros del cuerpo de respuesta

Parámetro

Tipo

Descripción

error_code

String

Código de error.

error_msg

String

Descripción de error.

Código de estado: 401

Tabla 12 Parámetros del cuerpo de respuesta

Parámetro

Tipo

Descripción

error_code

String

Código de error.

error_msg

String

Descripción de error.

Código de estado: 403

Tabla 13 Parámetros del cuerpo de respuesta

Parámetro

Tipo

Descripción

error_code

String

Código de error.

error_msg

String

Descripción de error.

Código de estado: 404

Tabla 14 Parámetros del cuerpo de respuesta

Parámetro

Tipo

Descripción

error_code

String

Código de error.

error_msg

String

Descripción de error.

Código de estado: 500

Tabla 15 Parámetros del cuerpo de respuesta

Parámetro

Tipo

Descripción

error_code

String

Código de error.

error_msg

String

Descripción de error.

Ejemplo de las solicitudes

  • Creación de una regla de orquestación de list

    {
      "orchestration_name" : "orchestration_demo_1",
      "orchestration_strategy" : "list",
      "orchestration_mapped_param" : {
        "mapped_param_name" : "shared-tag",
        "mapped_param_type" : "number",
        "mapped_param_location" : "header"
      },
      "orchestration_map" : [ {
        "map_param_list" : [ "10001", "10002" ],
        "mapped_param_value" : "1"
      }, {
        "map_param_list" : [ "10003", "10004" ],
        "mapped_param_value" : "2"
      } ],
      "is_preprocessing" : false
    }
  • Creación de una regla de orquestación de range

    {
      "orchestration_name" : "orchestration_demo_2",
      "orchestration_strategy" : "range",
      "orchestration_mapped_param" : {
        "mapped_param_name" : "shared-tag",
        "mapped_param_type" : "number",
        "mapped_param_location" : "header"
      },
      "orchestration_map" : [ {
        "map_param_range" : {
          "range_start" : "1",
          "range_end" : "1000"
        },
        "mapped_param_value" : "1"
      } ]
    }
  • Creación de una regla de orquestación de hash

    {
      "orchestration_name" : "orchestration_demo_3",
      "orchestration_strategy" : "hash",
      "orchestration_mapped_param" : {
        "mapped_param_name" : "shared-tag",
        "mapped_param_type" : "number",
        "mapped_param_location" : "header"
      }
    }
  • Creación de una regla de orquestación de hash_range

    {
      "orchestration_name" : "orchestration_demo_4",
      "orchestration_strategy" : "hash_range",
      "orchestration_mapped_param" : {
        "mapped_param_name" : "shared-tag",
        "mapped_param_type" : "number",
        "mapped_param_location" : "header"
      },
      "orchestration_map" : [ {
        "map_param_range" : {
          "range_start" : "1",
          "range_end" : "1000"
        },
        "mapped_param_value" : "1"
      } ]
    }
  • Creación de una regla de orquestación de none_value

    {
      "orchestration_name" : "orchestration_demo_5",
      "orchestration_strategy" : "none_value",
      "orchestration_mapped_param" : {
        "mapped_param_name" : "shared-tag",
        "mapped_param_type" : "number",
        "mapped_param_location" : "header"
      },
      "orchestration_map" : [ {
        "mapped_param_value" : "1"
      } ]
    }
  • Creación de una regla de orquestación de default

    {
      "orchestration_name" : "orchestration_demo_6",
      "orchestration_strategy" : "default",
      "orchestration_mapped_param" : {
        "mapped_param_name" : "shared-tag",
        "mapped_param_type" : "number",
        "mapped_param_location" : "header"
      },
      "orchestration_map" : [ {
        "mapped_param_value" : "1"
      } ]
    }
  • Creación de una regla de orquestación de head_n

    {
      "orchestration_name" : "orchestration_demo_7",
      "orchestration_strategy" : "head_n",
      "orchestration_mapped_param" : {
        "mapped_param_name" : "shared-tag",
        "mapped_param_type" : "number",
        "mapped_param_location" : "header"
      },
      "orchestration_map" : [ {
        "intercept_length" : 10,
        "mapped_param_value" : "1"
      } ]
    }
  • Creación de una regla de orquestación de tail_n

    {
      "orchestration_name" : "orchestration_demo_8",
      "orchestration_strategy" : "tail_n",
      "orchestration_mapped_param" : {
        "mapped_param_name" : "shared-tag",
        "mapped_param_type" : "number",
        "mapped_param_location" : "header"
      },
      "orchestration_map" : [ {
        "intercept_length" : 10,
        "mapped_param_value" : "1"
      } ]
    }
  • Creación de una regla de orquestación de preprocesamiento de tail_n

    {
      "orchestration_name" : "orchestration_demo_8",
      "orchestration_strategy" : "tail_n",
      "orchestration_mapped_param" : {
        "mapped_param_name" : "shared-tag",
        "mapped_param_type" : "number",
        "mapped_param_location" : "header"
      },
      "orchestration_map" : [ {
        "intercept_length" : 10
      } ],
      "is_preprocessing" : true
    }

Ejemplo de respuestas

Código de estado: 201

Creado

  • Ejemplo 1

    {
      "orchestration_id" : "76545e81d9cb4424bf704ef2b0ac7600",
      "orchestration_name" : "orchestration_demo_1",
      "orchestration_create_time" : "2023-07-02T12:31:23.353Z",
      "orchestration_update_time" : "2023-07-02T13:31:23.353Z",
      "orchestration_strategy" : "list",
      "orchestration_mapped_param" : {
        "mapped_param_name" : "shared-tag",
        "mapped_param_type" : "number",
        "mapped_param_location" : "header"
      },
      "orchestration_map" : [ {
        "map_param_list" : [ "10001", "10002" ],
        "mapped_param_value" : "1"
      }, {
        "map_param_list" : [ "10003", "10004" ],
        "mapped_param_value" : "2"
      } ]
    }
  • Ejemplo 2

    {
      "orchestration_id" : "yt655e81d9cb4424bf704ef2b0ac7600",
      "orchestration_name" : "orchestration_demo_2",
      "orchestration_create_time" : "2023-07-02T12:31:23.353Z",
      "orchestration_update_time" : "2023-07-02T13:31:23.353Z",
      "orchestration_strategy" : "range",
      "orchestration_mapped_param" : {
        "mapped_param_name" : "shared-tag",
        "mapped_param_type" : "number",
        "mapped_param_location" : "header"
      },
      "orchestration_map" : [ {
        "map_param_range" : {
          "range_start" : "1",
          "range_end" : "1000"
        },
        "mapped_param_value" : "1"
      } ]
    }
  • Ejemplo 3

    {
      "orchestration_id" : "a7655e81d9cb4424bf704ef2b0ac7600",
      "orchestration_name" : "orchestration_demo_3",
      "orchestration_create_time" : "2023-07-02T12:31:23.353Z",
      "orchestration_update_time" : "2023-07-02T13:31:23.353Z",
      "orchestration_strategy" : "hash",
      "orchestration_mapped_param" : {
        "mapped_param_name" : "shared-tag",
        "mapped_param_type" : "number",
        "mapped_param_location" : "header"
      }
    }

Código de estado: 400

Error en la solicitud

{
  "error_code" : "APIG.2012",
  "error_msg" : "Invalid parameter value,parameterName:instance_id. Please refer to the support documentation"
}

Código de estado: 401

Sin autorización

{
  "error_code" : "APIG.1002",
  "error_msg" : "Incorrect token or token resolution failed"
}

Código de estado: 403

Prohibido

{
  "error_code" : "APIG.1005",
  "error_msg" : "No permissions to request this method"
}

Código de estado: 404

No se ha encontrado

{
  "error_code" : "APIG.3030",
  "error_msg" : "The instance does not exist;id:f0fa1789-3b76-433b-a787-9892951c620ec"
}

Código de estado: 500

Error del servidor interno

{
  "error_code" : "APIG.9999",
  "error_msg" : "System error"
}

Códigos de estado

Código de estado

Descripción

201

Creado

400

Error en la solicitud

401

Sin autorización

403

Prohibido

404

No se ha encontrado

500

Error del servidor interno

Códigos de error

Consulte Códigos de error.