mongodb中出现mmap failed with out of memory的解决方法

在32位平台,MongoDB出现“mmap failed with out of memory”错误,因为在32位平台MongoDB不允许数据库文件(累计总和)超过2G,而64位平台没有这个限制。本想在新系统(64bit)中尝试采用MongoDB,但做一下MongoDB性能测试,结果却也报“mmap failed with out of memory”错误,好几天找不到答案,弄了个灰头土脸

今天终于找到了答案,原来是虚拟内存不足所致,
取消虚拟内存限制的方法:修改etc/profile文件,在文件最后加入一行

ulimit -v unlimited

保存,在命令行执行

# source /etc/profile

(重启linux也可以生效)
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在执行db.auth(‘username’, ‘password’)时,如果出现了Error: Authentication failed的错误,可能是因为环境的root、admin和业务数据库用户都认证失败了。解决这个问题的步骤如下: 1. 停止MongoDB服务。可以使用无身份认证的方式打开MongoDB。 2. 进入MongoDB的bin目录下。 3. 使用以下命令停止MongoDB服务: mongod --shutdown --dbpath=/soft/mongo/mgserver/data/ 4. 使用以下命令启动MongoDB服务: ./mongod --dbpath=/soft/mongo/mgserver/data/ --logpath=/soft/mongo/mgserver/logs/mongod.log --logappend --port=27017 --fork 5. 使用以下命令验证数据库和用户信息: mongo show dbs use ${your db} show users use admin show users 6. 修改密码: - 修改root用户密码: # mongo # db.changeUserPassword('root','${new password}') # exit退出 - 关闭MongoDB服务: mongod --shutdown --dbpath=/soft/mongo/mgserver/data/ - 使用以下命令认证启动MongoDB服务: ./mongod --dbpath=/soft/mongo/mgserver/data/ --logpath=/soft/mongo/mgserver/logs/mongod.log --auth --logappend --port=27017 --fork - 使用以下命令验证用户密码是否修改成功: mongo use admin db.auth('','') - 同样的步骤也可以修改其他用户的密码。 7. 新增用户: - mongo - use ${your db} - db.createUser({ user: "", pwd:"", roles:[{role:"readWrite",db:""}] }) 参考资料提到,可能出现Authentication failed的错误是因为没有正确指定数据库。确保在创建用户时使用了正确的数据库名称。例如,使用use admin指定数据库。另外,还要确保创建的用户具有正确的权限角色。 综上所述,要解决mongodb出现Authentication failed的问题,可以按照上述步骤进行操作。<span class="em">1</span><span class="em">2</span><span class="em">3</span><span class="em">4</span>

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值