sql >> Database >  >> NoSQL >> MongoDB

Eenvoudige HTTP/TCP-statuscontrole voor MongoDB

Ik heb een eenvoudige gezondheidscontrole voor mongodb gemaakt, het gebruikt de mongo client om een ​​eenvoudig queryverzoek te verzenden (bijv. db.stats() ) naar de server.

$ mongo 192.168.5.51:30000/test

MongoDB shell version: 3.2.3
connecting to: 192.168.5.51:30000/test

mongos> db.stats()
{
    "raw" : {
        "set1/192.168.5.52:27000,192.168.5.53:27000" : {
            "db" : "test",
            "collections" : 8,
            "objects" : 50,
            "avgObjSize" : 73.12,
            "dataSize" : 3656,
            "storageSize" : 53248,
            "numExtents" : 8,
            "indexes" : 8,
            "indexSize" : 65408,
            "fileSize" : 469762048,
            "nsSizeMB" : 16,
            "dataFileVersion" : {
                "major" : 4,
                "minor" : 6
            },
            "extentFreeList" : {
                "num" : 28,
                "totalSize" : 184807424
            },
            "ok" : 1
        }
    },
    "objects" : 50,
    "avgObjSize" : 73,
    "dataSize" : 3656,
    "storageSize" : 53248,
    "numExtents" : 8,
    "indexes" : 8,
    "indexSize" : 65408,
    "fileSize" : 469762048,
    "extentFreeList" : {
        "num" : 28,
        "totalSize" : 184807424
    },
    "ok" : 1
}

Je kunt dit ook in één regel doen:

$ echo 'db.stats().ok' | mongo 192.168.5.51:30000/test --quiet
1

Ik hoop dat het helpt.

UPDATE:

Zoals @luckydonald zei, de ping commando is beter, dus je kunt het als volgt doen:

$ mongo --eval 'db.runCommand("ping").ok' localhost:27017/test --quiet
1

Bedankt voor @luckydonald.



  1. De volledige tekstzoekopdracht van MongoDB 2.4 in een Meteor-app implementeren

  2. MongoDB $gt Aggregation Pipeline Operator

  3. Hoe toegang te krijgen tot geneste bestanden met Pick<> typoscript

  4. Mongo-query-uitvoer afdrukken naar een bestand terwijl deze zich in de mongo-shell bevindt