获取连接到特定MongoDB服务器的客户端数量的命令是什么?
答案 0 :(得分:112)
连接到管理数据库并运行db.serverStatus()
:
> var status = db.serverStatus()
> status.connections
{"current" : 21, "available" : 15979}
>
您可以通过查询直接获取
db.serverStatus().connections
要了解MongoDb db.serverStatus().connections
响应的含义,请阅读文档here。
<强>连接强>
"connections" : { "current" : <num>, "available" : <num>, "totalCreated" : NumberLong(<num>) },
<强>连接强> 报告连接状态的文档。使用这些值来评估服务器的当前负载和容量要求。
<强> connections.current 强> 从客户端到数据库服务器的传入连接数。此数字包括当前的shell会话。考虑connections.available的值,为此数据添加更多上下文。
该值将包括所有传入连接,包括任何shell连接或来自其他服务器的连接,例如副本集成员或mongos实例。
<强> connections.available 强> 可用的未使用传入连接数。将此值与connections.current的值结合使用以了解数据库上的连接负载,并将UNIX ulimit设置文档与有关可用连接的系统阈值的更多信息一起考虑。
<强> connections.totalCreated 强> 创建到服务器的所有传入连接的计数。此数字包括已关闭的连接。
答案 1 :(得分:16)
db.serverStatus()
没有提供连接opend和avail,但没有显示客户端的连接。有关详细信息,您可以使用此命令sudo lsof | grep mongod | grep TCP
。当我进行复制时,我需要它,主节点有许多客户端连接大于辅助节点。
$ sudo lsof | grep mongod | grep TCP
mongod 5733 Al 6u IPv4 0x08761278 0t0 TCP *:28017 (LISTEN)
mongod 5733 Al 7u IPv4 0x07c7eb98 0t0 TCP *:27017 (LISTEN)
mongod 5733 Al 9u IPv4 0x08761688 0t0 TCP 192.168.1.103:27017->192.168.1.103:64752 (ESTABLISHED)
mongod 5733 Al 12u IPv4 0x08761a98 0t0 TCP 192.168.1.103:27017->192.168.1.103:64754 (ESTABLISHED)
mongod 5733 Al 13u IPv4 0x095fa748 0t0 TCP 192.168.1.103:27017->192.168.1.103:64770 (ESTABLISHED)
mongod 5733 Al 14u IPv4 0x095f86c8 0t0 TCP 192.168.1.103:27017->192.168.1.103:64775 (ESTABLISHED)
mongod 5733 Al 17u IPv4 0x08764748 0t0 TCP 192.168.1.103:27017->192.168.1.103:64777 (ESTABLISHED)
这表明我目前有五个连接打开我的计算机上的MongoDB端口(27017)。在我的情况下,我从Scalatra服务器连接到MongoDB,并且我使用MongoDB Casbah驱动程序,但是无论使用何种客户端,您都会看到相同的lsof TCP连接(只要它们和&# #39;使用TCP / IP重新连接。
答案 2 :(得分:6)
我尝试通过以下命令查看mongo数据库的所有连接。
netstat -anp --tcp --udp | grep mongo
此命令可以更详细地显示mongodb的每个tcp连接。
tcp 0 0 10.26.2.185:27017 10.26.2.1:2715 ESTABLISHED 1442/./mongod
tcp 0 0 10.26.2.185:27017 10.26.2.1:1702 ESTABLISHED 1442/./mongod
tcp 0 0 10.26.2.185:27017 10.26.2.185:39506 ESTABLISHED 1442/./mongod
tcp 0 0 10.26.2.185:27017 10.26.2.185:40021 ESTABLISHED 1442/./mongod
tcp 0 0 10.26.2.185:27017 10.26.2.185:39509 ESTABLISHED 1442/./mongod
tcp 0 0 10.26.2.185:27017 10.26.2.184:46062 ESTABLISHED 1442/./mongod
tcp 0 0 10.26.2.185:27017 10.26.2.184:46073 ESTABLISHED 1442/./mongod
tcp 0 0 10.26.2.185:27017 10.26.2.184:46074 ESTABLISHED 1442/./mongod
答案 3 :(得分:5)
在OS X中,也可以直接在网络界面上看到连接,只需:
$ lsof -n -i4TCP:27017
mongod 2191 inanc 7u IPv4 0xab6d9f844e21142f 0t0 TCP 127.0.0.1:27017 (LISTEN)
mongod 2191 inanc 33u IPv4 0xab6d9f84604cd757 0t0 TCP 127.0.0.1:27017->127.0.0.1:56078 (ESTABLISHED)
stores.te 18704 inanc 6u IPv4 0xab6d9f84604d404f 0t0 TCP 127.0.0.1:56078->127.0.0.1:27017 (ESTABLISHED)
无需使用grep
等,只需使用lsof
的参数。
在MongoDb的CLI上看到连接,请参阅@milan的回答(我刚刚编辑的 )。
答案 4 :(得分:3)
还有一些关于连接的更多细节:
db.currentOp(true)
答案 5 :(得分:3)
ClientIP的连接计数,总计
我们使用它来查看IPAddress的连接数以及总连接数。这对于调试问题确实很有帮助...只需在达到最大连接数之前就到达那里!
对于Mongo Shell:
db.currentOp(true).inprog.reduce((accumulator, connection) => { ipaddress = connection.client ? connection.client.split(":")[0] : "Internal"; accumulator[ipaddress] = (accumulator[ipaddress] || 0) + 1; accumulator["TOTAL_CONNECTION_COUNT"]++; return accumulator; }, { TOTAL_CONNECTION_COUNT: 0 })
格式化:
db.currentOp(true).inprog.reduce(
(accumulator, connection) => {
ipaddress = connection.client ? connection.client.split(":")[0] : "Internal";
accumulator[ipaddress] = (accumulator[ipaddress] || 0) + 1;
accumulator["TOTAL_CONNECTION_COUNT"]++;
return accumulator;
},
{ TOTAL_CONNECTION_COUNT: 0 }
)
示例返回:
{
"TOTAL_CONNECTION_COUNT" : 331,
"192.168.253.72" : 8,
"192.168.254.42" : 17,
"127.0.0.1" : 3,
"192.168.248.66" : 2,
"11.178.12.244" : 2,
"Internal" : 41,
"3.100.12.33" : 86,
"11.148.23.34" : 168,
"81.127.34.11" : 1,
"84.147.25.17" : 3
}
(Atlas内部监控程序的192.x.x.x地址)
答案 6 :(得分:2)
db.runCommand({“connPoolStats”:1})
{
"numClientConnections" : 0,
"numAScopedConnections" : 0,
"totalInUse" : 0,
"totalAvailable" : 0,
"totalCreated" : 0,
"hosts" : {
},
"replicaSets" : {
},
"ok" : 1
}
答案 7 :(得分:2)
使用mongo-shell连接到MongoDB并运行以下命令。
db.serverStatus().connections
e.g:
mongo> db.serverStatus().connections
{ "current" : 3, "available" : 816, "totalCreated" : NumberLong(1270) }
答案 8 :(得分:2)
对不起,因为这是一个过时的帖子,当前有比以前更多的选择。
db.getSiblingDB("admin").aggregate( [
{ $currentOp: { allUsers: true, idleConnections: true, idleSessions: true } }
,{$project:{
"_id":0
,client:{$arrayElemAt:[ {$split:["$client",":"]}, 0 ] }
,curr_active:{$cond:[{$eq:["$active",true]},1,0]}
,curr_inactive:{$cond:[{$eq:["$active",false]},1,0]}
}
}
,{$match:{client:{$ne: null}}}
,{$group:{_id:"$client",curr_active:{$sum:"$curr_active"},curr_inactive:{$sum:"$curr_inactive"},total:{$sum:1}}}
,{$sort:{total:-1}}
] )
输出示例:
{ "_id" : "xxx.xxx.xxx.78", "curr_active" : 0, "curr_inactive" : 1428, "total" : 1428 }
{ "_id" : "xxx.xxx.xxx.76", "curr_active" : 0, "curr_inactive" : 1428, "total" : 1428 }
{ "_id" : "xxx.xxx.xxx.73", "curr_active" : 0, "curr_inactive" : 1428, "total" : 1428 }
{ "_id" : "xxx.xxx.xxx.77", "curr_active" : 0, "curr_inactive" : 1428, "total" : 1428 }
{ "_id" : "xxx.xxx.xxx.74", "curr_active" : 0, "curr_inactive" : 1428, "total" : 1428 }
{ "_id" : "xxx.xxx.xxx.75", "curr_active" : 0, "curr_inactive" : 1428, "total" : 1428 }
{ "_id" : "xxx.xxx.xxx.58", "curr_active" : 0, "curr_inactive" : 510, "total" : 510 }
{ "_id" : "xxx.xxx.xxx.57", "curr_active" : 0, "curr_inactive" : 459, "total" : 459 }
{ "_id" : "xxx.xxx.xxx.55", "curr_active" : 0, "curr_inactive" : 459, "total" : 459 }
{ "_id" : "xxx.xxx.xxx.56", "curr_active" : 0, "curr_inactive" : 408, "total" : 408 }
{ "_id" : "xxx.xxx.xxx.47", "curr_active" : 1, "curr_inactive" : 11, "total" : 12 }
{ "_id" : "xxx.xxx.xxx.48", "curr_active" : 1, "curr_inactive" : 7, "total" : 8 }
{ "_id" : "xxx.xxx.xxx.51", "curr_active" : 0, "curr_inactive" : 8, "total" : 8 }
{ "_id" : "xxx.xxx.xxx.46", "curr_active" : 0, "curr_inactive" : 8, "total" : 8 }
{ "_id" : "xxx.xxx.xxx.52", "curr_active" : 0, "curr_inactive" : 6, "total" : 6 }
{ "_id" : "127.0.0.1", "curr_active" : 1, "curr_inactive" : 0, "total" : 1 }
{ "_id" : "xxx.xxx.xxx.3", "curr_active" : 0, "curr_inactive" : 1, "total" : 1 }
答案 9 :(得分:1)
您可以使用
db.serverStatus().connections
此外,此功能可以帮助您发现连接到Mongo DB的IP地址
db.currentOp(true).inprog.forEach(function(x) { print(x.client) })
答案 10 :(得分:0)
从本地系统连接您的mongodb实例
它会让您知道所有连接的客户端及其详细信息
db.currentOp(true)
答案 11 :(得分:0)
或者,您可以通过登录Mongo Atlas并导航到群集来检查连接状态。