我在使用MongoHQ Heroku插件时遇到了麻烦。我的应用程序在本地运行,并且os变量在Heroku上存在且格式正确。但是,当我尝试访问数据库时,它将引发错误:OperationFailure: database error: unauthorized db:my_database ns:my_database.cars lock type:0 client:128.62.187.133
。如果我尝试对MongoHQ的连接字符串进行硬编码并在本地运行,则会收到相同的错误。
我的应用程序如下:
import os
import datetime
from flask import Flask
from flask import g
from flask import jsonify
from flask import json
from flask import request
from flask import url_for
from flask import redirect
from flask import render_template
from flask import make_response
import pymongo
from pymongo import Connection
from bson import BSON
from bson import json_util
app = Flask(__name__)
def mongo_conn():
# Format: MONGOHQ_URL: mongodb://<user>:<pass>@<base_url>:<port>/<url_path>
if os.environ.get('MONGOHQ_URL'):
return Connection(os.environ['MONGOHQ_URL'])
else:
return Connection()
@app.route('/', methods=['GET', 'POST'])
def hello():
# Get your DB
connection = mongo_conn()
db = connection.my_database
# Create an object
car = {"brand": "Ford",
"model": "Mustang",
"date": datetime.datetime.utcnow()}
# Get your collection
cars = db.cars # crashes
# Insert it
cars.insert(car)
...
编辑:MongoHQ支持帮助了我。问题是我在调用数据库
my_database
而不是MongoHQ插件给我的实际数据库名称。例如db = connection.app52314314
。那个改变解决了它。 最佳答案
连接之后,您可能需要直接对数据库运行authenticate
命令。
尝试这样的事情:
db.authenticate([USER], [PASSWORD])
如果那不起作用,请随时发送电子邮件至[email protected],我们将为您提供特定数据库的帮助。
关于python - Heroku MongoHQ插件和PyMongo-OperationFailure : database error: unauthorized,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/12984577/