Docs 菜单
Docs 主页
/ / /
Rust 驱动程序
/ /

命令监控

在此页面上

  • Overview
  • 事件描述
  • 事件监控示例
  • 示例事件文档
  • CommandStartedEvent
  • CommandSucceededEvent
  • CommandFailedEvent
  • 更多信息
  • API 文档

本指南向您展示如何使用 Rust 驱动程序监控驱动程序发送到 MongoDB 部署的命令的结果。

您可以使用有关应用程序中命令事件的信息,也可以监控命令以了解有关驱动程序如何执行这些命令的更多信息。

本指南包括以下部分:

  • 事件描述描述了驾驶员可以生成的命令事件。

  • 事件订阅示例提供了示例代码,演示如何订阅命令事件。

  • 示例事件文档提供了每个命令事件的示例。

  • 其他信息提供了指向本指南中提及的类型和方法的资源和API文档的链接。

您可以监控以下命令事件:

事件名称
说明
在命令启动时创建。
命令成功时创建。
命令不成功时创建。

您可以通过将 EventHandler实例分配为command_event_handler客户端选项的值来监控命令事件。 要构造处理所有命令事件的EventHandler ,请使用callback()async_callback()方法。

以下示例连接到MongoDB 部署,指示客户端监控命令事件,并打印每个事件:

let mut client_options = ClientOptions::parse("<connection string>").await?;
client_options.command_event_handler = Some(EventHandler::callback(|ev| println!("{:?}", ev)));
let client = Client::with_options(client_options)?;
// ... perform actions with the client to generate events

以下部分显示了每种类型的命令监控事件的输出示例。

CommandStartedEvent {
request_id: 12,
db: "testdb",
command_name: "find",
connection: ...,
command: ...,
service_id: ...
}
CommandSucceededEvent {
duration: ...,
reply: ...,
command_name: "find",
request_id: 12,
connection: ...,
service_id: ...,
}
CommandFailedEvent {
duration: ...,
command_name: "find",
failure: ...,
request_id: 12,
connection: ...,
service_id: ...,
}

要了解有关监控 MongoDB 部署的更多信息,请参阅如何监控 MongoDB一文。

要学习;了解有关执行MongoDB操作的更多信息,请参阅 CRUD操作指南。

要进一步了解本指南所提及的方法和类型,请参阅以下 API 文档:

后退

集群监控