添加链接
link管理
链接快照平台
  • 输入网页链接,自动生成快照
  • 标签化管理网页链接
Update avaliable. Click RELOAD to update.
目录

mongodb异常Too many threads are already waiting for a connection

通过 java 操作 mongodb 时,后台出现的 UncategorizedMongoDbException 错误。

Too many threads are already waiting for a connection.
Max number of threads (maxWaitQueueSize) of 50 has been exceeded.

上面的错误属于 mongodb 自身的异常,这个异常的原因在于 mongodb 的连接线程数不够使用,导致下面的客户端获取不到连接而抛出了队列等待线程数已满的错误。

解决方式

# 设置属性connectionsPerHost
MongoClient client = new MongoClient("127.0.0.1",MongoClientOptions.builder()
    .connectionsPerHost(250)
    .build());
<!-- spring 4新版本中 -->
<mongo:mongo host="${mongo.db.host}" port="${mongo.db.port}">
    <!-- 设置属性connectionsPerHost -->
    <mongo:options connections-per-host="100"/>
</mongo:mongo>
<!-- spring 4版本之下的 -->
<bean id="options" class="com.mongodb.MongoOptions">
    <property name="connectionsPerHost" value="${mongo.db.pool.size}"/>
    <property name="maxWaitTime" value="${mongo.db.pool.maxwait}"/>
</bean>
<bean id="address" class="com.mongodb.ServerAddress">
    <constructor-arg name="host" value="${mongo.db.host}" />
    <constructor-arg name="port" value="${mongo.db.port}" />
</bean>
<bean id="mongo" class="com.mongodb.Mongo">
    <constructor-arg name="addr" ref="address" />
    <constructor-arg name="options" ref="options" />