OperationFailure:未授权跟踪执行命令

Cra*_*ezy 7 mongodb mongoengine

我做了以下

-- `sudo apt-get install mongodb-org`
-- go to `etc/mongod.conf` change bindIp to: `0.0.0.0`
-- sudo mkdir /data/db
-- start without auth to create user
    `sudo mongod --port 27017 --dbpath /data/db`
-- open shell with : mongo --port 27017

```
> use admin
> db.createUser( { user: "useradmin", pwd: "mypassword", roles: [ { role: "root", db: "admin" } ] } )

```

-- Restart with auth required(ctrl+c the above mongod process): 
`sudo mongod --auth --port 27017 --dbpath /data/db'

-- To open shell(ctrl+c above mongo shell): 
`mongo --port 27017 -u useradmin -p mypassword --authenticationDatabase admin`
Run Code Online (Sandbox Code Playgroud)

我的mongoengine_settings.py

```PYTHON
from mongoengine import connect

DATABASE = 'tracking'
USERNAME = 'useradmin'
PASSWORD = 'mypassword'
HOST = 'mongodb://localhost/tracking'
PORT = 27017

connect(DATABASE, 
        username=USERNAME, 
        password=PASSWORD,
        host=HOST,
        port=PORT
        )

```
Run Code Online (Sandbox Code Playgroud)

现在,当我尝试批量插入一些数据使用mongoengine,如果我没有启用--auth工作正常,否则它会抛出以下错误:

OperationFailure(u'command SON([(\'createIndexes\', u\'order\'), (\'indexes\', [{\'unique\': True, \'background\': False, \'sparse\': False, \'key\': SON([(\'order_id\', 1)]), \'name\': u\'order_id_1\'}])]) on namespace tracking.$cmd failed: not authorized on tracking to execute command { createIndexes: "order", indexes: [ { unique: true, background: false, sparse: false, key: { order_id: 1 }, name: "order_id_1" } ] }',)
Run Code Online (Sandbox Code Playgroud)

我究竟做错了什么?

小智 8

MongoDB用户是在特定数据库中创建的,而不是在实例级别创建的.创建用户后,可以为不同的数据库授予不同的角色.创建用户的数据库称为其身份验证数据库

由于用户名不是唯一的(只有用户名和身份验证数据库的组合),因此可以在具有不同角色和密码的不同数据库中创建两个具有相同名称的用户.这也意味着在连接时需要指定身份验证数据库以及用户名和密码.

这就是为什么在数据库中创建useradmin用户后admin需要运行此命令:

mongo --port 27017 -u useradmin -p mypassword --authenticationDatabase admin

将MongoDB shell连接到默认数据库test.

如果未明确指定身份验证数据库,则MongoDB假定您要连接的数据库也是身份验证数据库.所以像这样连接到管理数据库就可以了:

mongo --port 27017 -u useradmin -p mypassword admin

并且这三个命令实际上是相同的,并且所有命令都将返回"身份验证失败"错误:

mongo --port 27017 -u useradmin -p mypassword mongo --port 27017 -u useradmin -p my password test mongo --port 27017 -u useradmin -p my password test --authenticationDatabase test


要从Python连接,如果您使用MongoClient并将其传递给完整的MongoDB URI,则连接字符串可以包含可选参数.其中一个选项是authSource(与用户凭据关联的数据库名称),这显然是您所需要的:连接选项.

你的URI看起来像这样:

MdbURI = "mongodb://useradmin:mypassword@localhost:27017/tracking?authSource=admin" client = MongoClient(MdbURI)


Rya*_*thm 5

这是一种与 pymongo 连接和验证的方法:

from pymongo import MongoClient

# MongoDB connection info
hostname = '10.20.30.40'
port = 27017
username = 'adminUserName'
password = 'secret'
databaseName = 'someDB'

# connect with authentication
client = MongoClient(hostname, port)
db = client[databaseName]
db.authenticate(username, password)
Run Code Online (Sandbox Code Playgroud)

  • 我尝试了此代码,但收到错误消息,表明身份验证方法不存在。类型错误:“集合”对象不可调用。如果您打算在“数据库”对象上调用“身份验证”方法,则会失败,因为不存在此类方法。 (2认同)