FTP 會話快取

從 Spring Integration 3.0 開始,會話預設不再快取。cache-sessions 屬性在端點上不再受支援。如果您希望快取會話,則必須使用 CachingSessionFactory(如下一個示例所示)。

在 3.0 之前的版本中,會話預設自動快取。提供了 cache-sessions 屬性來停用自動快取,但該解決方案無法配置其他會話快取屬性。例如,您無法限制建立的會話數量。為了支援此要求和其他配置選項,添加了 CachingSessionFactory。它提供了 sessionCacheSizesessionWaitTimeout 屬性。sessionCacheSize 屬性控制工廠在其快取中維護的活動會話數量(預設值是無限制)。如果已達到 sessionCacheSize 閾值,則任何獲取另一個會話的嘗試都將阻塞,直到其中一個快取會話可用或會話等待時間到期(預設等待時間為 Integer.MAX_VALUE)。sessionWaitTimeout 屬性配置該值。

如果您希望快取會話,請按照前面所述配置您的預設會話工廠,然後將其包裝在 CachingSessionFactory 例項中,您可以在其中提供這些附加屬性。以下示例展示瞭如何實現:

<bean id="ftpSessionFactory" class="o.s.i.ftp.session.DefaultFtpSessionFactory">
    <property name="host" value="localhost"/>
</bean>

<bean id="cachingSessionFactory" class="o.s.i.file.remote.session.CachingSessionFactory">
    <constructor-arg ref="ftpSessionFactory"/>
    <constructor-arg value="10"/>
    <property name="sessionWaitTimeout" value="1000"/>
</bean>

前面的示例展示了一個 CachingSessionFactory,其 sessionCacheSize 設定為 10sessionWaitTimeout 設定為一秒(其值以毫秒為單位)。

從 Spring Integration 3.0 開始,CachingConnectionFactory 提供了一個 resetCache() 方法。呼叫後,所有空閒會話立即關閉,正在使用的會話在返回到快取時關閉。如有必要,對會話的新請求會建立新會話。

從 5.1 版本開始,CachingSessionFactory 有一個新屬性 testSession。當為 true 時,會話將透過傳送 NOOP 命令進行測試,以確保它仍然處於活動狀態;如果不是,它將從快取中移除;如果快取中沒有活動會話,則會建立一個新會話。

© . This site is unofficial and not affiliated with VMware.