Queue
Kapstan offers simple setup for popular message queues and event streaming technologies. This page will guide you through the process of creating a new queue in your environment. Kapstan offers the following queues:
Steps to Create a Queue
- Navigate to the services overview on Kapstan.
- Click on "Create" and then on "Queue".
NATS
- Learn more about NATS here.
- Kapstan deploys NATS version 2.10.
- Cluster mode in NATS ensures high availability and scalability by distributing messages across multiple servers, enabling fault tolerance and load balancing.
- Jetstream provides persistent messaging, stream storage, and advanced message replay capabilities for durable and reliable event-driven systems.
data:image/s3,"s3://crabby-images/e2f96/e2f9691c7b3a1322e86f2ff0874b0cc979e808d3" alt="Configure NATS"
Kafka
- Learn more about Kafka here.
- Kapstan deploys Kafka version 3.6.
- Cluster mode runs multiple Kafka servers to provide fault tolerance and high availability.
data:image/s3,"s3://crabby-images/e2cc3/e2cc323728c30e08bdff8f0019a323e7252bea20" alt="Configure Kafka"
AWS SQS
- Learn more about SQS here.
- Kapstan creates a best-effort ordering queue behind the scenes. This queue comes with a default 4 days retention and without a dead-letter queue. 100% ordering is not guaranteed. Learn more
data:image/s3,"s3://crabby-images/f97ac/f97acbc835bbf144d16b2811d114dd9b020aabf1" alt="Configure SQS"
GCP Pub/Sub
- Learn more about GCP Pub/Sub here.
- Kapstan creates a best-effort ordering queue behind the scenes. This queue comes with a default 30 days retention and without a dead-letter queue. 100% ordering is not guaranteed. Learn more
data:image/s3,"s3://crabby-images/61c71/61c71b488eea20b76e1ea6cf73972db56aa130dd" alt="Configure Pub/Sub"
Connecting to your Queue
You can connect to the queue using attributes provided in details view.
Example
data:image/s3,"s3://crabby-images/481fa/481fab319d1a005e1c7925b9662848a234d6ba17" alt="NATS Attributes"
We will use the following sample app that will connect to the NATS queue. This app creates two subscribers:
- One subscriber listens to the "foo.1" subject
- The other one listens to all subjects that start with "foo."
It will then publish a message to the "foo.1" and "foo.2" subjects every 5 seconds. You can download a zip file containing the code along with a Dockerfile to build a container image from here.
Sample application code
package main
import (
"fmt"
"github.com/nats-io/nats.go"
"log"
"os"
"time"
)
func main() {
nc, err := nats.Connect(os.Getenv("NATS_SERVER_URL"))
if err != nil {
log.Panic(err)
}
defer nc.Drain()
subscribe(nc, "normal_subscriber", "foo.1")
subscribe(nc, "wildcard_subscriber", "foo.*")
ticker := time.NewTicker(5 * time.Second)
for {
select {
case <-ticker.C:
err = nc.Publish("foo.1", []byte("Hello World"))
if err != nil {
log.Panic(err)
}
err = nc.Publish("foo.2", []byte("Hello World"))
if err != nil {
log.Panic(err)
}
}
}
}
func subscribe(client *nats.Conn, name, subject string) {
_, err := client.Subscribe(subject, func(msg *nats.Msg) {
fmt.Printf("sub %s: received message %q\n", name, msg.Subject)
})
if err != nil {
log.Panic(err)
}
}
Configure and deploy the application:
- Create a container image with the sample code provided here.
- Push the image to the container registry of your choice. Read more about how to connect your container registry to Kapstan here.
- Create a new application in Kapstan with the image you just created.
- Add an environment variable called
NATS_SERVER_URL
with the value ofClient URL
from NATS details view. - Deploy the application.
- Check application logs to verify that the application is now connected to the queue.
data:image/s3,"s3://crabby-images/891d6/891d624109d76c3d5dd648ffcd3f4abd6db426f6" alt="NATS Logs"