sql >> Databasteknik >  >> NoSQL >> MongoDB

Anslut och fråga Mongo-databas över SSH med privat nyckel i Python

Det här fungerade för mig. Jag kollade paramiko-exemplet ovan men förstod inte och hittade detta. Jag tog koden härifrån och modifierade bara lite för mina 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. Är det möjligt att lägga till miljövariabler till MongoDB-konfigurationsfilen?

  2. iptables blockerar lokal anslutning till mongodb

  3. Facet + Aggregate Query med ObjectId-problem med Spring Data Mongo

  4. Installera mongodb på mac os 10.15 för php7