1
0
mirror of https://github.com/go-micro/go-micro.git synced 2025-11-23 21:44:41 +02:00
Files
go-micro/internal/website/docs/store.md
2025-11-13 18:11:29 +00:00

2.1 KiB

layout
layout
default

Store

The store provides a pluggable interface for data storage in Go Micro.

Features

  • Key-value storage
  • Multiple backend support

Implementations

Supported stores include:

  • Memory (default)
  • File (go-micro.dev/v5/store/file)
  • MySQL (go-micro.dev/v5/store/mysql)
  • Postgres (go-micro.dev/v5/store/postgres)
  • NATS JetStream KV (go-micro.dev/v5/store/nats-js-kv)

Plugins are scoped under go-micro.dev/v5/store/<plugin>.

Configure the store in code or via environment variables.

Example Usage

Here's how to use the store in your Go Micro service:

package main

import (
    "go-micro.dev/v5"
    "go-micro.dev/v5/store"
    "log"
)

func main() {
    service := micro.NewService()
    service.Init()

    // Write a record
    if err := store.Write(&store.Record{Key: "foo", Value: []byte("bar")}); err != nil {
        log.Fatal(err)
    }

    // Read a record
    recs, err := store.Read("foo")
    if err != nil {
        log.Fatal(err)
    }
    log.Printf("Read value: %s", string(recs[0].Value))
}

Configure a specific store in code

Postgres:

import (
    "go-micro.dev/v5"
    postgres "go-micro.dev/v5/store/postgres"
)

func main() {
    st := postgres.NewStore()
    svc := micro.NewService(micro.Store(st))
    svc.Init()
    svc.Run()
}

NATS JetStream KV:

import (
    "go-micro.dev/v5"
    natsjskv "go-micro.dev/v5/store/nats-js-kv"
)

func main() {
    st := natsjskv.NewStore()
    svc := micro.NewService(micro.Store(st))
    svc.Init()
    svc.Run()
}

Configure via environment

MICRO_STORE=postgres MICRO_STORE_ADDRESS=postgres://user:pass@127.0.0.1:5432/db \
MICRO_STORE_DATABASE=micro MICRO_STORE_TABLE=micro \
micro server

Common variables:

  • MICRO_STORE: selects the store implementation (memory, file, mysql, postgres, nats-js-kv).
  • MICRO_STORE_ADDRESS: connection/address string for the store (plugin-specific format).
  • MICRO_STORE_DATABASE: logical database or namespace (plugin-specific).
  • MICRO_STORE_TABLE: logical table/bucket (plugin-specific).