當(dāng)前位置:
首頁(yè) >
前端技术
> javascript
>内容正文
javascript
spring消息队列_AmazonSQS和Spring用于消息传递队列
生活随笔
收集整理的這篇文章主要介紹了
spring消息队列_AmazonSQS和Spring用于消息传递队列
小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.
spring消息隊(duì)列
下一篇文章將演示如何將Spring JMS模板和DLMC與AmazonSQS API一起使用,以放置消息隊(duì)列。
我為什么要使用Amazon SQS?
為什么我不使用Amazon SQS?
我遇到了一個(gè)很好的開源項(xiàng)目:Nevado,它以非常簡(jiǎn)潔的方式包裝了Amazon SQS API。
將此添加到您的Maven依賴項(xiàng):
<dependency><groupId>org.skyscreamer</groupId><artifactId>nevado-jms</artifactId><version>1.2.4</version></dependency>現(xiàn)在,讓我們配置Spring bean,使其與AmazonSQS很好地集成:
1.連接工廠:
<bean id="sqsConnectorFactory" class="org.skyscreamer.nevado.jms.connector.amazonaws.AmazonAwsSQSConnectorFactory"/>請(qǐng)注意,在此包裝器中,我們需要設(shè)置aws.accessKey和aws.secretKey。 我們從AmazonSQS帳戶門戶獲取這些密鑰:
<bean id="connectionFactory" class="org.skyscreamer.nevado.jms.NevadoConnectionFactory"><property name="sqsConnectorFactory" ref="sqsConnectorFactory"/><property name="awsAccessKey" value="${aws.accessKey}"/><property name="awsSecretKey" value="${aws.secretKey}"/></bean>2.創(chuàng)建隊(duì)列
<bean id="myQueue" class="org.skyscreamer.nevado.jms.destination.NevadoQueue"><constructor-arg value="${aws.sqs.queue.name}"/></bean>3.創(chuàng)建Jms模板(稍后將在代碼中注入它以發(fā)送消息):
<bean id="jmsTemplate" class="org.springframework.jms.core.JmsTemplate"><property name="defaultDestinationName" value="${aws.sqs.queue.name}"/><property name="connectionFactory" ref="cachedConnectionFactory"/></bean>4.添加監(jiān)聽器:
- 4.a我正在使用SimpleMessageListenerContainer,它具有緩存連接,運(yùn)行并發(fā)使用者,設(shè)置錯(cuò)誤偵聽器等功能。 <bean id="simpleMessageListenerContainer" class="org.springframework.jms.listener.SimpleMessageListenerContainer"><property name="connectionFactory" ref="connectionFactory"/><property name="messageListener" ref="listener"/><property name="destination" ref="myQueue"/><property name="errorHandler" ref="amazonMessageListener"/><property name="concurrency" value="20"/><property name="taskExecutor" ref="listenerThreadPoolTaskExecutor"/></bean>
- 4.b讓我們?yōu)閭陕犉鞯膱?zhí)行者添加線程池: <bean id="listenerThreadPoolTaskExecutor" class="org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor"><property name="corePoolSize" value="70"/><property name="maxPoolSize" value="70"/><property name="daemon" value="true"/><property name="keepAliveSeconds" value="60"/></bean>
- 4.c添加緩存連接支持: <bean id="cachedConnectionFactory" class="org.springframework.jms.connection.CachingConnectionFactory"><property name="targetConnectionFactory" ref="connectionFactory"/><property name="sessionCacheSize" value="10"/></bean>
- 4.d創(chuàng)建MessageAdapter來(lái)掛接所有內(nèi)容,并將pojo設(shè)置為我們的消息監(jiān)聽器(amazonMessageListener): <bean id="listener" class="org.springframework.jms.listener.adapter.MessageListenerAdapter"><property name="delegate" ref="amazonMessageListener"/><property name="defaultListenerMethod" value="onMessage"/><property name="defaultResponseDestination" ref="myQueue"/></bean>
翻譯自: https://www.javacodegeeks.com/2014/01/amazonsqs-and-spring-for-messaging-queue.html
spring消息隊(duì)列
總結(jié)
以上是生活随笔為你收集整理的spring消息队列_AmazonSQS和Spring用于消息传递队列的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 使用Spring Boot和H2可以完全
- 下一篇: 腾讯文档代码快捷键(腾讯文档功能)