Cómo programar una transferencia de Facebook Ads

El Servicio de transferencia de datos de BigQuery para el conector de Facebook Ads te permite programar y administrar de forma automática los trabajos de carga recurrentes de Facebook Ads en BigQuery.

Limitaciones

Las transferencias de Facebook Ads están sujetas a las siguientes limitaciones:

  • El tiempo de intervalo mínimo entre las transferencias recurrentes de Facebook Ads es 24 horas. El intervalo predeterminado para una transferencia recurrente es de 24 horas.
  • El Servicio de transferencia de datos de BigQuery para Facebook Ads solo admite un conjunto fijo de tablas. No se admiten los informes personalizados.
  • Las transferencias de Facebook Ads tienen una duración máxima de seis horas. Una transferencia falla si lleva más de esta duración máxima.
  • No se admiten las transferencias incrementales.
  • El Servicio de transferencia de datos de BigQuery admite la transferencia de datos desde un día (ayer) a las tablas AdInsights y AdInsightsActions.
  • El token de acceso de usuario de larga duración que se requiere para las transferencias de Facebook Ads vence después de 60 días.

    Si tu token de acceso de larga duración está vencido, puedes obtener el nuevo; para ello, ve a los detalles de la transferencia y haz clic en Editar. En la página para editar la transferencia, sigue los mismos pasos en Requisitos previos de Facebook Ads para generar un token de acceso de larga duración nuevo.

Antes de comenzar

En las siguientes secciones, se describen los pasos que debes seguir antes de crear una transferencia de Facebook Ads.

Requisitos previos de Facebook Ads

Asegúrate de tener la siguiente información de Facebook Ads cuando crees una transferencia de Facebook Ads.

Parámetros de Facebook Ads Descripción
clientID El nombre del ID de la app para el cliente de OAuth 2.0.
clientSecret El secreto de la app para el cliente de OAuth 2.0.
refreshToken El token de acceso de usuario de larga duración, también conocido como token de actualización.

Para obtener un clientID y un clientSecret, sigue estos pasos:

  1. Crea una app para desarrolladores de Facebook con el tipo de app Business.
  2. En el panel de la app de Facebook, haz clic en Configuración de la app > Básico y busca el ID de la app y el secreto de la app que correspondan a la app.

Para obtener un token de acceso de usuario de larga duración, también conocido como token de actualización, sigue estos pasos:

  1. En la consola de Google Cloud, continúa con los pasos para crear una transferencia de Facebook Ads.

  2. En la sección Detalles de la fuente de datos, copia el URI de redireccionamiento que se muestra después del campo Token de actualización.

    Copia el URI de redireccionamiento

  3. Haz clic en el panel de la app de Facebook y, luego, en Configurar en la sección Acceso con Facebook para empresas.

    Establece la configuración del Acceso con Facebook para empresas

  4. En la página Configuración, ingresa la URL de redireccionamiento en el campo URI de redireccionamiento de OAuth válidos y haz clic en Guardar.

  5. Regresa a la consola de Google Cloud. En la sección Detalles de la fuente de datos, haz clic en Autorizar. Se te redireccionará a la página de autenticación de Facebook.

    Genera un token de acceso de usuario de larga duración

  6. Selecciona la app de desarrollador de Facebook para autorizar la cuenta que se conecta con el Servicio de transferencia de datos de BigQuery.

  7. Cuando termines, haz clic en Entendido para volver a la consola de Google Cloud. El token de acceso de larga duración ahora se propaga en la configuración de la transferencia.

Como alternativa, puedes generar un token de acceso de usuario de larga duración mediante la API de Graph. Se requieren los permisos ads_management, ads_read y business_management para un token válido de la transferencia.

Los tokens de acceso de usuario de larga duración vencen después de 60 días.

Requisitos previos de BigQuery

Roles de BigQuery requeridos

Para obtener los permisos que necesitas para crear una transferencia, pídele a tu administrador que te otorgue el rol de IAM de administrador de BigQuery (roles/bigquery.admin). Para obtener más información sobre cómo otorgar roles, consulta Administra el acceso.

Este rol predefinido contiene los permisos necesarios para crear una transferencia. Para ver los permisos exactos que son necesarios, expande la sección Permisos requeridos:

Permisos necesarios

Se requieren los siguientes permisos para crear una transferencia:

  • bigquery.transfers.update en el usuario
  • bigquery.datasets.get en el conjunto de datos de destino
  • bigquery.datasets.update en el conjunto de datos de destino

También puedes obtener estos permisos con roles personalizados o con otros roles predefinidos

Crea una transferencia de datos de Facebook Ads

Selecciona una de las siguientes opciones:

Console

  1. En la consola de Google Cloud, ve a la página de BigQuery.

    Ve a BigQuery Studio

  2. Haz clic en Transferencias de datos > Crear una transferencia.

  3. En la sección Tipo de fuente, en Fuente, selecciona Facebook Ads.

  4. En la sección Nombre de configuración de la transferencia, en Nombre visible, ingresa el nombre de la transferencia.

  5. En la sección Opciones de programación, haz lo siguiente:

    • En la lista Frecuencia de repetición, selecciona una opción para especificar la frecuencia con la que se ejecuta esta transferencia. Para especificar una frecuencia de repetición personalizada, selecciona Personalizada. Si seleccionas Según demanda, esta transferencia se ejecuta cuando activas la transferencia de forma manual.

    • Si corresponde, selecciona Comenzar ahora o Comenzar a una hora determinada y proporciona una fecha de inicio y una hora de ejecución.

  6. En la sección Configuración de destino, en Conjunto de datos de destino, selecciona el conjunto de datos que creaste para almacenar tus datos.

  7. En la sección Detalles de fuente de datos, haz lo siguiente:

    • En ID de cliente, ingresa el ID de la app.
    • En Secreto del cliente, ingresa el secreto de la app.
    • En Refresh token, ingresa el ID del token de acceso de usuario de larga duración. Para ello, haz clic en Autorizar.

    Para obtener información sobre cómo recuperar estos valores, consulta Requisitos previos de Facebook Ads.

  8. Opcional: En el menú Cuenta de servicio, selecciona una cuenta de servicio de las cuentas de servicio asociadas a tu proyecto de Google Cloud. La cuenta de servicio seleccionada debe tener los roles necesarios para ejecutar esta transferencia.

    Si accediste con una identidad federada, se requiere una cuenta de servicio para crear una transferencia. Si accediste con una Cuenta de Google, la cuenta de servicio para la transferencia es opcional.

    Para obtener más información sobre el uso de cuentas de servicio con transferencias de datos, consulta Usa cuentas de servicio.

  9. Opcional: En la sección Opciones de notificación, haz lo siguiente:

    • Para habilitar las notificaciones por correo electrónico, haz clic en el botón de activar o desactivar Notificación por correo electrónico. Si habilitas esta opción, el administrador de transferencias recibirá una notificación por correo electrónico cuando falle la ejecución de una transferencia.
    • Si quieres habilitar las notificaciones de ejecución de transferencias de Pub/Sub para esta transferencia, haz clic en el botón de activar Notificaciones de Pub/Sub. Puedes seleccionar el nombre del tema o hacer clic en Crear un tema para crear uno.
  10. Haz clic en Guardar.

Cuando se ejecuta esta transferencia, el Servicio de transferencia de datos de BigQuery propaga automáticamente las siguientes tablas.

Nombre de la tabla Descripción
AdAccounts Son las cuentas de anuncios disponibles para un usuario.
AdInsights Informe de estadísticas de anuncios para todas las cuentas de anuncios.
AdInsightsActions Informe de acciones de estadísticas de anuncios para todas las cuentas de anuncios.

bq

Ingresa el comando bq mk y suministra la marca de creación de transferencias --transfer_config.

bq mk \
    --transfer_config \
    --project_id=PROJECT_ID \
    --data_source=DATA_SOURCE \
    --display_name=DISPLAY_NAME \
    --target_dataset=DATASET \
    --params='PARAMETERS'

Aquí:

  • PROJECT_ID (opcional): Tu ID del proyecto de Google Cloud. Si no se proporciona --project_id para especificar un proyecto en particular, se usa el proyecto predeterminado.
  • DATA_SOURCE: es la fuente de datos (por ejemplo, facebook-ads).
  • DISPLAY_NAME es el nombre visible de la configuración de transferencia. El nombre de la transferencia puede ser cualquier valor que te permita identificarla con facilidad si es necesario hacerle modificaciones más tarde.
  • DATASET es el conjunto de datos de destino para la configuración de transferencia.
  • PARAMETERS son los parámetros de la configuración de transferencia creada en formato JSON. Por ejemplo: --params='{"param":"param_value"}' Los siguientes son los parámetros para una transferencia de Facebook Ads:
    • connector.authentication.oauth.clientId: El nombre del ID de la app para el cliente de OAuth 2.0.
    • connector.authentication.oauth.clientSecret: El secreto de la app para el cliente de OAuth 2.0.
    • connector.authentication.oauth.refreshToken: El ID del token de larga duración.

Por ejemplo, el siguiente comando crea una transferencia de Facebook Ads en el proyecto predeterminado con todos los parámetros requeridos:

    bq mk 
--transfer_config
--target_dataset=mydataset
--data_source=facebook_ads
--display_name='My Transfer'
--params='{"connector.authentication.oauth.clientId": "1650000000", "connector.authentication.oauth.clientSecret":"TBA99550", "connector.authentication.oauth.refreshToken":"abcdef"}'

API

Usa el método projects.locations.transferConfigs.create y suministra una instancia del recurso TransferConfig.

Soluciona problemas con la configuración de una transferencia

Si tienes problemas para configurar una transferencia de Facebook Ads, prueba los siguientes pasos para solucionar problemas:

  • Comprueba que el token de acceso de larga duración no haya vencido. Los tokens de acceso de larga duración vencen después de 60 días. Si tu token de acceso de larga duración venció, navega a los detalles de tu transferencia y, luego, haz clic en Editar para modificar la configuración de tu transferencia. En la página para editar la transferencia, sigue los mismos pasos en Requisitos previos de Facebook Ads para generar uno nuevo.
  • Comprueba que el token de acceso de larga duración se genere con los permisos requeridos: ads_management, ads_read y business_management. Si no es así, sigue los pasos que se indican en los requisitos previos de Facebook Ads para generar un token de acceso de larga duración nuevo.
  • Revisa la pestaña Acciones requeridas en el panel de la app de Facebook para cualquier elemento que requiera atención.

Es posible que veas los siguientes mensajes de error relacionados con errores de límite de frecuencia de la API de Meta:

Error: Please reduce the amount of data you're asking for, then retry your request.
Error: There have been too many calls from this ad-account. Wait a bit and try again.
Resolución: Verifica que no haya flujos de trabajo paralelos que usen las mismas apps o credenciales. Si estos errores persisten, actualiza el nivel de tu app para reducir el límite de frecuencia.

Mensajes comunes de métricas de supervisión

También puedes consultar las métricas de supervisión del Servicio de transferencia de datos de BigQuery para determinar la causa de una falla en la transferencia. En la siguiente tabla, se mencionan algunos mensajes ERROR_CODE comunes para las transferencias de Facebook Ads.

Error Descripción
INVALID_ARGUMENT La configuración proporcionada no es válida
PERMISSION_DENIED Las credenciales no son válidas
UNAUTHENTICATED Se requiere autenticación
SERVICE_UNAVAILABLE El servicio no puede manejar temporalmente esta transferencia
DEADLINE_EXCEEDED La transferencia no finalizó en el plazo máximo de seis horas
NOT_FOUND No se encontró un recurso solicitado
INTERNAL Otro problema causó que el conector fallara
RESOURCE_EXHAUSTED Se agotó una cuota o un límite de fuente de datos

Precios

No se aplican costos por transferir datos de Facebook Ads a BigQuery mientras esta función está en vista previa.

¿Qué sigue?