linux shell中获取mongodb最大连接数、内存使用情况等

简介: 前两天接到了一个新的需求,需要在linux shell脚本中监控到mongodb最大连接数、内存使用情况等。但是我对于linux shel很不了解,只是会一些简单常用的linux的操作而已,只要一顿狂搜,最终多番尝试下终于获取到这些值。成功的步骤大致如下:0、./mongostat -u admin -p admin --authenticationDatabase admin -
前两天接到了一个新的需求,需要在linux shell脚本中监控到mongodb最大连接数、内存使用情况等。

但是我对于linux shel很不了解,只是会一些简单常用的linux的操作而已,只要一顿狂搜,最终多番尝试下终于获取到这些值。

成功的步骤大致如下:

0、
./mongostat -u admin -p admin --authenticationDatabase admin -n 1 --json >> aaa.txt 
把mongodb监控到的一行数据以json格式写入到aaa.txt文件中

1、  
a=`cat aaa.txt`   
读取aaa.txt中的内容并赋值给a

获取mapped映射到内存的数据大小:

2、
indma=`echo $a | awk '{printf("%d\n",match($0,"mapped"))}'` 
 获取字符串变量a中的子字符串“mapped”的下标,并赋值给indma

3、
indma1=$(($indma+8)) 
给变量ind加8,把结果赋值给indma1

4、
indma0=`echo $a | awk '{printf("%d\n",match($0,"netIn"))}'`  
获取字符串变量a中的子字符串“netIn”的下标,并赋值给indma0

5、
indma2=$(($indma0-4)) 
给变量indma0减4,把结果赋值给indma2

6、
mastr=`echo ${a:$indma1:$(($indma2-$indma1))}` 
获取字符串a中下标indma1到indma2之间的子字符串并赋值给mastr,即mapped的值

获取物理内存使用量:

7、
indre=`echo $a | awk '{printf("%d\n",match($0,"res"))}'` 
获取字符串变量a中的子字符串“res”的下标,并赋值给indre

8、
indre1=$(($indre+5)) 
给变量indre加5,把结果赋值给indre1

9、
indre0=`echo $a | awk '{printf("%d\n",match($0,"time"))}'`  
获取字符串变量a中的子字符串“time”的下标,并赋值给indre0

10、
indre2=$(($indre0-4)) 
给变量indre0减4,把结果赋值给indre2

11、
restr=`echo ${a:$indre1:$(($indre2-$indre1))}` 
获取字符串a中下标indre1到indre2之间的子字符串并赋值给restr,即res的值

获取虚拟内存使用量:

12、
indvs=`echo $a | awk '{printf("%d\n",match($0,"vsize"))}'` 
 获取字符串变量a中的子字符串“vsize”的下标,并赋值给indvs

13、
indvs1=$(($indvs+7)) 
给变量indvs加5,把结果赋值给indvs1

14、
indvs0=${#a} 
获取字符串变量a的总长度

15、
indvs2=$(($indvs0-3)) 
给变量indvs0减3,把结果赋值给indvs2

16、
vsstr=`echo ${a:$indvs1:$(($indvs2-$indvs1))}` 
获取字符串a中下标indvs1到indvs2之间的子字符串并赋值给vsstr,即vsize的值

获取当前连接数:

17、  
indco=`echo $a | awk '{printf("%d\n",match($0,"conn"))}'` 
获取字符串变量a中的子字符串“conn”的下标,并赋值给indco

18、
indco1=$(($indco+6)) 
给变量indco加6,把结果赋值给indco1

19、  
indco0=`echo $a | awk '{printf("%d\n",match($0,"delete"))}'` 
 获取字符串变量a中的子字符串“delete”的下标,并赋值给indco0

20、
indco2=$(($indco0-4)) 
给变量indco0减4,把结果赋值给indco2

21、
costr=`echo ${a:$indco1:$(($indco2-$indco1))}` 
获取字符串a中下标indco1到indco2之间的子字符串并赋值给costr,即conn的值

最大连接数819,空闲连接数可以根据最大连接数和当前连接数算出来。
目录
相关文章
|
11月前
|
监控 Shell Linux
Android调试终极指南:ADB安装+多设备连接+ANR日志抓取全流程解析,覆盖环境变量配置/多设备调试/ANR日志分析全流程,附Win/Mac/Linux三平台解决方案
ADB(Android Debug Bridge)是安卓开发中的重要工具,用于连接电脑与安卓设备,实现文件传输、应用管理、日志抓取等功能。本文介绍了 ADB 的基本概念、安装配置及常用命令。包括:1) 基本命令如 `adb version` 和 `adb devices`;2) 权限操作如 `adb root` 和 `adb shell`;3) APK 操作如安装、卸载应用;4) 文件传输如 `adb push` 和 `adb pull`;5) 日志记录如 `adb logcat`;6) 系统信息获取如屏幕截图和录屏。通过这些功能,用户可高效调试和管理安卓设备。
|
Linux
SecureCRT连接Linux时乱码问题
本文详细介绍了在使用SecureCRT连接Linux服务器时出现乱码问题的解决方法,包括设置SecureCRT字符编码、检查和配置Linux服务器字符编码、调整终端设置等。通过这些方法,您可以有效解决SecureCRT连接Linux时的乱码问题,确保正常的终端显示和操作。希望本文能帮助您在实际操作中更好地解决类似问题,提高工作效率。
1148 17
|
11月前
|
存储 NoSQL Linux
微服务2——MongoDB单机部署4——Linux系统中的安装启动和连接
本节主要介绍了在Linux系统中安装、启动和连接MongoDB的详细步骤。首先从官网下载MongoDB压缩包并解压至指定目录,接着创建数据和日志存储目录,并配置`mongod.conf`文件以设定日志路径、数据存储路径及绑定IP等参数。之后通过配置文件启动MongoDB服务,并使用`mongo`命令或Compass工具进行连接测试。此外,还提供了防火墙配置建议以及服务停止的两种方法:快速关闭(直接杀死进程)和标准关闭(通过客户端命令安全关闭)。最后补充了数据损坏时的修复操作,确保数据库的稳定运行。
752 0
|
11月前
|
NoSQL JavaScript Shell
微服务2——MongoDB单机部署2——Shell连接
本节介绍如何通过Shell连接MongoDB数据库,使用`mongo`命令登录,默认连接本地127.0.0.1的27017端口。可查看数据库列表(`show databases`),退出shell(`exit`),或通过`--help`获取更多参数。MongoDB Shell基于JavaScript解释器,支持运行JS程序。
277 0
|
数据库连接 Linux Shell
Linux下ODBC与 南大通用GBase 8s数据库的无缝连接配置指南
本文详细介绍在Linux系统下配置GBase 8s数据库ODBC的过程,涵盖环境变量设置、ODBC配置文件编辑及连接测试等步骤。首先配置数据库环境变量如GBASEDBTDIR、PATH等,接着修改odbcinst.ini和odbc.ini文件,指定驱动路径、数据库名称等信息,最后通过catalog.c工具或isql命令验证ODBC连接是否成功。
|
NoSQL 网络安全 MongoDB
MongoDB - 连接
10月更文挑战第12天
870 1
|
Linux 网络安全
Linux虚拟机与主机和Xshell的连接问题解决
Linux虚拟机与主机和Xshell的连接问题解决
552 1
|
NoSQL 前端开发 JavaScript
Node.js 连接 MongoDB
10月更文挑战第20天
163 0
|
NoSQL Shell MongoDB
MongoDB Shell
10月更文挑战第11天
274 0
|
NoSQL 前端开发 JavaScript
Node.js 连接 MongoDB
10月更文挑战第9天
229 0