MongoDB慢查询临时开启方法讲解

1、首先连接数据库

bash 复制代码
mongosh "mongodb://localhost:27017"

2、选择目标数据库

bash 复制代码
show databases;#显示所有数据库
use lidb;#使用某数据库

3、查看当前分析级别

bash 复制代码
db.getProfilingStatus()

输出

bash 复制代码
{ was: 0, slowms: 100, sampleRate: 1, ok: 1 }
#was=0表示关闭;was=1表示开启

4、开启慢查询日志(临时,重启失效)

bash 复制代码
#方法一
db.setProfilingLevel(1, { slowms: 100 })  // 记录超过100ms的操作
#方法二
db.setProfilingLevel(1, {
  slowms: 100,
  filter: { op: "query" }  // 只记录查询操作
})

再执行如下命令查看状态:

bash 复制代码
db.getProfilingStatus()

输出

bash 复制代码
{ was: 1, slowms: 100, sampleRate: 1, ok: 1 }

表示设置成功

5、查看慢查询记录

bash 复制代码
#查询超过100ms的慢日志
db.system.profile.find({millis: {$gt: 100}})
// 查看最近的慢查询
db.system.profile.find().sort({ ts: -1 }).limit(5).pretty()
// 分析特定慢查询
db.system.profile.find({
  millis: { $gt: 200 },  // 超过200ms的操作
  op: "query"            // 只查询操作
}).pretty()

6、不同数据库不同设置

bash 复制代码
// 设置db1
use db1
db.setProfilingLevel(1, { slowms: 50 })

// 设置db2
use db2
db.setProfilingLevel(1, { slowms: 200 })

7、修改采样率不改变级别

bash 复制代码
// 保持当前级别,只修改采样率
db.setProfilingLevel(1, { sampleRate: 0.3 })

8、修改慢查询阈值(不改变级别)

bash 复制代码
db.adminCommand({ 
  profile: 0,  // 0=保持当前级别
  slowms: 30   // 新阈值
})

9、全局设置(影响所有数据库)

bash 复制代码
db.adminCommand({ 
  setParameter: 1, 
  slowMS: 50 
})

10、生产环境推荐配置

bash 复制代码
db.setProfilingLevel(1, {
  slowms: 50,
  sampleRate: 0.8
})

11、定期清理分析数据

bash 复制代码
// 清空分析数据
db.system.profile.drop()

// 重建集合
db.createCollection("system.profile", {
  capped: true,
  size: 100 * 1024 * 1024  // 100MB
})

12、永久配置

bash 复制代码
# mongod.conf 添加
operationProfiling:
  mode: slowOp
  slowOpThresholdMs: 100
  slowOpSampleRate: 1.0

13、直接查看日志文件

bash 复制代码
# 查看慢查询日志
tail -f /usr/local/mongodb/logs/log.txt | grep "slow query"

# 过滤耗时超过100ms的操作
grep "ms" /usr/local/mongodb/logs/log.txt | awk -F 'ms' '{if ($1 > 100) print $0}'
相关推荐
ZFSS8 小时前
Localization Translate API 集成与使用指南
java·服务器·数据库·人工智能·mysql·ai编程
东风破1379 小时前
达梦DMDRS搭建、以及DMDRS双向同步
数据库·oracle·dm达梦数据库
KaMeidebaby10 小时前
卡梅德生物技术快报|抗独特型抗体开发:半抗原检测技术瓶颈拆解,抗独特型抗体开发工程化实践
前端·数据库·人工智能·其他·百度·新浪微博
NiceCloud喜云10 小时前
Claude Files API 深入:从上传、复用到配额管理的工程化指南
android·java·数据库·人工智能·python·json·飞书
A XMan.11 小时前
域名Whois信息查询V2版API接入指南
数据库
heimeiyingwang11 小时前
【架构实战】可观测性体系:从监控到全链路追踪
网络·数据库·架构
网管NO.111 小时前
SQL 日期函数全套精讲!时间格式化、日期加减、年月日提取,做日报周报直接套用
数据库·sql
杨云龙UP11 小时前
Linux 根分区被日志吃满?一次 58G Broker 日志清理实战_2026-05-20
linux·运维·服务器·数据库·hdfs·apache
sdk大全12 小时前
Studio 3T for MongoDB 2025.13.0
数据库·mongodb
码农阿豪12 小时前
平替MongoDB:金仓多模数据库助力电子证照国产化实践
数据库·mongodb