Skip to content

Widhian Bramantya

coding is an art form

Menu
  • About Me
Menu
nats

Key-Value Store in NATS: Simple State Management

Posted on September 6, 2025September 6, 2025 by admin

Example in Go

Create a KV Bucket

js, _ := nc.JetStream()
kv, _ := js.CreateKeyValue(&nats.KeyValueConfig{
    Bucket: "CONFIGS",
})

Put a Value

kv.Put("featureX.enabled", []byte("true"))

Get a Value

entry, _ := kv.Get("featureX.enabled")
fmt.Printf("Value: %s\n", string(entry.Value()))

Watch for Changes

watch, _ := kv.Watch("featureX.*")
for update := range watch.Updates() {
    if update != nil {
        fmt.Printf("Key %s changed to %s\n", update.Key(), string(update.Value()))
    }
}

With Watch, any time a key is updated, subscribers get notified instantly.

Use Case Examples

  1. Feature Flags
    • Key: featureX.enabled → Value: true/false.
    • All services watch this key and automatically switch behavior when it changes.
  2. Service Discovery (Lightweight)
    • Key: service.auth.url → Value: http://10.0.0.5:8080.
    • Clients always read the latest location of a service.
  3. Leader Election
    • Services write a key like leader=node1.
    • Others watch the key to know who the leader is.

Final Thoughts

The NATS KV store is not meant to replace a full database, but it’s perfect for lightweight state, configuration, and coordination. Because it’s built on top of JetStream, it’s reliable and supports history of changes.

See also  Producers and Consumers: How Data Flows in Kafka
Pages: 1 2
Category: NATS

Leave a Reply Cancel reply

Your email address will not be published. Required fields are marked *

Linkedin

Widhian Bramantya

Recent Posts

  • Log Management at Scale: Integrating Elasticsearch with Beats, Logstash, and Kibana
  • Index Lifecycle Management (ILM) in Elasticsearch: Automatic Data Control Made Simple
  • Blue-Green Deployment in Elasticsearch: Safe Reindexing and Zero-Downtime Upgrades
  • Maintaining Super Large Datasets in Elasticsearch
  • Elasticsearch Best Practices for Beginners
  • Implementing the Outbox Pattern with Debezium
  • Production-Grade Debezium Connector with Kafka (Postgres Outbox Example – E-Commerce Orders)
  • Connecting Debezium with Kafka for Real-Time Streaming
  • Debezium Architecture – How It Works and Core Components
  • What is Debezium? – An Introduction to Change Data Capture
  • Offset Management and Consumer Groups in Kafka
  • Partitions, Replication, and Fault Tolerance in Kafka
  • Delivery Semantics in Kafka: At Most Once, At Least Once, Exactly Once
  • Producers and Consumers: How Data Flows in Kafka
  • Kafka Architecture Explained: Brokers, Topics, Partitions, and Offsets
  • Getting Started with Apache Kafka: Core Concepts and Use Cases
  • Security Best Practices for RabbitMQ in Production
  • Understanding RabbitMQ Virtual Hosts (vhosts) and Their Uses
  • RabbitMQ Performance Tuning: Optimizing Throughput and Latency
  • High Availability in RabbitMQ: Clustering and Mirrored Queues Explained

Recent Comments

  1. Playing with VPC AWS (Part 2) – Widhian's Blog on Playing with VPC AWS (Part 1): VPC, Subnet, Internet Gateway, Route Table, NAT, and Security Group
  2. Basic Concept of ElasticSearch (Part 3): Translog, Flush, and Refresh – Widhian's Blog on Basic Concept of ElasticSearch (Part 1): Introduction
  3. Basic Concept of ElasticSearch (Part 2): Architectural Perspective – Widhian's Blog on Basic Concept of ElasticSearch (Part 3): Translog, Flush, and Refresh
  4. Basic Concept of ElasticSearch (Part 3): Translog, Flush, and Refresh – Widhian's Blog on Basic Concept of ElasticSearch (Part 2): Architectural Perspective
  5. Basic Concept of ElasticSearch (Part 1): Introduction – Widhian's Blog on Basic Concept of ElasticSearch (Part 2): Architectural Perspective

Archives

  • October 2025
  • September 2025
  • August 2025
  • November 2021
  • October 2021
  • August 2021
  • July 2021
  • June 2021
  • March 2021
  • January 2021

Categories

  • Debezium
  • Devops
  • ElasticSearch
  • Golang
  • Kafka
  • Lua
  • NATS
  • Programming
  • RabbitMQ
  • Redis
  • VPC
© 2025 Widhian Bramantya | Powered by Minimalist Blog WordPress Theme