我可以看到Mongo shell的统计信息为
db.stats()
或
db.collection_name.stats()
如何从PHP和Python查看数据库或集合的统计信息。
修改: 我已经在PHP中完成了它,但仍然无法在Python中完成它。
帮助?
答案 0 :(得分:13)
如果您使用的是Python
驱动程序,则可以在PyMongo
中执行此操作:
connection = pymongo.Connection(host = "127.0.0.1", port = 27017)
db = connection["test_db"]
test_collection = db["test_collection"]
db.command("dbstats") # prints database stats for "test_db"
db.command("collstats", "test_collection") # prints collection-level stats for "test_collection" under "test_db".
参考文献:
答案 1 :(得分:9)
这是你在PHP中的方式
$con= new Mongo()
$stats=$con->dbName->command(array('dbStats' => 1)); // for db.stats()
$stats=$con->dbName->command(array('collStats' => 'collection_name')); // for db.collection_name.stats()
但是如何在python中执行此操作?
答案 2 :(得分:0)
我发现使用Mongoengine模型执行此操作的最简单方法是:
import mongoengine
from models import MyModel
connection = mongoengine.connection.get_connection()
db = connection[MyModel._get_db().name]
stats = db.command("collstats", MyModel._get_collection_name())
这应该允许使用mongoengine的配置设置对集合和数据库进行透明更改。
答案 3 :(得分:0)
这是使用新dbStats
驱动程序执行MongoDB
命令的PHP代码:
$mongo = new \MongoDB\Driver\Manager('mongodb://localhost:27017');
$cmdstats = new \MongoDB\Driver\Command(['dbStats' => 1]);
$dbstats = $mongo->executeCommand('databaseName', $cmdstats);
$dbstats->setTypeMap(array(
'array' => 'array',
'document' => 'array',
'root' => 'array'
));
// There must be only one item in $dbstats
foreach ($dbstats as $dbs)
{
echo($dbs['dataSize']);
}