Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/cooperlyt/rocketmq-reactive-client-spring
RocketMQ-Spring with Reactive
https://github.com/cooperlyt/rocketmq-reactive-client-spring
flux mono reactive rocketmq stream
Last synced: about 1 month ago
JSON representation
RocketMQ-Spring with Reactive
- Host: GitHub
- URL: https://github.com/cooperlyt/rocketmq-reactive-client-spring
- Owner: cooperlyt
- Created: 2024-04-19T10:52:31.000Z (9 months ago)
- Default Branch: master
- Last Pushed: 2024-04-21T23:10:15.000Z (9 months ago)
- Last Synced: 2024-10-21T05:08:10.095Z (2 months ago)
- Topics: flux, mono, reactive, rocketmq, stream
- Language: Kotlin
- Homepage:
- Size: 87.9 KB
- Stars: 0
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# RocketMQ-Reactive-Consumer-Spring
This project aims to help developers quickly integrate [RocketMQ-Spring](https://github.com/apache/rocketmq-spring) with Reactive.
## Features
- [x] Consuming messages from RocketMQ with Reactive
- [x] Using Spring content ObjectMapper deserialization## Usage
使用和配置方式类似于 Spring Cloud Stream RocketMQ Binder,但解决一个Stream不能处理流中出现异常无法报告消息失败的[问题](https://github.com/spring-cloud/spring-cloud-stream/issues/2892) 。application.yml
```yml
rocketmq:
name-server: 192.168.1.21:9876
producer:
group: group-test-producer
bindings:
testFunction1-in-0:
consumer:
topic: test-topic
group: group-test-consumer
retry:
maxAttempts: 3
backoff:
delay: 10000
multiplier: 0.4
```consumer
```kotlin
@Bean
fun contractCreateChannel(): (Message) -> Mono = { str ->
Mono.just("${str.payload}").then()
}@Bean
fun testChannel(): (Message) -> Mono = { str ->
Mono.just("${str.payload}").doOnNext(::println).thenReturn(ConsumerResult.SUCCESS)
}@Bean
fun testReplayChannel(): (Message) -> Mono = { str ->
Mono.just("${str.payload}").doOnNext(::println).thenReturn(ReplayData())
}@Bean
fun testConsumer1(): Consumer> = object: TypedConsumer>(Consumer { msg ->
println("Receive New Create Messages: ${msg.payload}")
}){}@Bean
fun testFunction1() = object: TypedReplayConsumer(Function { msg ->
Mono.just("${msg}").thenReturn("replay")
}) {}```
## [Samples](https://github.com/cooperlyt/rocketmq-reactive-client-spring/tree/master/rocketmq-reactive-client-spring-boot-starter/src/test/kotlin/io/github/cooperlyt/rocketmq/client/support)