1
0
mirror of https://github.com/go-micro/go-micro.git synced 2025-07-12 22:41:07 +02:00
Files
go-micro/profile/profile.go
Brian Ketelsen ddc34801ee Plugins and profiles (#2764)
* feat: more plugins

* chore(ci): split out benchmarks

Attempt to resolve too many open files in ci

* chore(ci): split out benchmarks

* fix(ci): Attempt to resolve too many open files in ci

* fix: set DefaultX for cli flag and service option

* fix: restore http broker

* fix: default http broker

* feat: full nats profile

* chore: still ugly, not ready

* fix: better initialization for profiles

* fix(tests): comment out flaky listen tests

* fix: disable benchmarks on gha

* chore: cleanup, comments

* chore: add nats config source
2025-05-20 13:24:06 -04:00

76 lines
2.2 KiB
Go

// Package profileconfig provides grouped plugin profiles for go-micro
package profile
import (
"os"
"strings"
natslib "github.com/nats-io/nats.go"
"go-micro.dev/v5/broker"
"go-micro.dev/v5/broker/nats"
"go-micro.dev/v5/registry"
nreg "go-micro.dev/v5/registry/nats"
"go-micro.dev/v5/store"
nstore "go-micro.dev/v5/store/nats-js-kv"
"go-micro.dev/v5/transport"
ntx "go-micro.dev/v5/transport/nats"
)
type Profile struct {
Registry registry.Registry
Broker broker.Broker
Store store.Store
Transport transport.Transport
}
// LocalProfile returns a profile with local mDNS as the registry, HTTP as the broker, file as the store, and HTTP as the transport
// It is used for local development and testing
func LocalProfile() Profile {
return Profile{
Registry: registry.NewMDNSRegistry(),
Broker: broker.NewHttpBroker(),
Store: store.NewFileStore(),
Transport: transport.NewHTTPTransport(),
}
}
// NatsProfile returns a profile with NATS as the registry, broker, store, and transport
// It uses the environment variable MICR_NATS_ADDRESS to set the NATS server address
// If the variable is not set, it defaults to nats://0.0.0.0:4222 which will connect to a local NATS server
func NatsProfile() Profile {
addr := os.Getenv("MICRO_NATS_ADDRESS")
if addr == "" {
addr = "nats://0.0.0.0:4222"
}
// Split the address by comma, trim whitespace, and convert to a slice of strings
addrs := splitNatsAdressList(addr)
reg := nreg.NewNatsRegistry(registry.Addrs(addrs...))
brok := nats.NewNatsBroker(broker.Addrs(addrs...))
st := nstore.NewStore(nstore.NatsOptions(natslib.Options{Servers: addrs}))
tx := ntx.NewTransport(ntx.Options(natslib.Options{Servers: addrs}))
registry.DefaultRegistry = reg
broker.DefaultBroker = brok
store.DefaultStore = st
transport.DefaultTransport = tx
return Profile{
Registry: reg,
Broker: brok,
Store: st,
Transport: tx,
}
}
func splitNatsAdressList(addr string) []string {
// Split the address by comma
addrs := strings.Split(addr, ",")
// Trim any whitespace from each address
for i, a := range addrs {
addrs[i] = strings.TrimSpace(a)
}
return addrs
}
// Add more profiles as needed, e.g. grpc