Regroupement personnalisé
Section Overview
La solution Error Tracking regroupe intelligemment les erreurs similaires en problèmes à l’aide d’une stratégie par défaut. En utilisant les empreintes personnalisées, vous pouvez avoir un contrôle total sur vos décisions en matière de regroupement et personnaliser son comportement pour vos spans d’erreurs.
Vous pouvez personnaliser le regroupement en fournissant une empreinte error.fingerprint
pour l’erreur. L’empreinte est fournie dans un attribut ou un tag, en fonction de la source de l’erreur (consultez la section Configuration pour en savoir plus). Bien que la valeur de error.fingerprint
n’ait pas de prérequis en matière de format ni d’exigence, le contenu doit être une chaîne.
Si error.fingerprint
est fourni, le regroupement suit les règles suivantes :
- Le regroupement personnalisé a la priorité sur la stratégie par défaut.
- Le regroupement personnalisé peut être appliqué uniquement à un sous-ensemble de vos erreurs et peut coexister avec la stratégie par défaut.
- Le contenu de
error.fingerprint
est utilisé tel quel, sans aucune modification. - Les erreurs provenant du même service et ayant le même attribut
error.fingerprint
sont regroupées dans le même problème. - Les erreurs présentant différents attributs
service
sont regroupées en différents problèmes.
Configuration
APM
Le regroupement personnalisé ne nécessite qu’un span d’erreur et un tag de span de chaîne error.fingerprint
.
Si vous ne collectez pas déjà des traces APM avec Datadog, consultez la documentation relative à l’APM pour configurer l’APM.
Exemple
Si vous envoyez déjà des spans d’APM, ajoutez un nouveau tag error.fingerprint
à votre span d’erreur.
Voici un exemple dans Python :
with tracer.trace("throws.an.error") as span:
span.set_tag('error.fingerprint', 'my-custom-grouping-material')
raise Exception("Something went wrong")
Les informations relatives à l’exception sont capturées et attachées à un span s’il y en a un d’actif au moment où l’exception est soulevée.
Dans ce cas, my-custom-grouping-material
est utilisé pour regrouper ces spans d’erreurs en un seul problème
dans Error Tracking.
Log Management
Le regroupement personnalisé ne nécessite qu’un log d’erreur et un attribut de chaîne error.fingerprint
.
Si vous ne collectez pas déjà des logs avec Datadog, consultez la documentation relative à Log Management pour configurer des logs.
Assurez-vous que le tag source
(spécifiant la langue) est correctement configuré.
Exemple
Si vous journalisez déjà au format JSON, ajoutez un nouvel attribut error.fingerprint
à votre log d’erreur.
Voici un exemple de log au format JSON dans Python :
import logging
import json_log_formatter
formatter = json_log_formatter.JSONFormatter()
json_handler = logging.FileHandler(filename='/var/log/my-log.json')
json_handler.setFormatter(formatter)
logger = logging.getLogger('my_json')
logger.addHandler(json_handler)
logger.setLevel(logging.INFO)
logger.error('Error processing request', extra={'error.fingerprint': 'my-custom-grouping-material'})
Dans ce cas, my-custom-grouping-material
est utilisé pour regrouper ces logs d’erreurs en un seul problème
dans Error Tracking.
Exemple mobile
Dans les SDK mobiles de Datadog, vous pouvez ajouter une empreinte d’erreur personnalisée lors de l’enregistrement d’une erreur en ajoutant
un attribut prédéfini à l’appel de log :
Pour utiliser le regroupement personnalisé, vous devez disposer du SDK Datadog iOS 2.8.1
ou d’une version plus récente.
let errorFingerprint = "my-custom-grouping-material"
logger.error(
"My error message",
error: error,
attributes: [
Logs.Attributes.errorFingerprint: errorFingerprint
]
)
Pour utiliser le regroupement personnalisé, vous devez disposer du SDK Datadog Android 2.7.0
ou d’une version plus récente.
val errorFingerprint = "my-custom-grouping-material"
val attributes = mapOf(LogAttributes.ERROR_FINGERPRINT to errorFingerprint)
logger.e("My error message", error, attributes)
Pour utiliser le regroupement personnalisé, vous devez disposer du SDK Datadog Flutter 2.4.0
ou d’une version plus récente.
final errorFingerprint = "my-custom-grouping-material";
logger.error(
'My error message',
errorStackTrace: st,
attributes {
DatadogAttributes.errorFingerprint: "my-custom-grouping-material",
}
);
Vous pouvez également ajouter ou ajuster l’empreinte dans le mappeur de log :
Pour utiliser le regroupement personnalisé, vous devez disposer du SDK Datadog iOS 2.8.1
ou d’une version plus récente.
let logsConfiguration = Logs.Configuration(
eventMapper: { log in
var log = log
log.error?.fingerprint = "my-custom-grouping-material"
return log
}
)
Logs.enable(
with: logsConfiguration
)
Pour utiliser le regroupement personnalisé, vous devez disposer du SDK Datadog Android 2.7.0
ou d’une version plus récente.
val mapper = object : EventMapper<LogEvent> {
override fun map(event: LogEvent): LogEvent {
event.fingerprint = "my-custom-grouping-material"
return event
}
}
val logsConfiguration = LogsConfiguration.Builder()
.setEventMapper(mapper)
.build()
Logs.enable(logsConfiguration)
Pour utiliser le regroupement personnalisé, vous devez disposer du SDK Datadog Flutter 2.4.0
ou d’une version plus récente.
LogEvent? mapLogEvent(LogEvent event) {
event.error?.fingerprint = "my-custom-grouping-material";
return event;
}
final loggingConfiguration = DatadogLoggingConfiguration(
eventMapper: mapLogEvent,
);
final configuration = DatadogConfiguration(
// ...
loggingConfiguration: loggingConfiguration,
);
RUM
Exemple
Si vous ne collectez pas déjà des événements du RUM Browser avec Datadog, consultez la documentation relative à la configuration de la surveillance du RUM Browser ou la documentation relative à la configuration de la surveillance de TV et RUM Mobile.
Pour utiliser le regroupement personnalisé, vous avez besoin du SDK Browser Datadog v4.42.0 ou ultérieur, d’une erreur du RUM Browser et d’un attribut de chaîne supplémentaire.
Si vous êtes déjà en train de collecter les erreurs du navigateur, il est possible d’ajouter l’attribut en utilisant l’une ou l’autre des méthodes suivantes :
- Ajouter un attribut
dd_fingerprint
à l’objet error :
import { datadogRum } from '@datadog/browser-rum';
// Send a custom error with context
const error = new Error('Something went wrong');
error.dd_fingerprint = 'my-custom-grouping-fingerprint'
datadogRum.addError(error);
- Ou utiliser le rappel
beforeSend
avec un attribut error.fingerprint
:
DD_RUM.init({
...
beforeSend: () => {
if (event.type === 'error') {
event.error.fingerprint = 'my-custom-grouping-fingerprint'
}
},
})
Dans les deux cas, my-custom-grouping-material
est utilisé pour regrouper les erreurs du RUM Browser en une seule question dans Error Tracking.
Pour utiliser le regroupement personnalisé, vous devez disposer du SDK Datadog iOS 2.8.1
ou d’une version plus récente.
Pour ajouter une empreinte personnalisée lorsque vous signalez manuellement des erreurs, vous pouvez ajouter un attribut prédéfini lorsque vous appelez addError
:
RUMMonitor.shared().addError(
message: "My error message",
source: .source,
attributes: [
RUM.Attributes.errorFingerprint: "my-custom-grouping-fingerprint"
]
)
Vous pouvez également utiliser le mappeur errorEventMapper
:
var config = RUM.Configuration(applicationID: "rum-application-id")
config.errorEventMapper = { errorEvent in
var errorEvent = errorEvent
errorEvent.error.fingerprint = "my-custom-grouping-fingerprint"
return errorEvent
}
RUM.enable(with: config)
Pour utiliser le regroupement personnalisé, vous devez disposer du SDK Datadog Android 2.7.0
ou d’une version plus récente.
Pour ajouter une empreinte personnalisée lorsque vous signalez manuellement des erreurs, vous pouvez ajouter un attribut prédéfini lorsque vous appelez addError
:
GlobalRumMonitor.get().addError(
"My error message",
RumErrorSource.SOURCE,
exception,
mapOf(
RumAttributes.ERROR_CUSTOM_FINGERPRINT to "my-custom-grouping-fingerprint"
)
)
Vous pouvez également utiliser le mappeur errorEventMapper
:
val rumConfiguration = RumConfiguration.Builder("rum-application-id")
.setErrorEventMapper(object : EventMapper<ErrorEvent> {
override fun map(event: ErrorEvent): ErrorEvent {
event.error.fingerprint = "my-custom-grouping-fingerprint"
return event
}
}).build()
RUM.enable(rumConfiguration)
Pour utiliser le regroupement personnalisé, vous devez disposer du SDK Datadog Flutter 2.4.0
ou d’une version plus récente.
Pour ajouter une empreinte personnalisée lorsque vous signalez manuellement des erreurs, vous pouvez ajouter un attribut prédéfini lorsque vous appelez addError
:
final rum = DatadogSdk.instance.rum;
rum?.addErrorInfo("My error message",
RumErrorSource.source,
attributes: {
DatadogAttributes.errorFingerprint: 'my-custom-grouping-fingerprint',
},
);
Vous pouvez également utiliser le mappeur errorEventMapper
:
RumErrorEvent? mapRumErrorEvent(RumErrorEvent event) {
event.error.fingerprint = "my-custom-grouping-fingerprint";
return event;
}
final rumConfiguration = DatadogRumConfiguration(
// ...
errorEventMapper: mapRumErrorEvent,
);
final configuration = DatadogConfiguration(
// ...
rumConfiguration: rumConfiguration,
);