Spring Integration channel中使用message-store的例子

<bean id="sessionQueuePersistance"
    class="com.emph.SessionQueuePersistance">
    <constructor-arg name="sessionInboundChannel" ref="sessionInboundChannel" />
</bean>

<int:channel id="sessionInboundChannel">
    <int:queue message-store="sessionStore" />
    <int:interceptors>
        <int:ref bean="messageListener"/>
    </int:interceptors>
</int:channel>

<bean id="messageListener" class="com.emph.MessageListener" />

<!-- int:logging-channel-adapter id="logger" log-full-message="true" level="INFO" /-->

<bean id="sessionStore"
    class="org.springframework.integration.jdbc.store.JdbcChannelMessageStore">
    <property name="dataSource" ref="queueDataSource" />
    <property name="channelMessageStoreQueryProvider" ref="queryProvider" />
    <property name="tablePrefix" value="QUEUE_" />
</bean>

<bean id="queryProvider"
    class="org.springframework.integration.jdbc.store.channel.OracleChannelMessageStoreQueryProvider" />

<bean id="queueDataSource"
    class="org.springframework.jdbc.datasource.DriverManagerDataSource">
    <property name="driverClassName" value="oracle.jdbc.driver.OracleDriver" />
    <property name="url" value="jdbc:oracle:thin:@localhost:1521:XE" />
    <property name="username" value="test" />
    <property name="password" value="test" />
</bean>

<!-- the bridge polls the persisted messages and forwards them to the output 
    channel -->
<int:bridge input-channel="sessionInboundChannel"
    output-channel="sessionOutboundChannel">
    <int:poller fixed-rate="1000" max-messages-per-poll="-1">
        <int:transactional transaction-manager="txManager" />
    </int:poller>
</int:bridge>

<bean id="txManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
    <property name="dataSource" ref="queueDataSource"/>
</bean>

<int:channel id="sessionOutboundChannel">
    <int:dispatcher task-executor="taskExecutor" />
</int:channel>

<bean id="sessionQueueReader" class="com.emph.SessionReader" />

<int:service-activator input-channel="sessionOutboundChannel"
    ref="sessionQueueReader" method="handleMessage" />

<bean id="taskExecutor"
    class="org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor">
    <property name="corePoolSize" value="4" />
    <property name="maxPoolSize" value="4" />
</bean>
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值