Importante
Actualización de versión principal: Esta versión del agente de Ruby es una actualización MAYOR de SemVer y contiene cambios importantes. Las versiones MAYORES pueden dejar de ser compatibles con los entornos de ejecución de lenguaje que hayan llegado al final de su vida útil según el mantenedor. Además, las versiones MAYORES pueden dejar de ser compatibles y eliminar ciertas instrumentaciones. Para obtener más detalles sobre estos cambios, consulte la guía de migración aquí.
Importante
Recomendamos actualizar a la última versión del agente tan pronto como esté disponible. Si no puede actualizar a la última versión, actualice su agente a una versión que no tenga más de 90 días de antigüedad. Obtenga más información sobre cómo mantener al agente actualizado.
Consulte la política de fin de vida del agente Ruby New Relic para obtener información sobre los lanzamientos del agente y las fechas de soporte.
v10.0.0
Cambio importante: Eliminar la compatibilidad con Ruby 2.4 y 2.5
Se ha eliminado la compatibilidad con las versiones 2.4 y 2.5 de Ruby. La nueva versión mínima requerida de Ruby es ahora la 2.6. PR#3314
Cambio importante: Eliminación del rastreo entre aplicaciones (CAT)
Anteriormente, el Cross Application Tracing (CAT) fue desaprobado a favor del Distributed Tracing. La funcionalidad CAT ahora ha sido eliminada. La opción de configuración
cross_application_tracer.enabledha sido eliminada. Los métodos de la API públicaNewRelic::Agent::External.process_request_metadata,NewRelic::Agent::External.get_response_metadata,NewRelic::Agent::Transaction::ExternalRequestSegment#process_response_metadata,NewRelic::Agent::Transaction::ExternalRequestSegment#get_request_metadatayNewRelic::Agent::Transaction::ExternalRequestSegment#read_response_headerstambién se han eliminado. PR#3333Cambio importante: Renombrar las métricas y segmentos de ActiveJob
Las métricas de ActiveJob se han actualizado para incluir el nombre de la clase del trabajo para informes más específicos. Este es un cambio importante y puede requerir la actualización de paneles o alertas personalizadas. PR#3370 PR#3320
- Formato antiguo:
Ruby/ActiveJob/<QueueName>/<Method> - Nuevo formato:
Ruby/ActiveJob/<QueueName>/<ClassName>/<Method>
Además, los segmentos creados para las acciones de puesta en cola de Active Job ahora incluyen la clase de trabajo.
- Formato antiguo:
ActiveJob/<QueueAdapter>/Queue/<Event>/Named/<QueueName> - Nuevo formato:
ActiveJob/<QueueAdapter>/Queue/<Event>/Named/<QueueName>/<ClassName>
- Formato antiguo:
Cambio importante: Renombrar el comando
bin/newrelicabin/newrelic_rpmEl archivo ejecutable para la CLI del agente se ha renombrado de
bin/newrelicabin/newrelic_rpm. Este cambio resuelve un conflicto de nombres con la herramienta CLI independiente de New Relic. PR#3323Cambio importante: Eliminar el comando CLI
newrelic deploymentsEl comando CLI
newrelic deploymentsobsoleto se ha eliminado. Para rastrear los cambios y las implementaciones en New Relic, consulte nuestra guía sobre Seguimiento de cambios para obtener una lista de las opciones disponibles. PR#3299Cambio importante: Eliminar el método NewRelic::Agent::SqlSampler#notice_sql
Los usuarios deben llamar a
NewRelic::Agent::Datastores.notice_sqlen su lugar. PR#3338Cambio importante: Eliminar argumentos no utilizados de varias API de NewRelic::Agent::Datastores
Se han eliminado los argumentos de los métodos de las siguientes API de la clase
NewRelic::Agent::Datastores:NewRelic::Agent::Datastores.notice_sql, anteriormente tenía tres argumentos posicionales,query,scoped_metricyelapsed. Ahora, solo tienequery.NewRelic::Agent::Datastores.notice_statement, anteriormente tenía dos argumentos posicionalesqueryyelapsed. Ahora solo tienequery.NewRelic::Agent::Datastores.wraprequiere un proc. Anteriormente, el proc recibía tres argumentos: el resultado del yield, el nombre de la métrica con ámbito más específico y el tiempo transcurrido de la llamada. Ahora, solo recibe uno: el resultado del yield.
Los valores de los argumentos eliminados se derivan del segmento actual en el momento de la llamada. PR#3347
Cambio importante: Eliminar la función experimental Políticas de seguridad configurables (CSP)
La función experimental, Políticas de seguridad configurables (CSP), ya no es compatible y se ha eliminado. PR#3292
Cambio importante: Eliminar la compatibilidad con las versiones de Puma '<' 3.9.0
La versión mínima de Puma ahora compatible es 3.9.0 o superior. PR#3326
Cambio importante: Mejorar la validación y coerción de la configuración
Los mecanismos internos utilizados para forzar y validar los valores proporcionados para la configuración del agente ahora son más eficientes y precisos.
- Los mensajes de advertencia ahora se registrarán en el archivo newrelic_agent.log cuando se proporcione nil como valor de configuración para una configuración que no lo admita.
- Se permiten valores enteros para los tipos de configuración Float
- Se permiten valores Float para los tipos de configuración Integer
- Se evitan las interrupciones fatales cuando se puede encontrar un valor predeterminado para reemplazar un valor de entrada no válido PR#3341
Cambio importante: Reemplazar la opción 'default' con 'adaptive' para los muestreadores remotos de tracing distribuido
Anteriormente, la opción predeterminada para
distributed_tracing.sampler.remote_parent_sampledydistributed_tracing.sampler.remote_parent_not_samplederadefault, que utilizaba el muestreador adaptativo preexistente. La opcióndefaultha sido renombrada aadaptive. PR#3363Función: Agregar
loggercomo dependenciaLa gema
loggerahora se enumera como una dependencia del agente para garantizar la funcionalidad de logging continuo y la compatibilidad con Ruby 4.0.0 y versiones más recientes. PR#3293Función: Agregar la opción de configuración de lista de permitidos de notificación de Active Support
Una nueva opción de configuración,
instrumentation.active_support_notifications.active_support_events, permite a los usuarios definir una lista de permitidos de nombres de eventos de notificaciones de Active Support a los que el agente debe suscribirse. De forma predeterminada, el agente se suscribe a todos los eventos de Active Support: Caching y Active Support: Messages. PR#3327Función: Usar la compresión Gzip integrada de Ruby
El agente ahora utiliza el método
Zlib.gzipincorporado de la biblioteca estándar de Ruby para la compresión, reemplazando la implementación personalizada anterior. PR#3332Función: Agregar la validación de argumentos para la API
NewRelic::Agent#record_custom_eventLa API
NewRelic::Agent#record_custom_eventahora genera unArgumentErrorcuando se proporciona unevent_typeno válido. Un tipo de evento válido debe consistir solo en caracteres alfanuméricos, guiones bajos (_), dos puntos (:) o espacios (). PR#3319Función: Agregar opciones de configuración de muestreo raíz
Ahora puede configurar el comportamiento de muestreo para los rastreos que se originan dentro del servicio actual utilizando
distributed_tracing.sampler.root. PR#3330Hay cuatro modos disponibles:
Modo Descripción adaptiveUtiliza el algoritmo de muestreador adaptativo existente always_offMarca el 0% de los rastreos raíz como muestreados always_onMarca el 100% de los rastreos raíz como muestreados trace_id_ratio_basedMuestras de trazas basadas en una proporción establecida en distributed_tracing.sampler.root.trace_id_ratio_based.ratio. La proporción debe ser un flotante entre 0.0 y 1.0Función: Agregar opciones de muestreo basadas en la proporción de ID de rastreo
El agente ahora puede muestrear rastreos utilizando el algoritmo de muestreador basado en la proporción de ID de rastreo de OpenTelemetry. PR#3330 Esto muestrea rastreos en función de una probabilidad entre 0,0 y 1,0 basada en el ID de rastreo.
Para usar esta opción, primero debe configurar su configuración de muestreador de rastreo distribuido en
trace_id_ratio_basedy luego configurar el muestreadordistributed_tracing.sampler.*.trace_id_ratio_based.ratiocorrespondiente en un Float entre 0.0 y 1.0.Por ejemplo:
distributed_tracing.sampler.remote_parent_sampled: 'trace_id_ratio_based'distributed_tracing.sampler.remote_parent_sampled.trace_id_ratio_based.ratio': 0.5Esta configuración muestrearía aproximadamente el 50% de sus rastreos para todos los rastreos donde el elemento principal remoto se muestrea.
Esta opción está disponible para:
distributed_tracing.sampler.rootdistributed_tracing.sampler.remote_parent_sampleddistributed_tracing.sampler.remote_parent_not_sampled
Función: Agregar GUID de entidad a los archivos de comprobación de estado de Agent Control
Cuando el agente se inicia dentro de un entorno de Control de agente, se crea un archivo de verificación de estado en la ubicación de archivo configurada para cada proceso de agente. Este archivo ahora incluye el guid de la entidad relacionada con el agente cuando está disponible. PR#3371
Corrección de errores: Resolver un
NoMethodErroren la detección de utilización de GCP.La lógica de descubrimiento de metadatos de GCP ahora manejará con elegancia
nilo valores inesperados, evitando fallos en la inicialización del servicio. PR#3388
Importante
Recomendamos actualizar a la última versión del agente tan pronto como esté disponible. Si no puede actualizar a la última versión, actualice su agente a una versión que no tenga más de 90 días de antigüedad. Obtenga más información sobre cómo mantener al agente actualizado.
Consulte la política de fin de vida del agente Ruby New Relic para obtener información sobre los lanzamientos del agente y las fechas de soporte.
versión 9.24.0
característica: Recordatorio de desuso para SqlSampler#notice_sql API
El método
NewRelic::Agent::SqlSampler#notice_sqlestá obsoleto y se eliminará en una futura versión principal. En su lugar, el usuario debería llamar aNewRelic::Agent::Datastores.notice_sql. PR#3345característica: Aviso de desuso para el segundo y tercer argumento en Datastores.notice_sql API
El segundo (
scoped_metric) y tercer (elapsed) argumento del métodoNewRelic::Agent::Datastores.notice_sqlestán obsoletos. Hace tiempo que no se emplean con este método. En cambio, estos valores se establecerán en función del segmento actual cuando se llame a la API. PR#3345característica: Aviso de desuso para el segundo argumento en Datastores.notice_statement API
El segundo argumento (
elapsed) en el métodoNewRelic::Agent::Datastores.notice_statementestá obsoleto. Hace tiempo que no se emplea este método. En cambio, este valor se establecerá en función del segmento actual cuando se llama a la API. PR#3346característica: Aviso de desuso para el segundo y tercer argumento de proc en APIDatastores.wrap
El método
NewRelic::Agent::Datastores.wrapestá cambiando. En una futura versión principal, proc solo aceptará un único argumento, el resultado del rendimiento. El nombre de la métrica con alcance y los argumentos transcurridos se eliminarán, ya que se eliminan del métodoDatastores.notice_sql. El nombre de la métrica con alcance y los valores transcurridos se derivan del segmento actual cuando se realiza el ajuste. PR#3346
Importante
Recomendamos actualizar a la última versión del agente tan pronto como esté disponible. Si no puede actualizar a la última versión, actualice su agente a una versión que no tenga más de 90 días de antigüedad. Obtenga más información sobre cómo mantener al agente actualizado.
Consulte la política de fin de vida del agente Ruby New Relic para obtener información sobre los lanzamientos del agente y las fechas de soporte.
v9.23.0
característica: Agregar sidekiq.ignore_retry_errors opción de configuración
Se agregó una nueva opción de configuración,
sidekiq.ignore_retry_errors, para controlar si se capturan los reintentos de trabajo de Sidekiq. Los errores de reintento se capturan de forma predeterminada, pero ahora sisidekiq.ignore_retry_errorsse establece entrue, el agente ignorará las excepciones generadas durante los intentos de reintento de Sidekiq y solo informará el error si el trabajo falla permanentemente. Gracias DonGiulio por reconocer esta mejora y aportar una solución. PR#3317característica: Aviso de obsolescencia para la grabación de despliegue mediante Capistrano
El envío de información de despliegue de aplicaciones mediante una receta de Capistrano está obsoleto y se eliminará en la versión 10.0.0 del agente. Para el registro de despliegue, consulte nuestra guía de seguimiento de cambios para obtener una lista de las opciones disponibles.
característica: Emplee la configuración de ejemplificación principal remota para tomar decisiones en más escenarios
Anteriormente, las opciones de configuración
distributed_tracing.sampler.remote_parent_sampledydistributed_tracing.sampler.remote_parent_not_sampledse empleaban para la decisión de ejemplificación sola cuando estaban presentes los encabezadostraceparentytracestate. Ahora, estas opciones de configuración se aplican en los casos en que falta el encabezadotracestatey cuando solo está disponible el encabezadonewrelic. Este cambio hace que la ejemplificación de latitud distribuida sea más consistente y previsible. PR#3306
Importante
Recomendamos actualizar a la última versión del agente tan pronto como esté disponible. Si no puede actualizar a la última versión, actualice su agente a una versión que no tenga más de 90 días de antigüedad. Obtenga más información sobre cómo mantener al agente actualizado.
Consulte la política de fin de vida del agente Ruby New Relic para obtener información sobre los lanzamientos del agente y las fechas de soporte.
versión 9.22.0
característica: Instrumentación en un solo paso para Kubernetes
El APM Kubernetes implementa automáticamente la conexión automática de la aplicación y gestiona las actualizaciones del agente dentro del despliegue Kubernetes. Esta función salió de la vista previa y ahora está disponible de forma general. Obtenga más información sobre la conexión automática de Kubernetes. PR#2635 PR#3287
Característica: Aviso de desuso para Ruby 2.4 y Ruby 2.5
La compatibilidad del agente Ruby con las versiones Ruby 2.4 y 2.5 está obsoleta y se eliminará en la versión 10.0.0 del agente. La nueva versión mínima requerida de Ruby será Ruby 2.6 y dejaremos de realizar pruebas con Ruby 2.4 y 2.5. PR#3288
Característica: Aviso de desuso del comando
newrelic deploymentsLa compatibilidad para grabar la implementación mediante el comando
newrelic deploymentsahora está obsoleta y se eliminará en la versión 10.0.0 del agente.En el futuro, habrá varias formas automatizadas y manuales de registrar cambios en New Relic. Consulte nuestra guía de seguimiento de cambios para obtener una lista de las opciones disponibles. PR#3262
Característica: Recordatorio de obsolescencia para el seguimiento de múltiples aplicaciones
El seguimiento de múltiples aplicaciones quedó obsoleto desde la versión principal 8.0.0 del agente Ruby. Eliminaremos el soporte para este producto por completo en la versión 10.0.0 del agente. PR#3288
Característica: Garantizar la compatibilidad con Ruby 3.5 cambiar al método#source_location
Se actualizó el agente para analizar correctamente el valor de retorno del método #source_location, que está cambiando en Ruby 3.5 de una matriz de dos elementos a una matriz de cinco elementos. Este cambio mantiene el soporte para versiones anteriores de Ruby y al mismo tiempo agrega soporte para la versión futura. PR#3257
Importante
Recomendamos actualizar a la última versión del agente tan pronto como esté disponible. Si no puede actualizar a la última versión, actualice su agente a una versión que no tenga más de 90 días de antigüedad. Obtenga más información sobre cómo mantener al agente actualizado.
Consulte la New Relic Ruby política de fin de vida del agente para obtener información sobre los lanzamientos del agente y las fechas de soporte.
v9.21.0
Característica: En modo Serverless APM, use el nombre de la fuente del evento como prefijo del nombre de la transacción
El agente ahora empleará el nombre de origen del evento como prefijo para el nombre de la transacción en el modo APM Serverless. Esto ayudará a identificar mejor la fuente de la transacción en la UI New Relic. PR#3245
Bugfix: revertir la lógica modificada sobre cómo rastreamos el hilo en el que comienza el lapso
Este cambio restaura el comportamiento anterior de seguimiento del hilo en el que comienza el lapso, solucionando los problemas que surgieron de la lógica actualizada. Gracias @david-zw-liu por informarnos sobre esto. PR#3248