Docs 菜单

命令监控

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

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

本指南包括以下部分:

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

事件名称
说明

在命令启动时创建。

命令成功时创建。

命令不成功时创建。

您可以通过将 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 文档: