Using custom handler nats golang retain subscription method
php editor Banana will introduce you to how to use a custom handler nats golang to retain the subscription method in this article. During the development process, we often need to use message queues to handle asynchronous tasks, and nats golang is a lightweight message queue system with high performance and scalability. By customizing the handler, we can retain the subscription method and achieve more flexible message processing and process control. Below we will introduce in detail how to implement this function in nats golang.
Question content
I am writing a wrapper on top of golang's nats client and I want to get a handler function that can be called from the consumer once I receive a message from the nats server . I want to keep the custom subscription method until it receives the message from nats.
release:
func (busconfig busconfig) publish(service string, data []byte) error { puberr := conn.publish(service, data) if puberr != nil { return puberr } return nil }
subscription:
func (busconfig busconfig) subscribe(subject string, handler func(msg []byte)) { fmt.println("subscrbing on : ", subject) //wg := sync.waitgroup{} //wg.add(1) subscription, err := conn.subscribe(subject, func(msg *nats.msg) { go func() { handler(msg.data) }() //wg.done() }) if err != nil { fmt.println("subscriber error : ", err) } //wg.wait() defer subscription.unsubscribe() }
Test case:
func TestLifeCycleEvent(t *testing.T) { busClient := GetBusClient() busClient.Subscribe(SUBJECT, func(input []byte) { fmt.Println("Life cycle event received :", string(input)) }) busClient.Publish(SUBJECT, []byte("complete notification")) }
I see that the message is published but not subscribed, I tried using waitgroup retain subscription method but I think it is not the right solution.
Workaround
You cannot see the message being delivered because Subscribe
is an asynchronous method that generates a goroutine to handle the incoming message and call the callback.
Your application exits immediately after calling busClient.Publish()
. It doesn't wait for anything to happen inside Subscribe()
.
When you use nats.Subscribe()
you typically have a long-running application that exits under certain conditions (such as receiving a shutdown signal). WaitGroup will work here, but probably not for real applications, just for testing.
You should also call the Flush()
method on the NATS connection to ensure that all buffered messages have been sent before exiting the program.
If you want a synchronized method, you can use nats.SubscribeSync()
View example: https://natsbyexample.com/examples/messaging/publish-subscribe/execute
The above is the detailed content of Using custom handler nats golang retain subscription method. For more information, please follow other related articles on the PHP Chinese website!

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics

This article demonstrates creating mocks and stubs in Go for unit testing. It emphasizes using interfaces, provides examples of mock implementations, and discusses best practices like keeping mocks focused and using assertion libraries. The articl

This article explores Go's custom type constraints for generics. It details how interfaces define minimum type requirements for generic functions, improving type safety and code reusability. The article also discusses limitations and best practices

The article discusses writing unit tests in Go, covering best practices, mocking techniques, and tools for efficient test management.

This article explores using tracing tools to analyze Go application execution flow. It discusses manual and automatic instrumentation techniques, comparing tools like Jaeger, Zipkin, and OpenTelemetry, and highlighting effective data visualization

The article explains how to use the pprof tool for analyzing Go performance, including enabling profiling, collecting data, and identifying common bottlenecks like CPU and memory issues.Character count: 159

The article discusses Go's reflect package, used for runtime manipulation of code, beneficial for serialization, generic programming, and more. It warns of performance costs like slower execution and higher memory use, advising judicious use and best

This article advocates for using linters and static analysis tools to enhance Go code quality. It details tool selection (e.g., golangci-lint, go vet), workflow integration (IDE, CI/CD), and effective interpretation of warnings/errors to improve cod

The article discusses using table-driven tests in Go, a method that uses a table of test cases to test functions with multiple inputs and outcomes. It highlights benefits like improved readability, reduced duplication, scalability, consistency, and a
