mongodb 使用内存过大分析

ps aux

内存使用

复制代码
ps aux|head -1;ps aux|grep -v PID|sort -rn -k +4|head -10

swap 使用

复制代码
for i in $(ls /proc | grep "^[0-9]" | awk '$0>100'); do awk '/Swap:/{a=a+$2}END{print '"$i"',a/1024"M"}' /proc/$i/smaps;done| sort -k2nr | head

mongodb 命令

复制代码
data0data0:PRIMARY> db.version();
4.2.17

data0data0:PRIMARY> db.serverStatus().storageEngine;
{
	"name" : "wiredTiger",
	"supportsCommittedReads" : true,
	"oldestRequiredTimestampForCrashRecovery" : Timestamp(1738804816, 1),
	"supportsPendingDrops" : true,
	"dropPendingIdents" : NumberLong(0),
	"supportsSnapshotReadConcern" : true,
	"readOnly" : false,
	"persistent" : true,
	"backupCursorOpen" : false
}

查看 wiredTiger 内存参数大小

单位字节

复制代码
data0data0:PRIMARY> db.serverStatus().wiredTiger.cache["maximum bytes configured"]
1073741824

可以适当调小或者调大

复制代码
data0data0:PRIMARY> db.adminCommand({setParameter: 1, "wiredTigerEngineRuntimeConfig": "cache_size=2GB" });

查看修改后的最新值

复制代码
data0data0:PRIMARY> db.serverStatus().wiredTiger.cache["maximum bytes configured"];
2147483648

记得同步修改参数文件,避免实例重启后丢失修改值。

备注:

1、默认 WiredTiger 内部缓存大小为以下两者中的较大者:

(RAM 大小 - 1 GB)的 50%,或

256 MB.

https://www.mongodb.com/zh-cn/docs/v5.0/core/wiredtiger/#memory-use

相关推荐
好奇的菜鸟1 小时前
在IDEA中连接达梦数据库:详细配置指南
java·数据库·intellij-idea
CL_IN3 小时前
高效集成销售订单数据到MySQL的方法
android·数据库·mysql
架构文摘JGWZ3 小时前
SQLite?低调不是小众...
数据库·后端·学习·sqlite
划水哥~4 小时前
SQL99 多表查询
数据库·sql
王ASC4 小时前
kettle的转换中sql不按设计顺序执行原因分析与解决办法
数据库·sql
Elastic 中国社区官方博客4 小时前
Elasticsearch:语义文本 - 更简单、更好、更精炼、更强大 8.18
大数据·数据库·人工智能·elasticsearch·搜索引擎·ai·全文检索
老大白菜4 小时前
DeepSeek API 客户端使用文档
数据库
元气满满的热码式5 小时前
MySQL启动报错解决
运维·数据库·mysql
XMYX-05 小时前
解决 Redis 后台持久化失败的问题:内存不足导致 fork 失败
java·数据库·redis
猿小喵5 小时前
MySQL异常SQL排查
数据库·sql·mysql