首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >JMS通道不使用多线程

JMS通道不使用多线程
EN

Stack Overflow用户
提问于 2018-09-23 02:55:05
回答 1查看 65关注 0票数 0

我正在读取一条消息,对其进行转换并在JMS通道上输出。JMS通道使用WorkManager任务执行器读取消息并对其进行处理。尽管我们将应用服务器中的WorkManager配置为有10个线程,但只使用了一个线程。

代码语言:javascript
复制
<si:chain id="prenotifchain" input-channel="preNotificationChannel"  output-channel="notificationJMSChannel">           
    <si:transformer id="prenotif"  method="transformRequest"  ref="notificationTransformer"/>   
</si:chain> 



<si-jms:channel id="notificationJMSChannel" queue="notificationQueue" connection-factory="queueConnectionFactory" transaction-manager="txManager" task-executor="notificationTaskExecutor"  />

<jee:jndi-lookup id="notificationQueue" jndi-name="jms/notifqueue"/>    


    <bean id="notificationTaskExecutor"
    class="org.springframework.scheduling.commonj.WorkManagerTaskExecutor">
    <property name="workManagerName" value="notifWM" />
    <property name="resourceRef" value="true" />
</bean>

我们是否遗漏了任何配置,或者是否有其他方法读取多个配置?

EN

回答 1

Stack Overflow用户

发布于 2018-09-23 04:25:20

请使用concurrency属性:

代码语言:javascript
复制
<xsd:attribute name="concurrency" type="xsd:string">
        <xsd:annotation>
            <xsd:documentation><![CDATA[
The number of concurrent sessions/consumers to start for each listener.
Can either be a simple number indicating the maximum number (e.g. "5")
or a range indicating the lower as well as the upper limit (e.g. "3-5").
Note that a specified minimum is just a hint and might be ignored at runtime.
Default is 1; keep concurrency limited to 1 in case of a topic listener
or if message ordering is important; consider raising it for general queues.
            ]]></xsd:documentation>
        </xsd:annotation>
    </xsd:attribute>
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/52459865

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档