sql >> Database teknologi >  >> NoSQL >> MongoDB

Forbind og forespørg Mongo-database over SSH med privat nøgle i Python

Dette virkede for mig. Jeg tjekkede paramiko-eksemplet ovenfor, men forstod det ikke og fandt dette. Jeg tog koden herfra og ændret en lille smule til mine behov.

def data_call(collection_name, query={}):
    from sshtunnel import SSHTunnelForwarder
    import pymongo

    MONGO_HOST = 'HOST' 
    SERVER_USER   = 'server_user'
    PRIVATE_KEY ='pem.txt'

    MONGO_USER='user_mongo'
    MONGO_PASS ='pass_mongo'

    MONGO_DB = "db"

    # define ssh tunnel
    server = SSHTunnelForwarder(
        MONGO_HOST,
        ssh_username=SERVER_USER,
        ssh_pkey=PRIVATE_KEY,
        remote_bind_address=('127.0.0.1', 27017)
    )

    # start ssh tunnel
    server.start()

    connection = pymongo.MongoClient('127.0.0.1', server.local_bind_port)
    db = connection[MONGO_DB]

    data = db[collection_name].find(query)
    return data


  1. Forstå Meteor Publish / Abonner

  2. hvordan bruger man mongoDB som søgemaskine?

  3. MongoDB $pull array 2 niveau

  4. Node.js - vent på flere asynkrone opkald