我的 SpringConfig.xml 说:
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:context="http://www.springframework.org/schema/context"
xmlns:mongo="http://www.springframework.org/schema/data/mongo"
xsi:schemaLocation="http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context-3.0.xsd
http://www.springframework.org/schema/data/mongo
http://www.springframework.org/schema/data/mongo/spring-mongo-1.10.xsd
http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans-3.0.xsd">
<mongo:mongo-client id="mongo" host="127.0.0.1" port="27017" >
<mongo:client-options
connections-per-host="8"
threads-allowed-to-block-for-connection-multiplier="4"
connect-timeout="1000"
max-wait-time="1500"
socket-keep-alive="true"
socket-timeout="1500"
/>
</mongo:mongo-client>
<mongo:db-factory dbname="test" mongo-ref="mongo" />
<bean id="mappingContext"
class="org.springframework.data.mongodb.core.mapping.MongoMappingContext" />
<bean id="defaultMongoTypeMapper"
class="org.springframework.data.mongodb.core.convert.DefaultMongoTypeMapper">
<constructor-arg name="typeKey"><null/></constructor-arg>
</bean>
<bean id="mappingMongoConverter"
class="org.springframework.data.mongodb.core.convert.MappingMongoConverter">
<constructor-arg name="mongoDbFactory" ref="mongoDbFactory" />
<constructor-arg name="mappingContext" ref="mappingContext" />
<property name="typeMapper" ref="defaultMongoTypeMapper" />
</bean>
<bean id="mongoTemplate" class="org.springframework.data.mongodb.core.MongoTemplate">
<constructor-arg name="mongoDbFactory" ref="mongoDbFactory" />
<constructor-arg name="mongoConverter" ref="mappingMongoConverter" />
</bean>
</beans>
我在服务的构造函数中只调用一次:
ApplicationContext ctx;
public DoctorService() {
ctx = new GenericXmlApplicationContext("SpringConfig.xml");
}
然后使用 ctx ,如:
MongoOperations mongoOperation = (MongoOperations) ctx.getBean("mongoTemplate");
Query searchUserQuery = new Query(Criteria.where("_id").is( new ObjectId(userId)));
Keys k = new Keys();
Doctor doctor = mongoOperation.findOne(searchUserQuery, Doctor.class);
k.setSessionId(doctor.getSessionid());
k.setToken(doctor.getToken());
List<Keys> keys = new ArrayList<Keys>();
keys.add(k);
return keys;
但是,即使在超时期限之后,连接也没有关闭。
有什么想法吗?
由于
答案 0 :(得分:1)
每个mongo模板都有一个最大100个大小的连接池(默认情况下),这些连接池将再次重复使用。再次提高速度,因此连接不会被关闭,即mongo客户端选项中的connections-per-host="8"
。因此,您最多只能有8个连接,并且只要您的应用程序停留,它们就会保留。要自动
编辑: 要终止连接,您可以使用以下属性让他们使用计时器maxConnectionIdleTime: 1000
自杀,因此任何具有<空闲时间> 1000毫秒将被杀死,这确实有效,我已经测试过&amp;连接池大小的变化可以在下面看到;
服务器重启后的峰值是我的负载测试,并且没有达到其完整的连接池限制,并且在达到峰值后,连接被终止。虽然必须说连接创建确实非常昂贵,但我的响应时间增加了一百多倍,所以不是没有连接池的最佳解决方案,尽管最好只有一段maxConnectionIdleTime
这样的经过长时间的不活动,你开始杀死连接,并且还有一个minConnectionsPerHost
值,所以你总是准备好相当数量的连接池,如果需要你可以增加它,然后在服务器时杀死多余的不太活跃,冲洗和重复!