Unlock the Power of Pub/Sub Services in Go

What is Pub/Sub?

Imagine a messaging system where publishers send messages to subscribers without knowing the specifics of any single subscriber. Meanwhile, subscribers receive messages associated with a specific topic without knowing any details about the publisher. This system provides greater network scalability and can be used in various applications, such as streaming analytics or data integration pipelines.

Implementing Pub/Sub in Go

In this guide, we’ll explore how to implement a pub/sub service in Go using Go Patterns. We’ll use in-process communication between several Goroutines over channels, leveraging concurrent programming to communicate between independently running Goroutines.

File Structure

Our file structure consists of a new package named pubsub and a module called main.go, where we’ll run a crypto price example.

Creating and Publishing Messages

Let’s start with a simple implementation. Each message object has multiple attributes, including the topic and message body. Subscribers have a unique identifier string and a channel of messages, where publishers push messages via the signal() method. The Broker structure consists of all subscribers and a map of topics for subscribers to subscribe to.

Subscribing and Unsubscribing

The Subscribe method subscribes a given topic to a given subscriber by adding a topic to the Subscriber and creating an entry in the broker topics with a subscriber ID. The Unsubscribe method unsubscribes a subscriber from a given topic by deleting the subscriber ID from the specific topic map and removing the topic from the list of topics for that subscriber.

Removing Subscribers and Destruct Method

The RemoveSubscriber method removes a given subscriber from the broker by unsubscribing the subscriber from all topics and deleting the subscriber from the main subscriber list. The Destruct method sets the active flag to false, closing the message channel once we’re done sending.

Final Code

Now that we’ve covered the important snippets, let’s discuss the final complete code. We have pubsub/message.go, pubsub/subscriber.go, and pubsub/broker.go, where we define the message structure, subscriber, and broker methods, respectively.

Example: Crypto Price Updates

Let’s use our pub/sub service to get price updates of cryptocurrencies. The publisher publishes the price value of cryptocurrencies, and subscribers receive the price update. We’ll generate random price values for each cryptocurrency and publish them with their respective topic names.

Output

The output will display the received messages in the console.

Go’s Approach to Concurrency

Go follows a distinctive approach to concurrency, emphasizing communication over shared memory. While Go is a pragmatic language, it’s essential to clean up resources after the job is done.

Get Started with LogRocket

Ready to take your error tracking to the next level? Sign up for LogRocket and get set up with modern error tracking in minutes!

Leave a Reply