2025-05-21 13:48:03 +01:00
|
|
|
---
|
|
|
|
|
layout: default
|
|
|
|
|
---
|
|
|
|
|
|
2025-05-21 12:03:24 +00:00
|
|
|
# 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)
|
2025-11-13 18:11:29 +00:00
|
|
|
- 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`)
|
2025-05-21 12:03:24 +00:00
|
|
|
|
2025-11-13 18:11:29 +00:00
|
|
|
Plugins are scoped under `go-micro.dev/v5/store/<plugin>`.
|
|
|
|
|
|
|
|
|
|
Configure the store in code or via environment variables.
|
2025-05-21 12:03:24 +00:00
|
|
|
|
|
|
|
|
## Example Usage
|
|
|
|
|
|
|
|
|
|
Here's how to use the store in your Go Micro service:
|
|
|
|
|
|
|
|
|
|
```go
|
|
|
|
|
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))
|
|
|
|
|
}
|
|
|
|
|
```
|
2025-11-13 18:11:29 +00:00
|
|
|
|
|
|
|
|
## Configure a specific store in code
|
|
|
|
|
|
|
|
|
|
Postgres:
|
|
|
|
|
```go
|
|
|
|
|
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:
|
|
|
|
|
```go
|
|
|
|
|
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).
|