从Mongodb客户端,我们可以使用db.Collection.stats()来获取集合的状态,例如:
+记录数(计数)
+磁盘大小(storageSize)
+索引(indexSizes)
+平均对象大小(avgObjSize)
现在我想用Mongodb java驱动程序监控来自Web后端的这些数据,请告诉我如何获取它们?
我已经提到:http://mongodb.github.io/mongo-java-driver/3.0/driver-async/getting-started/quick-tour-admin/
但这对我来说还不够。
谢谢!
答案 0 :(得分:6)
@Yoshiya(对不起,没有足够的代表进行评论许可)
这适用于3.2驱动程序(由Mongo人员Kay Kim提供)
MongoDatabase database = mongoClient.getDatabase("mydb");
Document stats = database.runCommand(new Document("collStats", "myCollection"));
答案 1 :(得分:5)
使用 Spring 在java中查找collection stat
检查以下代码:
Mongo mongo = new Mongo("localhost", 27017);
DB db = mongo.getDB("data base name");
CommandResult resultSet = db.getCollection("collectionName").getStats();
System.out.println(resultSet);
System.out.println(resultSet.get("count"));
System.out.println(resultSet.get("avgObjSize"))
答案 2 :(得分:1)
这将有效:
CommandResult resultSet = db.getCollection("emp").getStats();
System.out.println(resultSet);
您将获得status.ouput的所有详细信息:
{ "ns" : "test.emp" , "count" : 2 , "size" : 96 , "avgObjSize" : 48 , "numExtents" : 1 , "storageSize" : 8192 , "lastExtentSize" : 8192.0 , "paddingFactor" : 1.0 , "paddingFactorNote" : "paddingFactor is unused and unmaintained in 3.0. It remains hard coded to 1.0 for compatibility only." , "userFlags" : 1 , "capped" : false , "nindexes" : 1 , "indexDetails" : { } , "totalIndexSize" : 8176 , "indexSizes" : { "_id_" : 8176} , "ok" : 1.0}