En este documento, se describe cómo configurar una prueba periódica de los vínculos contenidos en un URI mediante la creación de un monitor sintético. Especificas las opciones para la prueba, como el URI de origen, la cantidad de vínculos probados y la cantidad de reintentos, y, luego, implementas una función de Cloud Run preconfigurada. Para respaldar tus esfuerzos de solución de problemas y depuración, los monitores sintéticos guardan información detallada sobre cada prueba, incluidas las capturas de pantalla. Las capturas de pantalla te permiten ver la respuesta exacta que ven los clientes de tu aplicación.
Para obtener más información sobre los supervisores sintéticos, consulta Acerca de los supervisores sintéticos.
Acerca de los verificadores de vínculos rotos
Cada verificador de vínculos rotos prueba los vínculos de forma serial, y hay un tiempo de espera sintético general, que se puede configurar.
De forma predeterminada, un verificador de vínculos rotos hace lo siguiente:
- Busca elementos de anclaje HTML con atributos
href
en el URI de origen. - Prueba los primeros 10 vínculos que se encuentran en el URI de origen.
- Para cada vínculo, el verificador emite una solicitud y, luego, espera como máximo 30 segundos por una respuesta. Cuando se recibe una respuesta, el verificador verifica que el estado de la respuesta HTTP sea
200
, lo que indica que la respuesta se realizó correctamente. El verificador no realiza reintentos.
Especifica el URI de origen. Puedes configurar qué elementos HTML busca el verificador de vínculos rotos, la cantidad máxima de elementos probados, el tiempo de espera por prueba y si se realizan reintentos. También puedes configurar verificadores de vínculos rotos para que esperen a que aparezca un selector.
Los verificadores de vínculos rotos usan la plantilla broken-links-ok
. El objeto options
del archivo index.js
especifica la configuración de un verificador de vínculos rotos. Si creas tu verificador con la
consola de Google Cloud, se te solicitará cada opción de configuración y
se actualizará la función de Cloud Run por ti. Sin embargo, si usas la API de Cloud Monitoring o Terraform, debes propagar este objeto.
Después de crear un verificador de vínculos rotos, para modificar la configuración, actualiza
el objeto options
y vuelve a implementar la función de Cloud Run.
Antes de comenzar
-
Para obtener los permisos que necesitas para ver y modificar monitores sintéticos con la consola de Google Cloud, pídele a tu administrador que te otorgue los siguientes roles de IAM en tu proyecto:
-
Editor de Monitoring (
roles/monitoring.editor
) -
Desarrollador de Cloud Functions (
roles/cloudfunctions.developer
)
Para obtener más información sobre cómo otorgar roles, consulta Administra el acceso a proyectos, carpetas y organizaciones.
También puedes obtener los permisos necesarios mediante roles personalizados o cualquier otro rol predefinido.
-
Editor de Monitoring (
-
Enable the Cloud Monitoring API, Artifact Registry API, Cloud Build API, Cloud Functions API, Cloud Logging API, Pub/Sub API, and Cloud Run Admin API APIs.
Verifica que tu proyecto de Google Cloud contenga la cuenta de servicio predeterminada de Compute Engine. Esta cuenta de servicio se crea cuando habilitas la API de Compute Engine y tiene un nombre similar a
12345-compute@developer.gserviceaccount.com
.En la consola de Google Cloud, ve a la página Cuentas de servicio:
Si usas la barra de búsqueda para encontrar esta página, selecciona el resultado cuyo subtítulo es IAM y administrador.
Si no existe la cuenta de servicio predeterminada de Compute Engine, haz clic en Crear cuenta de servicio y completa el cuadro de diálogo.
Asegúrate de que se le haya otorgado el rol de editor (
roles/editor
) a la cuenta de servicio predeterminada de Compute Engine o a la que creaste.Para ver los roles otorgados a tu cuenta de servicio, haz lo siguiente:
-
En la consola de Google Cloud, ve a la página IAM:
Si usas la barra de búsqueda para encontrar esta página, selecciona el resultado cuyo subtítulo es IAM y administrador.
- Selecciona Incluir asignaciones de roles proporcionadas por Google.
- Si la cuenta de servicio que usa tu monitor sintético no aparece en la lista o si no se le otorgó un rol que incluya los permisos del rol de agente de Cloud Trace (
roles/cloudtrace.agent
), otorga este rol a tu cuenta de servicio.
-
- Configura los canales de notificaciones que deseas usar para recibir notificaciones. Te recomendamos que crees varios tipos de canales de notificaciones. Para obtener más información, consulta Cómo crear y administrar canales de notificaciones y Cómo crear y administrar canales de notificaciones con la API.
Crea un verificador de vínculos rotos
Console
Cuando creas un monitor sintético con la consola de Google Cloud, se implementa una función de Cloud Run (2ª gen.) nueva y se crea el monitor para esa función de Cloud Run. No puedes crear un monitor sintético que supervise una función de Cloud Run existente.
- Asegúrate de haber habilitado las APIs requeridas, de que tu proyecto contenga una cuenta de servicio predeterminada de Compute Engine y de que a esta cuenta se le haya otorgado el rol de editor (
roles/editor
). Para obtener más información, consulta Antes de comenzar. -
En la consola de Google Cloud, ve a la página Synthetic monitoring:
Si usas la barra de búsqueda para encontrar esta página, selecciona el resultado cuyo subtítulo es Monitoring.
- Selecciona Crear monitor sintético.
- En la plantilla, selecciona Verificador de vínculos rotos.
- Ingresa un nombre para el monitor sintético.
Opcional: Actualiza el tiempo de espera de la respuesta, la frecuencia de verificación y agrega etiquetas definidas por el usuario.
Configura el URI y los elementos que se probarán:
Haz clic en URI de origen y, luego, ingresa el URI que deseas probar. El valor que ingreses debe ser un extremo HTTP o HTTPS. Por ejemplo, puedes ingresar
https://mywebsite.example.com
.Opcional: En Cantidad de vínculos que se deben seguir, actualiza la cantidad máxima de vínculos que se prueban. El valor predeterminado de este campo es 10.
Opcional: En el campo Selector de elementos HTML, ingresa el elemento HTML que deseas que coincida, como una lista separada por comas. El valor que ingresas se convierte en una cadena y, luego, se pasa al método
Document: querySelectorAll()
.De forma predeterminada, este campo se establece en
a
, que coincide con las anclas. Puedes ingresar valores comoa, img
cuando quieras hacer coincidir las anclas y las imágenes.Opcional: En el campo Atributos HTML que se deben seguir, ingresa los atributos HTML que deseas que coincidan. Los valores separados por comas que ingreses se pasan de forma individual al método
getAttribute()
.De forma predeterminada, este campo se establece en
href
, que especifica el URI del vínculo. Puedes ingresar varios atributos, por ejemplo, puedes ingresarhref, src
. En este ejemplo, el código busca el atributohref
y, luego, el atributosrc
.Opcional: Configura el selector de espera, el tiempo de espera por URI, los reintentos y los códigos de estado esperados:
- Haz clic en Mostrar más opciones.
Para configurar el verificador de vínculos rotos de modo que espere a que aparezca un selector específico en el URI antes de que se extraigan los vínculos, ingresa los selectores CSS en el campo Esperar selector de elementos. El valor que ingresas se convierte en una cadena y, luego, se pasa al método
page.waitForSelector()
.Si el selector no aparece antes de que venza el tiempo de espera, el error se registra en los registros.
Actualiza el orden en que se seleccionan los vínculos para la prueba.
Configura los reintentos.
De forma predeterminada, se envía una solicitud a cada vínculo y, si la solicitud inicial falla por algún motivo, por ejemplo, si se agota el tiempo de espera del comando o el código de estado HTTP no es
200
, el vínculo se marca como fallido.Este campo especifica la cantidad de veces que el verificador de vínculos rotos puede emitir una solicitud HTTP a un vínculo antes de marcarlo como fallido.
Configura un tiempo de espera que se aplique a cada URI. De forma predeterminada, este valor se establece en 30 segundos.
Para especificar el código de estado y el tiempo de espera esperados para un URI específico, haz clic en Agregar opción por vínculo y completa el cuadro de diálogo.
Opcional: Configura si se recopilan y guardan capturas de pantalla de las respuestas. Si usas la configuración predeterminada, no se guardarán las capturas de pantalla. Si habilitas la recopilación de capturas de pantalla, puedes recopilarlas para todas las pruebas o solo para las que fallan. Cloud Monitoring usa la siguiente convención para nombrar el bucket de Cloud Storage:
gcm-PROJECT_ID-synthetics-LOCATION
En la expresión anterior:
- PROJECT_ID: El ID del proyecto de Google Cloud.
- LOCATION: Es la ubicación de tu bucket de Cloud Storage.
Puedes usar un bucket de Cloud Storage existente.
Revisa tu configuración y asegúrate de que sea correcta y esté completa y, luego, crea tu función de Cloud Run:
Haz clic en Crear función.
Los valores de los campos de configuración de URI se copian en el objeto
Options
del archivoindex.js
cuando haces clic en Crear función. Después de hacer clic en Crear función, para cambiar la configuración, edita el objetoOptions
.Ingresa un nombre visible y selecciona una región. Los nombres deben ser únicos dentro de una región.
En la sección Configuración del entorno de ejecución, la compilación, las conexiones y la seguridad, haz lo siguiente:
En la pestaña Conexiones, asegúrate de que esté seleccionada la opción Permitir todo el tráfico.
Revisa la configuración predeterminada y actualízala cuando sea necesario.
En el campo Cuenta de servicio del entorno de ejecución, selecciona una cuenta de servicio.
Haz clic en Aplicar función.
Configura la política de alertas:
Opcional: Actualiza el nombre de la política de alertas y la duración de la falla antes de que se envíen las notificaciones.
Agrega los canales de notificaciones.
Haz clic en Crear.
La función de Cloud Run que definiste se compila y se implementa como 2ª gen., y se crea el monitor sintético.
API
El proceso de crear un verificador de vínculos rotos con la API de Cloud Monitoring es idéntico al proceso de crear cualquier otro monitor sintético. Si deseas obtener información para usar la API de Cloud Monitoring y crear un monitor sintético, consulta Crea un monitor sintético y selecciona la pestaña Cloud Monitoring.
Los verificadores de vínculos rotos usan la plantilla broken-links-ok
. El objeto options
del archivo index.js
especifica la configuración de un verificador de vínculos rotos.
Cuando se define la estructura options.screenshot_options
, el verificador de vínculos rotos recopila capturas de pantalla y las guarda en un bucket de Cloud Storage.
Si el campo screenshot_options.storage_location
no está definido o si el valor es una cadena vacía, Monitoring crea un bucket de Cloud Storage y las capturas de pantalla se guardan en ese bucket.
Monitoring usa la siguiente convención para nombrar el bucket de Cloud Storage:
gcm-PROJECT_ID-synthetics-LOCATION
En la expresión anterior:
- PROJECT_ID: El ID del proyecto de Google Cloud.
- LOCATION: Es la ubicación de tu bucket de Cloud Storage.
Terraform
Si deseas obtener más información para aplicar o quitar una configuración de Terraform, consulta los comandos básicos de Terraform. Para obtener más información, consulta la documentación de referencia del proveedor de Terraform.
El proceso de crear un comprobador de vínculos rotos con Terraform es idéntico al proceso de crear cualquier otro monitor sintético. Para obtener información sobre el uso de Terraform para crear un monitor sintético, consulta Crea un monitor sintético y selecciona la pestaña Terraform.
Los verificadores de vínculos rotos usan la plantilla broken-links-ok
. El objeto options
del archivo index.js
especifica la configuración de un verificador de vínculos rotos.
Cuando se define la estructura options.screenshot_options
, el verificador de vínculos rotos recopila capturas de pantalla y las guarda en un bucket de Cloud Storage.
Si el campo screenshot_options.storage_location
no está definido o si el valor es una cadena vacía, Monitoring crea un bucket de Cloud Storage y las capturas de pantalla se guardan en ese bucket.
Monitoring usa la siguiente convención para nombrar el bucket de Cloud Storage:
gcm-PROJECT_ID-synthetics-LOCATION
En la expresión anterior:
- PROJECT_ID: El ID del proyecto de Google Cloud.
- LOCATION: Es la ubicación de tu bucket de Cloud Storage.
Explorar resultados
Para cada ejecución, un verificador de vínculos rotos hace lo siguiente:
Genera una tabla, en la que cada fila proporciona información sobre las pruebas de un URI específico. La información del resumen incluye el URI de destino, la latencia, el estado y el identificador del elemento HTML. Por ejemplo, esta columna muestra a cuando se prueba un elemento de anclaje HTML. Cuando la fila corresponde al URI de origen, el valor del identificador de elemento HTML es -.
Recopila métricas, datos de seguimiento y datos de registro.
Recopila capturas de pantalla, cuando se configura.
Para obtener más información sobre cómo explorar los datos recopilados, consulta Cómo explorar los resultados del monitor sintético.
Solucionar problemas
En esta sección, se proporciona información que puedes usar para solucionar problemas con los verificadores de vínculos rotos.
No se puede editar la configuración de un verificador de vínculos rotos
Creaste un verificador de vínculos rotos con la consola de Google Cloud y quieres cambiar los elementos HTML que se prueban o modificar el tiempo de espera del URI, los reintentos, el selector de espera y las opciones por vínculo. Sin embargo, cuando editas el verificador de vínculos rotos, la consola de Google Cloud no muestra los campos de configuración.
Para resolver este error, haz lo siguiente:
-
En la consola de Google Cloud, ve a la página Synthetic monitoring:
Si usas la barra de búsqueda para encontrar esta página, selecciona el resultado cuyo subtítulo es Monitoring.
- Busca el monitor sintético que deseas editar, haz clic en more_vert Más opciones y, luego, selecciona Editar.
- Haz clic en Editar función.
Edita el objeto
options
en el archivoindex.js
y, luego, haz clic en Aplicar función.Para obtener información sobre los campos y la sintaxis de este objeto, consulta
broken-links-ok/index.js
.Haz clic en Guardar.
La consola de Google Cloud muestra que no se pueden guardar las capturas de pantalla
Creaste un verificador de vínculos rotos y lo configuraste para guardar capturas de pantalla. Sin embargo, la consola de Google Cloud muestra uno de los siguientes mensajes de advertencia junto con información más detallada:
InvalidStorageLocation
StorageValidationError
BucketCreationError
ScreenshotFileUploadError
Para resolver estos errores, prueba lo siguiente:
Si ves el mensaje
InvalidStorageLocation
, verifica la existencia del bucket de Cloud Storage especificado en el campo llamadooptions.screenshot_options.storage_location
.Visualiza los registros relacionados con tu función de Cloud Run. Para obtener más información, consulta Cómo encontrar registros.
Verifica que la cuenta de servicio que se usa en la función de Cloud Run correspondiente tenga un rol de Identity and Access Management que le permita crear, acceder y escribir en buckets de Cloud Storage.
¿Qué sigue?
- Muestras de monitores sintéticos
- Administrar monitores sintéticos
- Explora los resultados de los monitores sintéticos