如何连接远程mongodb和pymongo

新手上路,请多包涵

当我使用 MongoChef 连接远程 mongo 数据库时,我使用下一个参数:


服务器

  • 服务器: 本地主机
  • 端口: 27017

SSH隧道

  • SSH地址: 10.1.0.90

  • 端口: 25

  • SSH 用户名: 用户名

  • SSH密码: 密码


当我连接 Pymongo 时,我有下一个代码:

 import pymongo

MONGO_HOST = "10.1.0.90"
MONGO_PORT = 25
MONGO_DB = "db_name"
MONGO_USER = "username"
MONGO_PASS = "password"

con = pymongo.MongoClient(MONGO_HOST, MONGO_PORT)
db = con[MONGO_DB]
db.authenticate(MONGO_USER, MONGO_PASS)

print(db)

但是我有下一个错误:

 pymongo.errors.ServerSelectionTimeoutError: 10.1.2.84:27017: [Errno 111] Connection refused

拜托,你能帮我解决这个问题吗?我做错了什么?

原文由 Volodymyr Nazarenko 发布,翻译遵循 CC BY-SA 4.0 许可协议

阅读 1.5k
2 个回答

对我有用的解决方案。

 from sshtunnel import SSHTunnelForwarder
import pymongo
import pprint

MONGO_HOST = "REMOTE_IP_ADDRESS"
MONGO_DB = "DATABASE_NAME"
MONGO_USER = "LOGIN"
MONGO_PASS = "PASSWORD"

server = SSHTunnelForwarder(
    MONGO_HOST,
    ssh_username=MONGO_USER,
    ssh_password=MONGO_PASS,
    remote_bind_address=('127.0.0.1', 27017)
)

server.start()

client = pymongo.MongoClient('127.0.0.1', server.local_bind_port) # server.local_bind_port is assigned local port
db = client[MONGO_DB]
pprint.pprint(db.collection_names())

server.stop()

原文由 Volodymyr Nazarenko 发布,翻译遵循 CC BY-SA 3.0 许可协议

或者,您可以 pip install ssh-pymongo

 from ssh_pymongo import MongoSession

session = MongoSession('10.1.0.90',
    port=25,
    user='USERNAME',
    password='PASSWORD',
    uri='mongodb://127.0.0.1:27017'
)

db = session.connection['DATABASE_NAME']

print(db)

session.stop()

包中的更多示例:

示例 1——如果您的用户名相同,并且您已经配置了 ssh 密钥。

 from ssh_pymongo import MongoSession

session = MongoSession('db.example.com')

db = session.connection['db-name']

示例 2——如果您有一些自定义本地身份验证。

 from ssh_pymongo import MongoSession

session = MongoSession('db.example.com',
    uri='mongodb://user:password@127.0.0.1/?authSource=admin&authMechanism=SCRAM-SHA-256')

db = session.connection['db-name']

示例 3——如果您想使用不同的端口和密钥。

 from ssh_pymongo import MongoSession

session = MongoSession(
    host='db.example.com',
    port=21,
    user='myuser',
    key='/home/myplace/.ssh/id_rsa2'
)

db = session.connection['db-name']

原文由 Mindey I. 发布,翻译遵循 CC BY-SA 4.0 许可协议

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题