最新消息: 关于Git&GitHub 版本控制你了解多少?
您现在的位置是:群英 > 数据库 > MongoDB数据库 >
Mongodb 崩溃报错 Too many open files是什么原因?
脚本之家发表于 2021-03-25 16:10 次浏览

在项目实际使用过程中,客户反馈能打开网页但无法登陆,第一时间感觉到应该是数据库服务器挂了,于是查看Mongodb数据库服务器日志,果不其然挂了。
报错信息如下:

2020-12-28T13:21:21.731 0800 E STORAGE  [conn2624] WiredTiger error (24) [1609132881:731422][23581:0x7fe157189700], WT_SESSION.create: __posix_directory_sync, 135: /data1/mongodb/data/db/: directory-sync: open: Too many open files Raw: [1609132881:731422][23581:0x7fe157189700], WT_SESSION.create: __posix_directory_sync, 135: /data1/mongodb/data/db/: directory-sync: open: Too many open files
2020-12-28T13:21:21.731 0800 E STORAGE  [conn2624] WiredTiger error (24) [1609132881:731616][23581:0x7fe157189700], WT_SESSION.create: __posix_directory_sync, 151: /data1/mongodb/data/db/collection-1063-1706476241051221735.wt: directory-sync: Too many open files Raw: [1609132881:731616][23581:0x7fe157189700], WT_SESSION.create: __posix_directory_sync, 151: /data1/mongodb/data/db/collection-1063-1706476241051221735.wt: directory-sync: Too many open files
2020-12-28T13:21:21.731 0800 E STORAGE  [conn2624] WiredTiger error (-31804) [1609132881:731651][23581:0x7fe157189700], WT_SESSION.create: __wt_panic, 494: the process must exit and restart: WT_PANIC: WiredTiger library panic Raw: [1609132881:731651][23581:0x7fe157189700], WT_SESSION.create: __wt_panic, 494: the process must exit and restart: WT_PANIC: WiredTiger library panic
2020-12-28T13:21:21.731 0800 F -        [conn2624] Fatal Assertion 50853 at src/mongo/db/storage/wiredtiger/wiredtiger_util.cpp 420
2020-12-28T13:21:21.731 0800 F -        [conn2624]
***aborting after fassert() failure
可以看到核心问题就是 Too many open files。经查阅相关资料,造成如下问题的原因就是Centos7给每个用户默认的同时打开文件的数值为1024,可通过如下配置文件查看:
ulimit -a

其中所有的参数均可修改,那么如何修改open files呢?
在此提供两种方法:
首先查看系统全局参数:

所以我们可以修改的最大值也是174198
具体修改方法一:
新建一个nofile.conf文件:
vi /etc/security/limits.d/nofile.conf
在此配置文件中写入:
* soft nofile 65536
* hard nofile 65536

保存后,需要重启系统,永久有效。
具体修改方法二:(不需要重启,不需要停服务,动态修改
1,查看mongodb pid:

2,查看对应pid limits:
cat /proc/41814/limits

3,可直接编辑以上文件,也可以直接运行命令行:
prlimit --pid 41814 --nofile=65535:65535
4,再次查看,修改成功:

总结:建议双管齐下,都修改了。
到此这篇关于Mongodb 崩溃报错 Too many open files的问题解析的文章就介绍到这了,更多相关Mongodb 报错 Too many open files内容请搜索群英网络以前的文章或继续浏览下面的相关文章希望大家以后多多支持群英网络!

标签:Mongodb报错
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
相关信息推荐
2021-03-26 17:06:21 关键词:mongodb表设计,mongodb设计范式,mongodb
摘要:这篇文章主要给大家介绍了关于MongoDB设计方法以及技巧的相关资料,文中通过示例代码介绍的非常详细,对大家学习或者使用MongoDB具有一定的参考学习价值,需要的朋友们下面来一起学..
2021-03-26 17:06:13 关键词:MongoDB,关系
摘要:这篇文章主要介绍了MongoDB 关系的相关资料,文中示例代码非常详细,帮助大家更好的理解和学习,感兴趣的朋友可以了解下..
2021-03-26 17:06:05 关键词:Docker安装MongoDB
摘要:这篇文章主要介绍了如何使用Docker安装一个MongoDB最新版,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下..
2021-03-26 17:05:57 关键词:mongodb使用教程,mongodb,crud插入
摘要:这篇文章主要给大家介绍了关于MongoDB CRUD操作中的插入的相关资料,文中通过示例代码介绍的非常详细,对大家学习或者使用MongoDB具有一定的参考学习价值,需要的朋友们下面来一起学..
2021-03-26 17:05:49 关键词:MongoDB,分布式,MongoDB,分布式集群
摘要:这篇文章主要介绍了MongoDB 分布式集群的相关资料,文中讲解非常细致,帮助大家更好的理解和学习,感兴趣的朋友可以了解下..