Nota:
El acceso a esta página requiere autorización. Puede intentar iniciar sesión o cambiar directorios.
El acceso a esta página requiere autorización. Puede intentar cambiar los directorios.
Este ejemplo .NET 6.0 demuestra cómo realizar operaciones de datos paralelos utilizando la API web de Dataverse.
Esta muestra utiliza el código auxiliar común de la biblioteca de clases WebAPIService (C#).
Requisitos previos
- Microsoft Visual Studio 2022.
- Acceso a Dataverse con privilegios para realizar operaciones de datos.
Cómo ejecutar esta muestra
Clonar o descargar el repositorio de ejemplos de PowerApps.
Localice la carpeta /dataverse/webapi/C#-NETx/ParallelOperations/.
Abrir el archivo
ParallelOperations.slnusando Visual Studio 2022Editar el archivo
appsettings.jsonpara establecer los siguientes valores de propiedad:Property Instrucciones UrlLa URL para su entorno. Reemplazar el valor de marcador de posición https://yourorg.api.crm.dynamics.comcon el valor para su entorno. Consulte Ver recursos de desarrollador para encontrar la URL de su entorno.UserPrincipalNameReemplazar el valor de marcador de posición you@yourorg.onmicrosoft.comcon el valor de UPN que usa para acceder al entorno.PasswordReemplazar el valor de marcador de posición yourPasswordcon la contraseña que utiliza.Guarde el archivo
appsettings.jsonPresione F5 para ejecutar el ejemplo.
Código
El código para este ejemplo está aquí: PowerApps-Samples/dataverse/webapi/C#-NETx/ParallelOperations/Program.cs
Demostraciones
Esta muestra incluye configuraciones que puede aplicar para optimizar su conexión.
Esta muestra primero envía una solicitud simplemente para acceder al valor del encabezado de respuesta x-ms-dop-hint para determinar los grados recomendados de paralelismo para este entorno. Cuando el grado máximo de paralelismo se establece igual al valor del encabezado de respuesta x-ms-dop-hint, debe lograr un estado estable en el que el rendimiento se optimice con un mínimo de 429 TooManyRequests se devolvieron errores de límite de protección de servicio.
Para encontrar límites de protección de servicio con esta muestra, debe aumentar la variable numberOfRecords a más de 10.000 o lo que sea necesario para que la muestra funcione durante más de 5 minutos. También debe cambiar el código para configurar maxDegreeOfParallelism ser significativamente mayor que el valor de x-ms-dop-hint del encabezado de respuesta. Luego, al usar Fiddler, debería poder observar cómo WebAPIService vuelve a intentar las solicitudes que devuelven este error.
Este ejemplo utiliza el método Parallel.ForEachAsync introducido con .NET 6.0.
Esta muestra procesa una lista de solicitudes para crear registros de cuentas, envía las solicitudes en paralelo y luego usa los datos devueltos para agregar solicitudes para eliminar las cuentas creadas en un ConcurrentBag. Después de crear los registros, se muestra la cantidad de segundos para crear los registros.
Luego, las solicitudes de eliminación de ConcurrentBag se procesan y se muestra el tiempo empleado en eliminar los registros.
Es posible que desee comparar este ejemplo con el Ejemplo de operaciones paralelas de API web con componentes de Dataflow TPL (C#).
Limpiar
De forma predeterminada, esta muestra elimina todos los registros creados en ella. Si desea ver los registros creados después de completar la muestra, cambie la variable deleteCreatedRecords a false y se le pedirá que decida si desea eliminar los registros.
Consulte también
Usar la API web de Dataverse
Biblioteca de clases WebAPIService (C#)
Crear una fila de tabla usando la API web
Actualizar y eliminar filas de tablas usando la API web
Límites de la API de protección de servicio
Ejemplos de la API web
Ejemplo de operaciones básicas de la API web (C#)
Ejemplo de datos de consulta de API web (C#)
Ejemplo de operaciones condicionales de la API web (C#)
Ejemplo de funciones y acciones de la API web (C#)
Ejemplo de operaciones de esquema de tabla de API web (C#)
Ejemplo de operaciones paralelas de API web con componentes de flujo de datos TPL (C#)