mongoshell 执行JavaScript文件获取数据库实例基本信息
由于MongoDB没有关系型数据中强大的数据字典。因此,如果需要汇总统计一些内部信息,包括数据量,基本元信息,集群架构,状态信息。则需要自己写脚本统计。为日后工作方便,本人在此将一些统计信息通过JavaScript汇总。。使用方式如下:
脚本如下:(还有很多信息待收集统计,先走出第一步)
// 查看mongodb实例信息。 var maxSizeDb = 5; // 看前多少数据库。默认为5
var maxSizeTable = 10; // 前五数据库中表排名前多少。 默认为10. function byteToGb(num){
return (num/1024/1024/1024).toFixed(2);
}; function byteToMb(num){
return (num/1024).toFixed(0);
}; function statsDbSize(){ var dbArray={}; // 获取数据库信息
dbInfo=db.adminCommand('listDatabases'); // 获取主机信息
hostinfo = db.hostInfo(); dbNameSizeArray = dbInfo.databases;
dbDiskSize = db.getSiblingDB(dbNameSizeArray[0].name); dbDiskSizeTotal = dbDiskSize.stats().fsTotalSize; print("=======服务器信息=================");
print("CPU核数:", hostinfo.system.numCores);
print("内存Size:(MB)", byteToMb(hostinfo.system.memSizeMB));
print("磁盘空间:",byteToGb(dbDiskSizeTotal),"GB");
print("系统版本:",hostinfo.os.name);
print("内核版本:",hostinfo.os.version);
print("最大文件打开数:",hostinfo.extra.maxOpenFiles);
print("是否启用numa:",hostinfo.system.numaEnabled); print("==================================\n") print("=======实例概览=======")
print("磁盘空间:",byteToGb(dbDiskSizeTotal),"GB",'\t||');
print("数据总大小:",byteToGb(dbInfo.totalSize),"GB",'\t||');
print("数据库个数:",dbNameSizeArray.length,'\t\t||');
print("===========================\n") // 获取副本集信息
//
rsinfo = db.adminCommand({replSetGetStatus:1});
// printjson(rsinfo); rsname = rsinfo.set;
print("=======副本集信息=======");
print("副本集:",rsname); rsOptimesLastCommittedOpTimeTs = rsinfo.optimes.lastCommittedOpTime.ts
rsOptimesReadConcernMajorityOpTimeTs = rsinfo.optimes.readConcernMajorityOpTime.ts
rsOptimesAppliedOpTimeTs = rsinfo.optimes.appliedOpTime.ts
rsOptimesDurableOpTimeTs = rsinfo.optimes.durableOpTime.ts
rslastStableCheckpointTimestamp = rsinfo.lastStableCheckpointTimestamp;
// print("最後提交時間:", (Date(rsOptimesLastCommittedOpTimeTs.toLocaleString())).toISOString())
print("最後提交時間:", Date(rsOptimesLastCommittedOpTimeTs.toLocaleString()))
print("一致性读時間:", Date(rsOptimesReadConcernMajorityOpTimeTs.toLocaleString()))
print("日志应用時間:", Date(rsOptimesAppliedOpTimeTs.toLocaleString()))
print("日志持久時間:", Date(rsOptimesDurableOpTimeTs.toLocaleString()))
print(" 检查点時間:", Date(rslastStableCheckpointTimestamp.toLocaleString()))
print("==========成员=====================") // 打印MongoDB副本集成员信息
rsinfoMember = rsinfo.members
//print("===========================================================================================")
print('ip:port \t\t health \t state \t optime \t syncSourceHost \t 成员角色');
for(var mem in rsinfoMember){
rsinfoMemberInfo = rsinfoMember[mem];
print('---------------------------------------------------------------------------------------------------------')
if(rsinfoMemberInfo.syncSourceHost == ""){ delimiterChar = '\t\t\t';
}
else{
delimiterChar = '\t';
}
if(rsinfoMemberInfo.optime == null){
print(rsinfoMemberInfo.name,'\t' ,rsinfoMemberInfo.health,'\t\t', rsinfoMemberInfo.state,'\t', "None", delimiterChar,rsinfoMemberInfo.syncSourceHost, '\t\t', rsinfoMemberInfo.stateStr);}
else{
print(rsinfoMemberInfo.name,'\t' ,rsinfoMemberInfo.health,'\t\t', rsinfoMemberInfo.state,'\t', rsinfoMemberInfo.optime.ts.getTime(), delimiterChar,rsinfoMemberInfo.syncSourceHost, '\t', rsinfoMemberInfo.stateStr);}
} // 获取副本集配置信息
rsconf = db.adminCommand( { replSetGetConfig: 1 } ); rsconfConfig = rsconf.config; // 成员設置
rsconfConfigMember = rsconfConfig.members;
// 全局設置
rsconfConfigSettings = rsconfConfig.settings;
rsconfprotocolVersion = rsconfConfig.protocolVersion;
rsconfwriteConcernMajorityJournalDefault = rsconfConfig.writeConcernMajorityJournalDefault;
rsconfConfigSettingschainingAllowed = rsconfConfigSettings.chainingAllowed;
rsconfConfigSettingsheartbeatIntervalMillis = rsconfConfigSettings.heartbeatIntervalMillis;
rsconfConfigSettingsheartbeatTimeoutSecs = rsconfConfigSettings.heartbeatTimeoutSecs;
rsconfConfigSettingselectionTimeoutMillis = rsconfConfigSettings.electionTimeoutMillis; print(" 协议版本( 影响):", rsconfprotocolVersion);
print(" 默认写策略:", rsconfwriteConcernMajorityJournalDefault);
print("是否允许链式复制:", rsconfConfigSettingschainingAllowed);
print("心跳检测间隔时间:", rsconfConfigSettingsheartbeatIntervalMillis);
print("心跳检测超时时间:", rsconfConfigSettingsheartbeatTimeoutSecs);
print(" 选举超时时间:", rsconfConfigSettingselectionTimeoutMillis); print("ip:port,\t\t arbiterOnly, \t buildIndexes, \t影藏节点, \t权重,\t 标签, \t 延时同步,\t 投票节点");
for(var i in rsconfConfigMember){
print('------------------------------------------------------------------------------------------------------')
var rsmember = rsconfConfigMember[i];
if(rsmember.tags = {}){ rsmember.tags = 'None';
}
print(rsmember.host, '\t',rsmember.arbiterOnly,'\t\t', rsmember.buildIndexes,'\t\t', rsmember.hidden,'\t\t', rsmember.priority, '\t',rsmember.tags,'\t', rsmember.slaveDelay,'\t', rsmember.votes) } // printjson(rsconfConfigMember);
// printjson(rsconfConfigSettings);
// print("===========================\n")
// for(var i=0; i<dbNameSizeArray.length; i++){
dbname = dbNameSizeArray[i].name;
dbvalue = byteToGb(dbNameSizeArray[i].sizeOnDisk);
dbArray[dbname] = dbvalue; } // 将时间戳转换成时间
// //printjson(dbArray);
// order by dbsize ,Get the top five(maxSizeDb) database names in the occupied space
var items = Object.keys(dbArray).map(function(key){ return [key, dbArray[key]];});
var sdbArray = items.sort(function(first, second){return second[1] - first[1]});
// maxSizeDbName = sdbArray.slice(0, maxSizeDb);
print("=========Overview Database=========")
print("库名","\t\t大小:GB\t\t||")
for(var i in sdbArray){
//print(sdbArray[i][0],'\t\t',sdbArray[i][1],'\t\t');
printjson(sdbArray[i],"||") } print("===========================\n") // 可以在这个里面加上前十大的集合
for(var j in sdbArray.slice(0, maxSizeDb)){
db1 = db.getSiblingDB(sdbArray[j][0]);
// printjson(db1.stats())
db2 = db.getSiblingDB(db1);
tableName = db2.getCollectionNames();
// print("集合\t","\t,大小\t行数")
for(var i in tableName){
tn = tableName[i];
// print(db1+'.'+tn);
}
} } statsDbSize()
mongoshell 执行JavaScript文件获取数据库实例基本信息的更多相关文章
- mysql数据库批量执行sql文件对数据库进行操作【windows版本】
起因: 因工作需要,在本机测试环境升级mysql数据库,需逐条执行mysql数据库的sql文件对数据库进行升级,因此找了些关于mysql的文章,对批量升级数据库所需的sql文件进行升级. 整理思路: ...
- FireDAC 下的 Sqlite [3] - 获取数据库的基本信息
在空白窗体上添加: TFDConnection, TFDPhysSQLiteDriverLink, TFDGUIxWaitCursor, TMemo procedure TForm1.FormCrea ...
- Oracle 数据库实例简介
回到顶部 一:Oracle 数据库实例简介 1:数据库实例的启动顺序: 使用数据库其实就是访问内存.即:数据库实例.数据库的启动是顺序是 先 nomount ----> mount --- ...
- sehlle脚本获取linux服务器基本信息
将以下代码全选复制在linux机器上新建x.sh文件编辑复制进去执行即可. #获取linux服务器基本信息脚本 #!/bin/bash # #Name:system_info #Ver:1.0 #Au ...
- oracle数据库实例启动与关闭
区分数据库与实例:实例是指各种内存结构和服务进程,数据库是指基于磁盘存储的数据文件.控制文件.参数文件.日志文件和归档日志文件组成的物里文件集合. 数据库实例启动: startup [nomount ...
- JavaScript 文件延迟和异步加载
JavaScript 文件延迟和异步加载 -般情况下,在文档的 <head> 标签中包含 JavaScript 脚本,或者导入的 JavaScript 文件. 这意味着必须等到全部 Jav ...
- 利用PHP执行SQL文件,将SQL文件导入到数据库
如何利用php自动执行.sql文件.其实很简单,就是获取sql文件中的内容,然后将每一句sql语句一次执行就行啦. 这是代码 //读取文件内容 $_sql = file_get_contents('t ...
- logstash快速入门 (这篇文章很不错 ) | 两种方式往logstash传输数据实例:Apache 日志(从文件获取)、Syslog方式
原文地址:http://www.2cto.com/os/201411/352015.html 原文地址:http://logstash.net/docs/1.4.2/tutorials/getting ...
- 导入dmp文件时,需要删除原有ORACLE数据库实例
导入dmp文件时,对于已存在的数据库实例及表处理方式:删除实例. 1.以管理员身份登录 sqlplus / as sysdba 2.停止实例 shutdown abort; 执行结果:ORACLE i ...
随机推荐
- React实现checkbox group多组选项和标签组显示的联动
实现功能:勾选checkbox项,确定后,已勾选的checkbox项以tag标签的形式展示,tag标签可快捷删除. 实现过程: 使用React. 使用Ant Design的Checkbox.Tag组件 ...
- Cocos2d-x 3.0final 终结者系列教程09-漆节点Node中间Schedule
怎么做HelloWorld工程HelloWorld文字实现它自己主动运动? 有的童鞋会想到使用线程.不断的变化Label的Position, 不要那样做,因为Cocos2d-x在主线程只能被改变Nod ...
- 【转】postgresql 9.4 在linux环境的安装步骤详解
本文章来为各位介绍一篇关于postgresql 9.4 在linux环境的安装步骤详解,希望文章能够对各位新手朋友带来帮助的哦. 环境说明系统:centos 6.4 64位软件:postgresql ...
- C++学习笔记27,虚函数作品
C++它指定虚函数的行为,但实现的作者编译器. 通常,编译器处理虚函数的方法是给每个对象加入一个隐藏成员.隐藏成员中保存了一个指向函数地址数组的指针. 这个数组称为虚函数表(virtual funct ...
- node express4.x 的安装
4.x开始不再是 一个express就搞定一切了,需要装另外一个部署插件 具体: 跟着<nodejs开发指南>敲npm install -g express, 安装好了,就在linux命令 ...
- WPF Binding妙处-既无Path也无Source
<Window x:Class="XamlTest.Window12" xmlns="http://schemas.microsoft.com/win ...
- 【C#】获取"我的电脑"的名字,如This PC、这台计算机
原文:[C#]获取"我的电脑"的名字,如This PC.这台计算机 注意:这里获取的[我的电脑]的名字,不是机器的名字.如图所示: 要获取的是This PC这个字符串. ----- ...
- centos搭建免费的ssl证书,大部分浏览器均支持!(let’s encrypt 的使用记录)
安装certbot wget https://dl.eff.org/certbot-auto chmod a+x certbot-auto 然后就是通过这个脚本获取证书,安装前先将NGINX 停一下. ...
- Python Pandas 分析郁达夫《故都的秋》
最近刚学这块,如果有错误的地方还请大家担待. 本文用到的Python包: Ipython, Numpy, Pandas, Matplotlib 故都的秋原文参考:http://www.xiexingc ...
- 正试图在 os 加载程序锁内执行托管代码
正试图在 os 加载程序锁内执行托管代码.不要尝试在 DllMain 或映像初始化函数内运行托管代码... 当我在窗体初始化的时候,调用了一个外部的dill时,它就不知什么原因的 抛出一个“正试图在 ...