[springboot mongodb] DefaultServerMonitor Exception in monitor thread while connecting to server

本文讲述了在SpringBoot工程中,尽管MongoTemplate操作正常,但因MongoDB连接配置中的mongos节点地址错误导致的连接问题。作者发现私有云托管的MongoDB中,mongos节点地址变更或配置失误引发异常。排查过程中,通过抓包和DefaultServerMonitor工具确认了TCP握手失败是原因。

1.问题描述

springboot mongodb工程报错,但是mongoTemplate查询、修改都正常;

2.解决办法

结论:检查mongodb连接配置信息,mongos节点为多个,有一个地址端口配置错误,导致连接不上对应的mongos节点、控制台一直报错,但是查询、修改功能都正常;

解释说明:私有云托管的mongodb,mongos节点地址被变更、笔误配置写错,都有可能导致上面的异常打印。

3. 排查办法

网上也没看到我这种情况,抓包之下才发现问题,tcp握手一直不成功,使用navicat测试连接发现地址端口变了。

4.DefaultServerMonitor简介

DefaultServerMonitor以固定频率请求服务器,获取mongodb服务器状态信息等。如果spring.data.mongodb.uri配置了多个mongos地址,日志里可以看到会输出多条信息,连不上就会抛出之前的异常了。

项目突然跑不起来报这个错 Exception in monitor thread while connecting to server 10.18.21.79:27117 com.mongodb.MongoSocketReadException: Exception receiving message at com.mongodb.connection.InternalStreamConnection.translateReadException(InternalStreamConnection.java:536) at com.mongodb.connection.InternalStreamConnection.receiveMessage(InternalStreamConnection.java:421) at com.mongodb.connection.InternalStreamConnection.receiveCommandMessageResponse(InternalStreamConnection.java:290) at com.mongodb.connection.InternalStreamConnection.sendAndReceive(InternalStreamConnection.java:255) at com.mongodb.connection.CommandHelper.sendAndReceive(CommandHelper.java:84) at com.mongodb.connection.CommandHelper.executeCommand(CommandHelper.java:34) at com.mongodb.connection.InternalStreamConnectionInitializer.initializeConnectionDescription(InternalStreamConnectionInitializer.java:91) at com.mongodb.connection.InternalStreamConnectionInitializer.initialize(InternalStreamConnectionInitializer.java:51) at com.mongodb.connection.InternalStreamConnection.open(InternalStreamConnection.java:127) at com.mongodb.connection.DefaultServerMonitor$ServerMonitorRunnable.run(DefaultServerMonitor.java:114) at java.lang.Thread.run(Thread.java:748) Caused by: java.net.SocketException: Connection reset at java.net.SocketInputStream.read(SocketInputStream.java:210) at java.net.SocketInputStream.read(SocketInputStream.java:141) at com.mongodb.connection.SocketStream.read(SocketStream.java:84) at com.mongodb.connection.InternalStreamConnection.receiveResponseBuffers(InternalStreamConnection.java:547) at com.mongodb.connection.InternalStreamConnection.receiveMessage(InternalStreamConnection.java:418)
06-09
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值