使用mongod.conf时Mongo身份验证无法登录

时间:2020-02-20 13:11:22

标签: mongodb centos centos7

这是最奇怪的事情。

我有两台运行mongo的centOS 7服务器。现在,我想强制执行身份验证,因此在mongod.conf文件中添加了security.authorization:启用。

我已经有一个数据库“ buzzztv”的用户。

因此,当我在第一台服务器上运行mongod --conf /etc/mongod.conf时,一切正常。

然后,我在第二台服务器上执行了完全相同的操作,每当尝试与其中一个用户连接时,都会出现以下错误:

connecting to: mongodb://127.0.0.1:27017/?authSource=buzzztv&compressors=disabled&gssapiServiceName=mongodb
2020-02-20T13:02:35.166+0000 E  QUERY    [js] Error: Authentication failed. :
connect@src/mongo/shell/mongo.js:341:17
@(connect):2:6
2020-02-20T13:02:35.168+0000 F  -        [main] exception: connect failed
2020-02-20T13:02:35.168+0000 E  -        [main] exiting with code 1

现在,如果我运行mongod --fork --logpath /var/log/mongodb/mongod.log --auth,则登录正常。

太可惜了,我只能运行此命令,但是我想使用mongod.conf。

这是我的mongod.conf文件,我检查了一下,它是文件所在的服务器的完美副本。

有什么想法吗?

# mongod.conf

# for documentation of all options, see:
#   http://docs.mongodb.org/manual/reference/configuration-options/

# where to write logging data.
systemLog:
  destination: file
  logAppend: true
  path: /var/log/mongodb/mongod.log

# Where and how to store data.
storage:
  dbPath: /var/lib/mongo
  journal:
    enabled: true
#  engine:
#  wiredTiger:

# how the process runs
processManagement:
  fork: true  # fork and run in background
  pidFilePath: /var/run/mongodb/mongod.pid  # location of pidfile
  timeZoneInfo: /usr/share/zoneinfo

# network interfaces
net:
  port: 27017
  bindIp: 0.0.0.0 # 127.0.0.1  # Enter 0.0.0.0,:: to bind to all IPv4 and IPv6 addresses or, alternatively, use the net.bindIpAll setting.


security:
  authorization: enabled

#operationProfiling:

#replication:

#sharding:

## Enterprise-Only Options

#auditLog:

#snmp:

1 个答案:

答案 0 :(得分:0)

因此,经过数小时的痛苦调查,我需要更改

storage:
  dbPath: /var/lib/mongo
  journal:
    enabled: true

显然/var/lib/mongo出了问题,所以我备份了数据,并创建了一个新文件夹/var/lib/mongodb

然后将mongod.conf文件编辑为:

storage:
  dbPath: /var/lib/mongodb
  journal:
    enabled: true

然后一切正常。现在,我将重新创建用户并重新插入所有数据,我很好。

希望这可以节省我失去的时间

相关问题