Compartir vía


Actualización asincrónica con la API de REST

Al usar cualquier lenguaje de programación que admita llamadas REST, puede realizar operaciones de actualización de datos asincrónicas en los modelos tabulares de Azure Analysis Services, incluida la sincronización de réplicas de solo lectura para la escalabilidad horizontal de consultas.

Las operaciones de actualización de datos pueden tardar algún tiempo en función de muchos factores, como el volumen de datos, el nivel de optimización con particiones, etc. Estas operaciones se han invocado tradicionalmente con métodos existentes, como TOM (Modelo de objetos tabulares), cmdlets de PowerShell o TMSL (Tabular Model Scripting Language). Sin embargo, estos métodos pueden requerir a menudo conexiones HTTP poco confiables y de larga ejecución.

La API de REST de Azure Analysis Services permite la realización asincrónica de las operaciones de actualización de datos. Mediante el uso de la API de REST, las conexiones HTTP de larga ejecución de las aplicaciones cliente no son necesarias. También hay otras características integradas para la confiabilidad, como reintentos automáticos y confirmaciones por lotes.

URL base

La dirección URL base sigue este formato:

https://<rollout>.asazure.windows.net/servers/<serverName>/models/<resource>/

Por ejemplo, considere la posibilidad de un modelo denominado AdventureWorks, en un servidor llamado myserver, ubicado en la región Oeste de EE. UU. de Azure. El nombre del servidor es:

asazure://westus.asazure.windows.net/myserver 

La dirección URL base para este nombre de servidor es:

https://westus.asazure.windows.net/servers/myserver/models/AdventureWorks/ 

Mediante el uso de la dirección URL base, los recursos y las operaciones se pueden anexar basándose en los siguientes parámetros:

Diagrama en el que se muestra la lógica de actualización asincrónica.

  • Todo lo que termina en s es una colección.
  • Todo lo que termina en () es una función.
  • Todo lo demás es un recurso/objeto.

Por ejemplo, puede utilizar el verbo POST en la colección de actualizaciones para realizar una operación de actualización:

https://westus.asazure.windows.net/servers/myserver/models/AdventureWorks/refreshes

Autenticación

Todas las llamadas deben autenticarse con un token de Microsoft Entra ID (OAuth 2) válido en el encabezado de autorización y deben cumplir los siguientes requisitos:

  • El token debe ser un token de usuario o una entidad de servicio de aplicación.

  • El token debe tener la audiencia correcta establecida exactamente en https://*.asazure.windows.net. Tenga en cuenta que * no es un marcador de posición ni un carácter comodín, y que la audiencia debe tener el carácter * como subdominio. No se admiten audiencias personalizadas, como https://customersubdomain.asazure.windows.net. Si se especifica una audiencia no válida, se produce un error de autenticación.

  • El usuario o la aplicación deben tener permisos suficientes en el servidor o el modelo para realizar la llamada solicitada. El nivel de permiso lo determinan los roles dentro del modelo o del grupo de administradores del servidor.

    Importante

    Actualmente, se requieren permisos del rol administrador del servidor.

POST /refreshes

Para realizar una operación de actualización, puede utilizar el verbo POST en la colección /refreshes para agregar un nuevo elemento de actualización a la colección. El encabezado de ubicación de la respuesta incluye el identificador de la actualización. La aplicación cliente se puede desconectar y comprobar el estado más adelante si es necesario porque es asincrónica.

Solo se acepta una operación de actualización a la vez para un modelo. Si hay una operación de actualización en ejecución actualmente y se envía otra, se devuelve el código de estado HTTP 409 - Conflicto.

El cuerpo debe ser similar al siguiente:

{
    "Type": "Full",
    "CommitMode": "transactional",
    "MaxParallelism": 2,
    "RetryCount": 2,
    "Objects": [
        {
            "table": "DimCustomer",
            "partition": "DimCustomer"
        },
        {
            "table": "DimDate"
        }
    ]
}

Parámetros

Si no se especifica el parámetro, se aplica el valor predeterminado.

Nombre Escribir Descripción Valor predeterminado
Type Enum El tipo de procesamiento que desea realizar. Los tipos se alinean con los tipos de comando de actualización de TMSL: full, clearValues, calculate, dataOnly, automatic y defragment. No se admite el tipo add. automatic
CommitMode Enum Determina si los objetos se confirman en lotes o solo cuando se completa toda la operación. Modos: transactional y partialBatch. transactional
MaxParallelism Int Este valor determina el número máximo de subprocesos en los que ejecutar los comandos de procesamiento en paralelo. Este valor se alinea con la propiedad MaxParallelism que se puede establecer en el comando de secuencia de TMSL o mediante otros métodos. 10
RetryCount Int Indica el número de veces que se vuelve a intentar la operación antes de un error. 0
Objects Matriz Una matriz de objetos que se va a procesar. Cada objeto incluye: "table" al procesar la tabla completa o "table" y "partition" al procesar una partición. Si no se especifica ningún objeto, se actualiza el modelo completo. Process the entire model

La especificación de partialBatch para CommitMode es útil cuando se realiza una carga inicial de grandes conjuntos de datos que podría tardar horas. Si se produce un error en la operación de actualización después de confirmar correctamente uno o varios lotes, los lotes confirmados correctamente permanecerán confirmados (no se revertirán los lotes confirmados correctamente).

Nota:

En el momento de escribir este artículo, el tamaño del lote es el valor de MaxParallelism, pero este valor puede cambiar.

Valores de estado

Valor de estado Descripción
notStarted La operación todavía no se ha iniciado.
inProgress Operación en curso.
timedOut Se ha agotado el tiempo de espera de la operación según el tiempo de espera especificado por el usuario.
cancelled Operación cancelada por el usuario o el sistema.
failed No se pudo realizar la operación.
succeeded Operación realizada correctamente.

GET /refreshes/<refreshId>

Para comprobar el estado de una operación de actualización, use el verbo GET en el identificador de la actualización. Este es un ejemplo del cuerpo de la respuesta. Si la operación está en curso, inProgress se devuelve en el estado.

{
    "startTime": "2017-12-07T02:06:57.1838734Z",
    "endTime": "2017-12-07T02:07:00.4929675Z",
    "type": "full",
    "status": "succeeded",
    "currentRefreshType": "full",
    "objects": [
        {
            "table": "DimCustomer",
            "partition": "DimCustomer",
            "status": "succeeded"
        },
        {
            "table": "DimDate",
            "partition": "DimDate",
            "status": "succeeded"
        }
    ]
}

GET /refreshes

Para obtener una lista de las operaciones de actualización históricas de un modelo, use el verbo GET en la colección /refreshes. Este es un ejemplo del cuerpo de la respuesta.

Nota:

En el momento de escribir este artículo, se almacenan y se devuelven los últimos treinta días de las operaciones de actualización, pero este número podría cambiar.

[
    {
        "refreshId": "1344a272-7893-4afa-a4b3-3fb87222fdac",
        "startTime": "2017-12-07T02:06:57.1838734Z",
        "endTime": "2017-12-07T02:07:00.4929675Z",
        "status": "succeeded"
    },
    {
        "refreshId": "474fc5a0-3d69-4c5d-adb4-8a846fa5580b",
        "startTime": "2017-12-07T01:05:54.157324Z",
        "endTime": "2017-12-07T01:05:57.353371Z",
        "status": "succeeded"
    }
]

DELETE /refreshes/<refreshId>

Para cancelar una operación de actualización en curso, utilice el verbo DELETE en el identificador de la actualización.

POST /sync

Tras realizar las operaciones de actualización, puede ser necesario sincronizar los nuevos datos con réplicas para la escalabilidad horizontal de la consulta. Para llevar a cabo una operación de sincronización de un modelo, use el verbo POST en la función /sync. El encabezado de ubicación de la respuesta incluye el identificador de la operación de sincronización.

GET /sync status

Para comprobar el estado de una operación de sincronización, utilice el verbo GET pasando el identificador de la operación como un parámetro. Este es un ejemplo del cuerpo de la respuesta:

{
    "operationId": "cd5e16c6-6d4e-4347-86a0-762bdf5b4875",
    "database": "AdventureWorks2",
    "UpdatedAt": "2017-12-09T02:44:26.18",
    "StartedAt": "2017-12-09T02:44:20.743",
    "syncstate": 2,
    "details": null
}

Los valores para syncstate:

  • 0: Replicando. Los archivos de base de datos se replican en una carpeta de destino.
  • 1: Rehidratando. La base de datos se rehidrata en las instancias de servidor de solo lectura.
  • 2: Completado. La operación de sincronización se completó correctamente.
  • 3: Error. Error en la operación de sincronización.
  • 4: Finalizando. La operación de sincronización se completó, pero está realizando los pasos de limpieza.

Código de ejemplo

Este es un ejemplo de código de C# para comenzar, RestApiSample en GitHub.

Para usar el código de ejemplo

  1. Clone o descargue el repositorio. Abra la solución RestApiSample.
  2. Busque la línea client.BaseAddress = y proporcione la URL base.

El ejemplo de código usa autenticación de entidad de servicio.

Entidad de servicio

Vea Creación de una entidad de servicio: Azure Portal y Adición de una entidad de servicio al rol de administrador del servidor para obtener más información y los pasos sobre cómo configurar una entidad de servicio y asignar los permisos necesarios en Azure AS. Después, siga estos pasos adicionales:

  1. En el código de ejemplo, busque string authority = … y reemplace common por el identificador del inquilino de su organización.
  2. Comente o quite la marca de comentario para que se use la clase ClientCredential para crear una instancia del objeto creado. Asegúrese de que se accede a los valores <Id. de aplicación> y <Clave de la aplicación> de forma segura o use una autenticación basada en certificado para las entidades de servicio.
  3. Ejecute el ejemplo.

Consulte también

Muestras
REST API