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 ...
随机推荐
- 形态学-扩大-C代码
直接在代码,难.他们明白: void MorhpolotyDilate_ChenLee(unsigned char* pBinImg, int imgW, int imgH, Tpoint* mask ...
- php_Ubuntu Linux下为PHP5安装cURL,mysql
如果你在用PHP, 你可能需要用到cURL, 这是其中最流行的插件. PHP CURL插件需要通过libcurl来实现, Daniel Stenberg创建的一个库, 能够和许多不同类型协议的web服 ...
- XF相对布局
using System; using Xamarin.Forms; using Xamarin.Forms.Xaml; [assembly: XamlCompilation (XamlCompila ...
- JS如何为iframe添加onclick事件
如果页面上有iframe时,鼠标点击在iframe内时,包含iframe的document是不响应任何事件的, 例如: $("#iframe1").click(function() ...
- Xpose菜鸟笔记
0.官网入门教程 https://github.com/rovo89/XposedBridge/wiki/Development-tutorial 1.Hook自定义类中的私有类 https://fo ...
- ArcGIS中Python逆地理编码,根据坐标获取实际的地址
import json import urllib import arcpy def getAddress(lng,lat): url= 'http://restapi.amap.com/v3/geo ...
- Socket小白篇-附加TCP/UDP简介
Socket小白篇-附加TCP/UDP简介 Socket 网络通信的要素 TCP和UDP Socket的通信流程图 1.Socket 什么是Socket Socket:又称作是套接字,网络上的两个程序 ...
- 【原创】基于Docker的CaaS容器云平台架构设计及市场分析
基于Docker的CaaS容器云平台架构设计及市场分析 ---转载请注明出处,多谢!--- 1 项目背景---概述: “在移动互联网时代,企业需要寻找新的软件交付流程和IT架构,从而实现架构平台化,交 ...
- BuildWinRTL.dproj 用这个重新编译就行
BuildWinRTL.dproj 用这个重新编译就行 我每次安装新版本,都删掉了这两个函数 {$IFDEF DEBUG}exports dbkFCallWrapperAddr,{$IF defin ...
- How to Capture the Integer-Divide-By-Zero Error in C++(提前定义信号)
How to Capture the Integer-Divide-By-Zero Error in C++? MANUAL CAPTURE The simple and straightforwar ...