设想
我在 ASP .NET Core 中有一个容器化、事件驱动的微服务应用程序,刚刚迁移到 .NET 5。
所有项目都使用Microsoft.ApplicationInsights 2.16.0,并且我检查了所有遥测数据都已发送并且采样不会影响结果(至少对于每个微服务单独)。
所有项目都向 RabbitMQ 发布和订阅事件。
我有自己的 rabbitmq nuget 包来简化对 RabbitMQ 的访问(它已经正常工作了一年多)。我添加了此代码以在发布事件时发送遥测标识符:
var operation = _telemetryClient.StartOperation<DependencyTelemetry>($"Publish {theEvent.EventName.Replace(".", "-")}");
operation.Telemetry.Type = "Azure Service Bus"; // Just because I like the icon shown in Azure.
operation.Telemetry.Data = JsonConvert.SerializeObject(theEvent);
_basicProperties.Headers["x-telemetry-operationid"] = operation.Telemetry.Context.Operation.Id;
_basicProperties.Headers["x-telemetry-parentOperationId"] = operation.Telemetry.Id;
_channelProvider
.GetChannel()
.BasicPublish(_configuration.Exchange, theEvent.EventName, _basicProperties, Encoding.UTF8.GetBytes(payload));
当收到事件时,我使用此代码跟踪依赖关系:
var operation = _telemetryClient.StartOperation<RequestTelemetry>($"Received {eventName.Replace(".", "-")}");
operation.Telemetry.Context.Operation.Id = basicDeliverEventArgs.BasicProperties.Headers["x-telemetry-operationId"];
operation.Telemetry.Context.Operation.ParentId = basicDeliverEventArgs.BasicProperties.Headers["x-telemetry-operationId"];
// Handle the message...
_telemetryClient.StopOperation(operation);
当一个微服务收到一个 POST 请求时,它会触发一个事件。其他几个微服务正在订阅它,它们也可以发布新事件,这将再次影响另一组微服务。当我单击 POST 请求时,我希望在端到端交易详细信息页面中看到这一切。
但不幸的是,这并没有发生:(
您可以看到“event-one”是如何发布的,以及如何有一个微服务接收它。但没有别的。
现在,如果我搜索事件名称,我不仅会找到发布跟踪,还可以找到更多反映微服务发布的事件的依赖项:
但是,这里仍然缺少很多:每个微服务执行的所有 SQL 调用,微服务在接收事件 2、3 和 4 时执行的所有操作。
实际上,所有这些都在 Application Map 中可用:
这意味着所有遥测都正确存在!
问题
- 我做的一切正确吗?
- 有没有办法在端到端中显示完整的事件链?
提前致谢