azure-application-insights - 应该使用哪个 API 来查询 Application Insights 跟踪日志?
问题描述
我们的 ASP.NET Core 应用程序将跟踪消息记录到 App Insights。我们需要能够查询它们并通过一些自定义维度进行过滤。但是,我找到了 3 个 API,但不确定要使用哪一个:
首先,我不明白这些选项之间的关系。我认为 App Insights 将其数据持久保存到 Log Analytics;但如果是这种情况,我希望只能通过 Log Analytics 进行查询。
无论如何,我只需要知道哪个是最好用的,我希望文档更清晰。我的直觉是使用 App Insights API,因为我们只需要来自 App Insights 的数据,而不需要来自其他来源的数据。
解决方案
#1和#2之间的差异主要是历史性的和趋同的。
Application Insights 在日志分析之前作为产品存在,并且基于不同的底层数据库技术
Application Insights 和 Log Analytics 都融合使用相同的底层数据库,基于 ADX(Azure 数据资源管理器)和相同的 REST API 服务进行查询。因此,虽然您的 #1 和 #2 链接不同,但它们实际上指向同一团队的相同服务后端,但路径/语义在服务看起来取决于入站请求的地方略有不同。
AI 和 LA 都在其 azure 资源之上引入了多租户的概念和一组特定的表/模式。它们有效地向您隐藏了整个数据库,并使其看起来像一个巨大的数据库。
现在甚至可以(建议)将 Application Insights 数据放置在 Log Analytics 工作区中:
https://docs.microsoft.com/en-us/azure/azure-monitor/app/create-workspace-resource
这使您可以将多个 AI 应用程序/组件的数据放入相同的日志分析工作区,以简化跨不同应用程序的查询等
- 将 ADX 视为任何其他类型的数据库产品。如果您创建 ADX 集群实例,您必须创建数据库、管理架构、管理用户等。AI 和 LA 为您完成所有这些工作。因此,在您上面的问题中,指向 ADX SDK 的第三个链接将用于直接与 ADX 集群/数据库通信。我不相信您可以使用它直接与任何 AI/LA 资源对话,但有一些方法可以让 ADX 集群查询 AI/LA 数据:
推荐阅读
- excel - 调用Oracle存储过程时Excel崩溃
- python - Collab 在创建表格数据集时不断循环,但在 Jupyter 上运行时却没有
- ios - 您如何让 Firebase/Crashlytics 上传的 dsym 注册统计建模和百分比?
- python - Tkinter 按钮命令未运行
- javascript - Javascript 检查表单中的空白
- angular - 'items' 隐式具有类型 'any' 因为它没有类型注释并且在其自己的初始化程序中直接或间接引用
- python - pycharm 没有正确显示文档字符串数学?
- javascript - 使用 http-proxy-middleware 从请求中删除标头
- html - 嵌套 id 的 CSS 不会被覆盖
- c# - 从 Xml 响应中获取特定元素值 (RestSharp/C#)