2017-02-28 111 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我更新了我的答案,我認爲這對你會有幫助! –