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 ...
随机推荐
- FastDFS是纯C语言实现,只支持Linux,适合以中小文件为载体的在线服务,还可以冗余备份和负载均衡
一.理论基础 FastDFS比较适合以中小文件为载体的在线服务,比如跟NGINX(APACHE)配合搭建图片服务器. 分布式文件系统FastDFS FastDFS是纯C语言实现,只支持Linux.Fr ...
- Android数组和开发List之间的转换
1.List转换到一个数组.(这里List它是实体是ArrayList) 转让ArrayList的toArray方法. toArray public <T> T[] toArray(T[] ...
- 如何完全备份android在系统system分区和data分
安德鲁斯系统备份是非常的情况下,可以使用.下面的这个python脚本.它可以用来备份整个data分:所有data分区的文件和文件夹打包data.zip.并产生recovery专用edify脚本upda ...
- 微信红包功能(含示例demo)
开通支付权限 登录微信公众平台管理后台,找到“微信支付”一栏,进行开通会跳转到“微信支付商户平台”,根据提示提交相关证明,完成支付权限的开通开通之后,“微信支付”一栏会显示相关信息,在“开发-接口权限 ...
- LeapMotion Demo1
原文:LeapMotion Demo1 LeapMotion SDK For c# 只提供了一个Sample.cs. Leap Motion App Home 可以给初入手者提供很好的用户 ...
- 用MVVM模式开发中遇到的零散问题总结(2)
原文:用MVVM模式开发中遇到的零散问题总结(2) 本节目录: 1.解决动画属性被劫持问题 2.设置页面焦点默认所在对象 3.XAML模拟键盘按键 4.DataGrid数据源绑定到复杂格式(dynam ...
- jquery 访问cookie
<!DOCTYPE html><html lang="en" xmlns="http://www.w3.org/1999/xhtml"> ...
- C#可扩展编程之MEF学习笔记(五):MEF高级进阶(转)
好久没有写博客了,今天抽空继续写MEF系列的文章.有园友提出这种系列的文章要做个目录,看起来方便,所以就抽空做了一个,放到每篇文章的最后. 前面四篇讲了MEF的基础知识,学完了前四篇,MEF中比较常用 ...
- Win8 Metro(C#)数字图像处理--2.67图像最大值滤波器
原文:Win8 Metro(C#)数字图像处理--2.67图像最大值滤波器 [函数名称] 最大值滤波器WriteableBitmap MaxFilterProcess(WriteableBi ...
- Windows10 1607 x64/x86 + Office 2016 Win/Mac + KMS激活/安装密钥汇总
各位观众,这里汇总了一份最新微软系统和办公软件的资源清单,希望对你们有帮助. Windows10 1607 For x64 ed2k://|file|cn_windows_10_multiple_ed ...