README
¶
Go Micro v5

Go Micro is a framework for distributed systems development.
Have a look at examples for examples.
v5 is a proof of concept - DO NOT USE
v5 intodruces wire generated code.
See this Diagram for an overview:
Goals
- Add backward incompatible lint fixes
- Remove all globals
- Backward compatiblity is not required at all places but a nice to have
- Replace util/cmd
- Choose what features you want from go-micro:
- You can select if you want Auth/Events/"name it here"
- If you don't want CLI opts you can exclude them
- No default plugins, that makes the core even slimer
- Choose your Prefix for CLI opts not only "micro"
- No more Globals, everything lives in the DI
- wire for the end users will allow them wire theier app together
- Easy to make a micro Service and a monolith with the same codebase
Implemented features
- util/cmd/ is gone
- web/ is gone
- config/source/(env|file) is gone
- 6 components, component generator so easy to add them all
- Cli is a component now, its easy to replace it with other flag+env plugins
- ArgPrefix("myapp") for micro flags and environment vars
- NoFlags() option, this will disable all micro flags
- Config() option, to provide a config file
- Each component reads the configuration by its own, config is tightly coupled
Example yaml config
---
Broker:
Enabled: true
Plugin: nats
Addresses:
- nats://localhost:4222
Registry:
Enabled: true
Plugin: nats
Addresses:
- nats://localhost:4222
Store:
Enabled: false
Transport:
Enabled: true
Plugin: nats
Addresses:
- nats://localhost:4222
Overview
Go Micro provides the core requirements for distributed systems development including RPC and Event driven communication. The Go Micro philosophy is sane defaults with a pluggable architecture. We provide defaults to get you started quickly but everything can be easily swapped out.
Features
Go Micro abstracts away the details of distributed systems. Here are the main features.
-
Authentication - Auth is built in as a first class citizen. Authentication and authorization enable secure zero trust networking by providing every service an identity and certificates. This additionally includes rule based access control.
-
Dynamic Config - Load and hot reload dynamic config from anywhere. The config interface provides a way to load application level config from any source such as env vars, file, etcd. You can merge the sources and even define fallbacks.
-
Data Storage - A simple data store interface to read, write and delete records. It includes support for memory, file and CockroachDB by default. State and persistence becomes a core requirement beyond prototyping and Micro looks to build that into the framework.
-
Service Discovery - Automatic service registration and name resolution. Service discovery is at the core of micro service development. When service A needs to speak to service B it needs the location of that service. The default discovery mechanism is multicast DNS (mdns), a zeroconf system.
-
Load Balancing - Client side load balancing built on service discovery. Once we have the addresses of any number of instances of a service we now need a way to decide which node to route to. We use random hashed load balancing to provide even distribution across the services and retry a different node if there's a problem.
-
Message Encoding - Dynamic message encoding based on content-type. The client and server will use codecs along with content-type to seamlessly encode and decode Go types for you. Any variety of messages could be encoded and sent from different clients. The client and server handle this by default. This includes protobuf and json by default.
-
RPC Client/Server - RPC based request/response with support for bidirectional streaming. We provide an abstraction for synchronous communication. A request made to a service will be automatically resolved, load balanced, dialled and streamed.
-
Async Messaging - PubSub is built in as a first class citizen for asynchronous communication and event driven architectures. Event notifications are a core pattern in micro service development. The default messaging system is a HTTP event message broker.
-
Event Streaming - PubSub is great for async notifications but for more advanced use cases event streaming is preferred. Offering persistent storage, consuming from offsets and acking. Go Micro includes support for NATS Jetstream and Redis streams.
-
Synchronization - Distributed systems are often built in an eventually consistent manner. Support for distributed locking and leadership are built in as a Sync interface. When using an eventually consistent database or scheduling use the Sync interface.
-
Pluggable Interfaces - Go Micro makes use of Go interfaces for each distributed system abstraction. Because of this these interfaces are pluggable and allows Go Micro to be runtime agnostic. You can plugin any underlying technology.
Getting Started
To make use of Go Micro
package main
import (
_ "github.com/go-micro/microwire-plugins/sets/defaults/v5"
micro "github.com/go-micro/microwire/v5"
"github.com/go-micro/microwire/v5/logger"
)
func main() {
service, err := micro.NewService(
micro.Name("livecyclehooks"),
micro.Usage("A POC for go-micro.dev/v5"),
micro.Version("v0.0.1"),
micro.ArgPrefix(""),
)
if err != nil {
logger.Fatal(err)
}
if err := service.Run(); err != nil {
logger.Fatal(err)
}
}
See the examples for detailed information on usage.
Toolkit
See github.com/go-micro for tooling.
Changelog
See CHANGELOG.md for release history.
License
Go Micro is Apache 2.0 licensed.
Documentation
¶
Overview ¶
Package micro is a pluggable framework for microservices
Index ¶
- Variables
- func NewContext(ctx context.Context, s Service) context.Context
- func ProvideConfigFile(options *Options) (di.DiConfig, error)
- func ProvideFlags(_ *auth.DiFlags, _ *broker.DiFlags, _ *cache.DiFlags, _ *registry.DiFlags, ...) (di.DiFlags, error)
- func RegisterHandler(s server.Server, h interface{}, opts ...server.HandlerOption) error
- func RegisterSubscriber(topic string, s server.Server, h interface{}, opts ...server.SubscriberOption) error
- type CliArgs
- type Event
- type HookFunc
- type Option
- func Action(fn HookFunc) Option
- func AddListenOption(option server.Option) Option
- func Address(addr string) Option
- func AfterStart(fn HookFunc) Option
- func AfterStop(fn HookFunc) Option
- func ArgPrefix(n string) Option
- func Auth(a auth.Auth) Option
- func BeforeStart(fn HookFunc) Option
- func BeforeStop(fn HookFunc) Option
- func Broker(b broker.Broker) Option
- func Cache(c cache.Cache) Option
- func Client(c client.Client) Option
- func Config(c config.Config) Option
- func ConfigFile(n string) Option
- func Context(ctx context.Context) Option
- func Description(n string) Option
- func Flags(n []mCli.Flag) Option
- func HandleSignal(b bool) Option
- func Logger(l logger.Logger) Option
- func Metadata(md map[string]string) Option
- func Name(n string) Option
- func NoFlags() Option
- func Profile(p profile.Profile) Option
- func RegisterInterval(t time.Duration) Option
- func RegisterTTL(t time.Duration) Option
- func Registry(r registry.Registry) Option
- func Runtime(r runtime.Runtime) Option
- func Selector(s selector.Selector) Option
- func Server(s server.Server) Option
- func Store(s store.Store) Option
- func Tracer(t trace.Tracer) Option
- func Transport(t transport.Transport) Option
- func Usage(n string) Option
- func Version(v string) Option
- func WrapCall(w ...client.CallWrapper) Option
- func WrapClient(w ...client.Wrapper) Option
- func WrapHandler(w ...server.HandlerWrapper) Option
- func WrapSubscriber(w ...server.SubscriberWrapper) Option
- type Options
- type Publisher
- type Service
Constants ¶
This section is empty.
Variables ¶
var DiCliSet = wire.NewSet( cli.ProvideCli, cli.ProvideParsed, cli.ProvideConfig, )
var DiNoCliSet = wire.NewSet( configdi.ProvideConfigor, auth.DiNoCliSet, broker.DiNoCliSet, cache.DiNoCliSet, registry.DiNoCliSet, store.DiNoCliSet, transport.DiNoCliSet, )
var DiNoDiSet = wire.NewSet( ProvideFlags, ProvideAllService, )
var DiSet = wire.NewSet( configdi.ProvideConfigor, auth.DiSet, broker.DiSet, cache.DiSet, registry.DiSet, store.DiSet, transport.DiSet, )
DiSet is a set of all things components need, except the components themself.
Functions ¶
func NewContext ¶
NewContext returns a new Context with the Service embedded within it.
func ProvideConfigFile ¶ added in v5.0.1
func ProvideFlags ¶ added in v5.0.1
func RegisterHandler ¶
func RegisterHandler(s server.Server, h interface{}, opts ...server.HandlerOption) error
RegisterHandler is syntactic sugar for registering a handler.
func RegisterSubscriber ¶
func RegisterSubscriber(topic string, s server.Server, h interface{}, opts ...server.SubscriberOption) error
RegisterSubscriber is syntactic sugar for registering a subscriber.
Types ¶
type Event ¶
type Event interface { // Publish publishes a message to the event topic Publish(ctx context.Context, msg interface{}, opts ...client.PublishOption) error }
Event is used to publish messages to a topic.
type Option ¶
type Option func(*Options)
func BeforeStart ¶
BeforeStart run funcs before service starts.
func ConfigFile ¶ added in v5.0.1
ConfigFile is the config file to read in.
func Context ¶
Context specifies a context for the service. Can be used to signal shutdown of the service and for extra option values.
func Description ¶ added in v5.0.1
Description is the Description in cli usage.
func Flags ¶ added in v5.0.1
Flags is a list of additional flags to add you can parse them in Hooks.
func HandleSignal ¶
HandleSignal toggles automatic installation of the signal handler that traps TERM, INT, and QUIT. Users of this feature to disable the signal handler, should control liveness of the service through the context.
func NoFlags ¶ added in v5.0.1
func NoFlags() Option
NoFlags is a marker that no micro flags should be there.
func RegisterInterval ¶
RegisterInterval specifies the interval on which to re-register.
func RegisterTTL ¶
RegisterTTL specifies the TTL to use when registering the service.
func WrapCall ¶
func WrapCall(w ...client.CallWrapper) Option
WrapCall is a convenience method for wrapping a Client CallFunc.
func WrapClient ¶
WrapClient is a convenience method for wrapping a Client with some middleware component. A list of wrappers can be provided. Wrappers are applied in reverse order so the last is executed first.
func WrapHandler ¶
func WrapHandler(w ...server.HandlerWrapper) Option
WrapHandler adds a handler Wrapper to a list of options passed into the server.
func WrapSubscriber ¶
func WrapSubscriber(w ...server.SubscriberWrapper) Option
WrapSubscriber adds a subscriber Wrapper to a list of options passed into the server.
type Options ¶
type Options struct { ArgPrefix string Name string Description string Version string Usage string NoFlags bool ConfigFile string Flags []mCli.Flag // TODO: Remove me Auth auth.Auth Broker broker.Broker Cache cache.Cache Config config.Config Client client.Client Server server.Server Store store.Store Registry registry.Registry Runtime runtime.Runtime Transport transport.Transport Profile profile.Profile Logger logger.Logger // Before and After funcs Actions []HookFunc BeforeStart []HookFunc BeforeStop []HookFunc AfterStart []HookFunc AfterStop []HookFunc // Other options for implementations of the interface // can be stored in a context Context context.Context Signal bool }
Options for micro service.
func NewOptions ¶ added in v5.0.1
type Service ¶
type Service interface { // The service name Name() string // Init initializes options Init(...Option) // Options returns the current options Options() Options // Client is used to call services Client() client.Client // Server is for handling requests and events Server() server.Server // Run the service Run() error // The service implementation String() string }
Service is an interface that wraps the lower level libraries within go-micro. Its a convenience method for building and initializing services.
func FromContext ¶
FromContext retrieves a Service from the Context.
func NewMicroService ¶ added in v5.0.1
NewMicroService creates and returns a new Service based on the packages within.
func NewService ¶
Directories
¶
Path | Synopsis |
---|---|
Package api is for building api gateways
|
Package api is for building api gateways |
client
Package client provides an api client
|
Package client provides an api client |
handler
Package handler provides http handlers
|
Package handler provides http handlers |
handler/api
Package api provides an http-rpc handler which provides the entire http request over rpc
|
Package api provides an http-rpc handler which provides the entire http request over rpc |
handler/event
Package event provides a handler which publishes an event
|
Package event provides a handler which publishes an event |
handler/http
Package http is a http reverse proxy handler
|
Package http is a http reverse proxy handler |
handler/rpc
Package rpc is a go-micro rpc handler.
|
Package rpc is a go-micro rpc handler. |
handler/web
Package web contains the web handler including websocket support
|
Package web contains the web handler including websocket support |
resolver
Package resolver resolves a http request to an endpoint
|
Package resolver resolves a http request to an endpoint |
resolver/grpc
Package grpc resolves a grpc service like /greeter.Say/Hello to greeter service
|
Package grpc resolves a grpc service like /greeter.Say/Hello to greeter service |
resolver/host
Package host resolves using http host
|
Package host resolves using http host |
resolver/path
Package path resolves using http path
|
Package path resolves using http path |
resolver/vpath
Package vpath resolves using http path and recognized versioned urls
|
Package vpath resolves using http path and recognized versioned urls |
router
Package router provides api service routing
|
Package router provides api service routing |
router/registry
Package registry provides a dynamic api service router
|
Package registry provides a dynamic api service router |
server
Package server provides an API gateway server which handles inbound requests
|
Package server provides an API gateway server which handles inbound requests |
server/acme
Package acme abstracts away various ACME libraries
|
Package acme abstracts away various ACME libraries |
server/acme/autocert
Package autocert is the ACME provider from golang.org/x/crypto/acme/autocert This provider does not take any config.
|
Package autocert is the ACME provider from golang.org/x/crypto/acme/autocert This provider does not take any config. |
server/http
Package http provides a http server with features; acme, cors, etc
|
Package http provides a http server with features; acme, cors, etc |
Package auth provides authentication and authorization capability
|
Package auth provides authentication and authorization capability |
Package broker is an interface used for asynchronous messaging
|
Package broker is an interface used for asynchronous messaging |
Package client is an interface for an RPC client
|
Package client is an interface for an RPC client |
Package codec is an interface for encoding messages
|
Package codec is an interface for encoding messages |
bytes
Package bytes provides a bytes codec which does not encode or decode anything
|
Package bytes provides a bytes codec which does not encode or decode anything |
grpc
Package grpc provides a grpc codec
|
Package grpc provides a grpc codec |
json
Package json provides a json codec
|
Package json provides a json codec |
jsonrpc
Package jsonrpc provides a json-rpc 1.0 codec
|
Package jsonrpc provides a json-rpc 1.0 codec |
proto
Package proto provides a proto codec
|
Package proto provides a proto codec |
protorpc
Protorpc provides a net/rpc proto-rpc codec.
|
Protorpc provides a net/rpc proto-rpc codec. |
text
Package text reads any text/* content-type
|
Package text reads any text/* content-type |
Package config is an interface for dynamic configuration.
|
Package config is an interface for dynamic configuration. |
encoder
Package encoder handles source encoding formats
|
Package encoder handles source encoding formats |
loader
Package loader manages loading from multiple sources
|
Package loader manages loading from multiple sources |
reader
Package reader parses change sets and provides config values
|
Package reader parses change sets and provides config values |
secrets
Package secrets is an interface for encrypting and decrypting secrets
|
Package secrets is an interface for encrypting and decrypting secrets |
secrets/box
Package box is an asymmetric implementation of config/secrets using nacl/box
|
Package box is an asymmetric implementation of config/secrets using nacl/box |
secrets/secretbox
Package secretbox is a config/secrets implementation that uses nacl/secretbox to do symmetric encryption / verification
|
Package secretbox is a config/secrets implementation that uses nacl/secretbox to do symmetric encryption / verification |
source
Package source is the interface for sources
|
Package source is the interface for sources |
source/file
Package file is a file source.
|
Package file is a file source. |
source/memory
Package memory is a memory source
|
Package memory is a memory source |
debug
|
|
handler
Package handler implements service debug handler embedded in go-micro services
|
Package handler implements service debug handler embedded in go-micro services |
log
Package log provides debug logging
|
Package log provides debug logging |
log/memory
Package memory provides an in memory log buffer
|
Package memory provides an in memory log buffer |
profile
Package profile is for profilers
|
Package profile is for profilers |
profile/http
Package http enables the http profiler
|
Package http enables the http profiler |
profile/pprof
Package pprof provides a pprof profiler
|
Package pprof provides a pprof profiler |
stats
Package stats provides runtime stats
|
Package stats provides runtime stats |
trace
Package trace provides an interface for distributed tracing
|
Package trace provides an interface for distributed tracing |
Package errors provides a way to return detailed information for an RPC request error.
|
Package errors provides a way to return detailed information for an RPC request error. |
Package events is for event streaming and storage
|
Package events is for event streaming and storage |
Package log provides a log interface
|
Package log provides a log interface |
Package metadata is a way of defining message headers
|
Package metadata is a way of defining message headers |
Package mdns is a multicast dns registry
|
Package mdns is a multicast dns registry |
cache
Package cache provides a registry cache
|
Package cache provides a registry cache |
Package runtime is a service runtime manager
|
Package runtime is a service runtime manager |
kubernetes
Package kubernetes implements kubernetes micro runtime
|
Package kubernetes implements kubernetes micro runtime |
local
Package local provides a local runtime
|
Package local provides a local runtime |
local/build
Package build builds a micro runtime package
|
Package build builds a micro runtime package |
local/build/docker
Package docker builds docker images
|
Package docker builds docker images |
local/build/go
Package golang is a go package manager
|
Package golang is a go package manager |
local/process
Package process executes a binary
|
Package process executes a binary |
local/process/os
Package os runs processes locally
|
Package os runs processes locally |
local/source
Package source retrieves source code
|
Package source retrieves source code |
local/source/git
Package git provides a git source
|
Package git provides a git source |
local/source/go
Package golang is a source for Go
|
Package golang is a source for Go |
Package selector is a way to pick a list of service nodes
|
Package selector is a way to pick a list of service nodes |
Package server is an interface for a micro server
|
Package server is an interface for a micro server |
Package store is an interface for distributed data storage.
|
Package store is an interface for distributed data storage. |
Package sync is an interface for distributed synchronization
|
Package sync is an interface for distributed synchronization |
Package transport is an interface for synchronous connection based communication
|
Package transport is an interface for synchronous connection based communication |
util
|
|
backoff
Package backoff provides backoff functionality
|
Package backoff provides backoff functionality |
io
Package io is for io management
|
Package io is for io management |
jitter
Package jitter provides a random jitter
|
Package jitter provides a random jitter |
kubernetes/client
Package client provides an implementation of a restricted subset of kubernetes API client
|
Package client provides an implementation of a restricted subset of kubernetes API client |
pki
Package pki provides PKI all the PKI functions necessary to run micro over an untrusted network including a CA
|
Package pki provides PKI all the PKI functions necessary to run micro over an untrusted network including a CA |
pool
Package pool is a connection pool
|
Package pool is a connection pool |
qson
Package qson implmenets decoding of URL query params into JSON and Go values (using JSON struct tags).
|
Package qson implmenets decoding of URL query params into JSON and Go values (using JSON struct tags). |
ring
Package ring provides a simple ring buffer for storing local data
|
Package ring provides a simple ring buffer for storing local data |
socket
Package socket provides a pseudo socket
|
Package socket provides a pseudo socket |
stream
Package stream encapsulates streams within streams
|
Package stream encapsulates streams within streams |
sync
Package syncs will sync multiple stores
|
Package syncs will sync multiple stores |