此版本仍在开发中,尚不被认为是稳定的。对于最新的稳定版本,请使用 Spring Integration 6.5.1! |
FTP 会话缓存
从 Spring Integration 3.0 开始,默认情况下不再缓存会话。
这cache-sessions 端点不再支持属性。
您必须使用CachingSessionFactory (如下一个示例所示),如果希望缓存会话。 |
在 3.0 之前的版本中,默认情况下会自动缓存会话。
一个cache-sessions
属性可用于禁用自动缓存,但该解决方案不提供配置其他会话缓存属性的方法。
例如,您无法限制创建的会话数。
为了支持该要求和其他配置选项,一个CachingSessionFactory
被添加。
它提供了sessionCacheSize
和sessionWaitTimeout
性能。
这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
设置为10
和sessionWaitTimeout
设置为一秒(其值以毫秒为单位)。
从 Spring Integration 3.0 开始,CachingConnectionFactory
提供一个resetCache()
方法。
调用时,所有空闲会话都会立即关闭,正在使用的会话在返回到缓存时会关闭。
新的会话请求会根据需要建立新的会话。
从 5.1 版本开始,CachingSessionFactory
有一个新属性testSession
.
当为 true 时,将通过发送 NOOP 命令来测试会话,以确保它仍然处于活动状态;如果没有,它将从缓存中删除;如果缓存中没有活动会话,则会创建新会话。