Recupera vínculos de linaje de datos en varias Google Cloud regiones con un enfoque de distribución. Usa la API de Data Lineage para recuperar y agregar datos de linaje de todas las regiones disponibles. Esto es útil cuando tus recursos de datos se distribuyen en diferentes ubicaciones y necesitas una vista unificada de su linaje.
Para obtener más información, consulta Acerca de la búsqueda de linaje multirregional.
Procedimiento
El procedimiento realiza solicitudes paralelas al extremo projects.locations.searchLinks en cada región. Recopilas resultados, administras la paginación en las regiones y agregas los vínculos encontrados. Administra un regionalPageToken para garantizar una paginación coherente para las llamadas posteriores, teniendo en cuenta las regiones a las que no se puede acceder.
En el siguiente pseudocódigo, se describe un procedimiento que puedes seguir con la API de Data Lineage para recuperar vínculos de linaje de datos de todas las regiones disponibles.
- Configuración de entrada:
linksToFetch= 5 (cantidad de vínculos que se recuperarán de todas las regiones)regionalPageToken= "" (último token de página regional recibido que se usa para la paginación)
- Crear:
- lista de todas las regiones para fan-out llamada
regions - una lista de regiones a las que no se puede acceder llamada
unreachable - una lista vacía de vínculos encontrados llamada
foundLinks - una variable vacía
nextPageTokenynextRegionalPageToken - una variable vacía
lastRegion - una variable vacía
lastRegionLinksCount
- lista de todas las regiones para fan-out llamada
- Ordena
regionsalfabéticamente. - Analiza
regionalPageToken- Si está vacío, continúa con el paso 5.
- Si no está vacío, haz lo siguiente:
- Analiza
regionalPageTokendividiéndolo por el primer punto en dos segmentos. - Filtra las regiones tomando solo las que están después (en orden alfabético) del primer segmento de
regionalPageTokenanalizado. - Almacena el segundo segmento para usarlo en todas las llamadas a projects.locations.searchLinks.
- Analiza
- Realiza una llamada a projects.locations.searchLinks
en cada región de la lista
regionsen paralelo. - Espera a que se completen todas las solicitudes.
- Filtra las respuestas correctas y almacena los nombres de las regiones con errores en la lista
unreachable. - Para cada una de las respuestas (comenzando con la primera región en orden alfabético), haz lo siguiente:
- Si no se devolvieron vínculos junto con un token de página no vacío, haz lo siguiente:
- Almacena el nombre de la región en
lastRegion. - Guarda el pageToken recibido en
nextPageToken. - Ignora las respuestas restantes.
- Almacena el nombre de la región en
- De lo contrario, haz lo siguiente:
- Almacena el nombre de la región en
lastRegion. - Guarda los vínculos recibidos en
foundLinks(hastalinksToFetch). - Guarda el pageToken recibido en
nextPageToken. - Almacena la cantidad de vínculos tomados de la respuesta en
lastRegionLinksCount. - Si
foundLinkses menor quelinksToFetch- Continúa el pseudocódigo con la siguiente respuesta recibida en orden alfabético.
- Si
foundLinkses igual alinksToFetch- Realiza otra solicitud al extremo projects.locations.searchLinks
en la misma región, pero establece el parámetro
pageSizeen el valor delastRegionLinksCount. - Almacena el pageToken recibido en
nextPageToken. - Continúa con el paso 9.
- Realiza otra solicitud al extremo projects.locations.searchLinks
en la misma región, pero establece el parámetro
- Almacena el nombre de la región en
- Si no se devolvieron vínculos junto con un token de página no vacío, haz lo siguiente:
- Antepón
nextPageTokenconlastRegion(es decir,[region].[receivedNextPageToken]) para crearnextRegionalPageTokeny controlar la paginación en llamadas consecutivas.
¿Qué sigue?
Obtén más información sobre la búsqueda de linaje multirregional.
Obtén información para buscar linaje multirregional con la automatización del servidor.
Obtén más información sobre el linaje de datos.