2017-02-28 132 views
1

SpringConfig.xml说:MongoDB的连接不是在春季启动封闭得到

<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 like:

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; 

但是,即使在超时期限之后,连接仍未关闭。

有什么想法?

感谢

+1

你的期望是什么?你想为每个查询建立一个新的连接吗? – Veeram

+0

@Veeram,当我运行db.serverStatus()。连接时,我获得当前键下增加的连接,比发送请求之前 – Satya

回答

1

没有为每个蒙戈模板最多100大小的连接池(默认),而这些又再次重用&速度,这样连接不会被关闭,也就是connections-per-host="8"在蒙戈客户选项。所以你最多只能有8个连接,只要你的应用停留,它们就会停留。为了具备自动

编辑:杀连接,可以使用下面的属性让他们自杀的计时器maxConnectionIdleTime: 1000,使具有闲置时间> 1000毫秒就会被杀死任何空闲连接,这样做工作,我已经测试过&连接池大小的变化可以在下面看到;服务器重新启动后

enter image description here

斯派克是我的负载测试,并没有充分发挥其连接池的限制,并达到顶峰后,连接被打死。虽然必须说创建连接的确是非常昂贵的,但是我的响应时间增加了百倍以上,所以不是没有连接池的最佳解决方案,尽管只有在长时间不活动之后才会有更长的时间你会开始关闭连接,并且也有minConnectionsPerHost的值,所以你总是会准备好大量的连接池,如果需要的话,你可以增加它,然后在服务器不活跃的时候杀掉多余的部分,冲洗并重复!

+0

@Satya我更新了我的答案,我认为这对你会有帮助! –