micro

package module
v4.10.2 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Apr 26, 2023 License: Apache-2.0 Imports: 23 Imported by: 409

README

Go Micro License Go.Dev reference Go Report Card Discord

Go Micro is a framework for distributed systems development.

Note: V5 is in development. Leave feedback in this form

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 import it

import "go-micro.dev/v4

Define a handler (protobuf is optionally supported - see example)

type Request struct {
        Name string `json:"name"`
}

type Response struct {
        Message string `json:"message"`
}

type Helloworld struct{}

func (h *Helloworld) Greeting(ctx context.Context, req *Request, rsp *Response) error {
        rsp.Message = "Hello " + req.Name
        return nil
}

Create, initialise and run the service

// create a new service
service := micro.NewService(
    micro.Name("helloworld"),
    micro.Handle(new(Helloworld)),
)

// initialise flags
service.Init()

// start the service
service.Run()

Optionally set fixed address

service := micro.NewService(
    // set address
    micro.Handle(":8080"),
)

Call it via curl

curl -XPOST \
     -H 'Content-Type: application/json' \
     -H 'Micro-Endpoint: Helloworld.Greeting' \
     -d '{"name": "alice"}' \
      http://localhost:8080

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

Constants

This section is empty.

Variables

This section is empty.

Functions

func NewContext

func NewContext(ctx context.Context, s Service) context.Context

NewContext returns a new Context with the Service embedded within it.

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.

func NewEvent

func NewEvent(topic string, c client.Client) Event

NewEvent creates a new event publisher.

type Option

type Option func(*Options)

func Action

func Action(a func(*cli.Context) error) Option

Action can be used to parse user provided cli options.

func AddListenOption added in v4.8.1

func AddListenOption(option server.Option) Option

Add opt to server option.

func Address

func Address(addr string) Option

Address sets the address of the server.

func AfterStart

func AfterStart(fn func() error) Option

AfterStart run funcs after service starts.

func AfterStop

func AfterStop(fn func() error) Option

AfterStop run funcs after service stops.

func Auth

func Auth(a auth.Auth) Option

Auth sets the auth for the service.

func BeforeStart

func BeforeStart(fn func() error) Option

BeforeStart run funcs before service starts.

func BeforeStop

func BeforeStop(fn func() error) Option

BeforeStop run funcs before service stops.

func Broker

func Broker(b broker.Broker) Option

Broker to be used for service.

func Cache

func Cache(c cache.Cache) Option

func Client

func Client(c client.Client) Option

Client to be used for service.

func Cmd

func Cmd(c cmd.Cmd) Option

func Config

func Config(c config.Config) Option

Config sets the config for the service.

func Context

func Context(ctx context.Context) Option

Context specifies a context for the service. Can be used to signal shutdown of the service and for extra option values.

func Flags

func Flags(flags ...cli.Flag) Option

Flags that can be passed to service.

func Handle added in v4.10.1

func Handle(v interface{}) Option

Handle will register a handler without any fuss

func HandleSignal

func HandleSignal(b bool) Option

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 Logger added in v4.9.0

func Logger(l logger.Logger) Option

Logger sets the logger for the service.

func Metadata

func Metadata(md map[string]string) Option

Metadata associated with the service.

func Name

func Name(n string) Option

Name of the service.

func Profile

func Profile(p profile.Profile) Option

Profile to be used for debug profile.

func RegisterInterval

func RegisterInterval(t time.Duration) Option

RegisterInterval specifies the interval on which to re-register.

func RegisterTTL

func RegisterTTL(t time.Duration) Option

RegisterTTL specifies the TTL to use when registering the service.

func Registry

func Registry(r registry.Registry) Option

Registry sets the registry for the service and the underlying components.

func Runtime

func Runtime(r runtime.Runtime) Option

Runtime sets the runtime.

func Selector

func Selector(s selector.Selector) Option

Selector sets the selector for the service client.

func Server

func Server(s server.Server) Option

Server to be used for service.

func Store

func Store(s store.Store) Option

Store sets the store to use.

func Tracer

func Tracer(t trace.Tracer) Option

Tracer sets the tracer for the service.

func Transport

func Transport(t transport.Transport) Option

Transport sets the transport for the service and the underlying components.

func Version

func Version(v string) Option

Version of the service.

func WrapCall

func WrapCall(w ...client.CallWrapper) Option

WrapCall is a convenience method for wrapping a Client CallFunc.

func WrapClient

func WrapClient(w ...client.Wrapper) Option

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 {
	Registry registry.Registry
	Store    store.Store
	Auth     auth.Auth
	Cmd      cmd.Cmd
	Config   config.Config
	Client   client.Client
	Server   server.Server

	// Other options for implementations of the interface
	// can be stored in a context
	Context context.Context

	Cache     cache.Cache
	Runtime   runtime.Runtime
	Profile   profile.Profile
	Transport transport.Transport
	Logger    logger.Logger
	Broker    broker.Broker
	// Before and After funcs
	BeforeStart []func() error
	AfterStart  []func() error
	AfterStop   []func() error

	BeforeStop []func() error

	Signal bool
}

Options for micro service.

type Publisher

type Publisher = Event

Type alias to satisfy the deprecation.

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

func FromContext(ctx context.Context) (Service, bool)

FromContext retrieves a Service from the Context.

func NewService

func NewService(opts ...Option) Service

NewService creates and returns a new Service based on the packages within.

Directories

Path Synopsis
Config module
a module
address module
agent module
command Module
input Module
input/discord Module
input/slack Module
proto Module
answer module
api module
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
cmd Module
cmd/api Module
handler/cmd Module
handler/cors Module
handler/grpc Module
internal Module
metadata Module
proto/api Module
proto/cmd Module
proto/go_api Module
registry Module
resolver/cmd Module
resolver/http Module
router/cmd Module
router/grpc Module
router/http Module
service Module
third_party Module
util Module
util/log Module
web Module
apm module
app module
auth module
api Module
api/handler Module
api/internal Module
api/proto Module
api/resolver Module
api/router Module
api/server Module
broker Module
cache Module
client Module
cmd Module
cmd/dashboard Module
cmd/micro Module
cmd/micro/cli Module
codec Module
codec/bytes Module
codec/grpc Module
codec/json Module
codec/jsonrpc Module
codec/proto Module
codec/text Module
config Module
config/loader Module
config/reader Module
config/source Module
debug Module
debug/handler Module
debug/log Module
debug/profile Module
debug/proto Module
debug/stats Module
debug/trace Module
errors Module
events Module
examples Module
examples/http Module
jwt Module
jwt/token Module
logger Module
metadata Module
plugins Module
plugins/acme Module
plugins/auth Module
plugins/codec Module
plugins/proxy Module
plugins/store Module
plugins/sync Module
provider Module
registry Module
runtime Module
runtime/local Module
selector Module
server Module
server/mock Module
server/proto Module
service Module
service/proto Module
services Module
services/db Module
services/file Module
services/gifs Module
services/id Module
services/ip Module
services/otp Module
services/qr Module
services/rss Module
services/sms Module
services/time Module
services/url Module
services/user Module
store Module
sync Module
token Module
token/basic Module
token/jwt Module
transport Module
util Module
util/addr Module
util/backoff Module
util/buf Module
util/ctx Module
util/file Module
util/grpc Module
util/http Module
util/io Module
util/jitter Module
util/log Module
util/mdns Module
util/net Module
util/pki Module
util/pool Module
util/qson Module
util/registry Module
util/ring Module
util/signal Module
util/socket Module
util/stream Module
util/sync Module
util/test Module
util/tls Module
util/wrapper Module
web Module
avatar module
borker module
broke module
broker module
api Module
api/handler Module
api/internal Module
api/proto Module
api/resolver Module
api/router Module
api/server Module
auth Module
broker/sqs Module
cache Module
client Module
cmd Module
cmd/dashboard Module
cmd/micro Module
cmd/micro/cli Module
codec Module
codec/bytes Module
codec/grpc Module
codec/json Module
codec/jsonrpc Module
codec/noop Module
codec/proto Module
codec/text Module
config Module
config/loader Module
config/reader Module
config/source Module
debug Module
debug/handler Module
debug/log Module
debug/profile Module
debug/proto Module
debug/stats Module
debug/trace Module
errors Module
events Module
examples Module
examples/http Module
grpc Module
http Module
kafka Module
logger Module
memory Module
metadata Module
mqtt Module
nats Module
noop Module
nsq Module
plugins Module
plugins/acme Module
plugins/auth Module
plugins/codec Module
plugins/proxy Module
plugins/store Module
plugins/sync Module
rabbitmq Module
rebbit Module
redis Module
registry Module
runtime Module
runtime/local Module
selector Module
server Module
server/mock Module
server/proto Module
service Module
service/proto Module
services Module
services/db Module
services/file Module
services/gifs Module
services/id Module
services/ip Module
services/otp Module
services/qr Module
services/rss Module
services/sms Module
services/time Module
services/url Module
services/user Module
stan Module
store Module
stream Module
stream/redis Module
sync Module
transport Module
util Module
util/addr Module
util/backoff Module
util/buf Module
util/ctx Module
util/file Module
util/grpc Module
util/http Module
util/io Module
util/jitter Module
util/log Module
util/mdns Module
util/net Module
util/pki Module
util/pool Module
util/qson Module
util/registry Module
util/ring Module
util/signal Module
util/socket Module
util/stream Module
util/sync Module
util/test Module
util/tls Module
util/wrapper Module
web Module
cmd Module
redis Module
cli module
cmd Module
micro Module
micro/debug Module
clien module
client module
api Module
api/handler Module
api/internal Module
api/proto Module
api/resolver Module
api/router Module
api/server Module
auth Module
broker Module
cache Module
cmd Module
cmd/dashboard Module
cmd/micro Module
cmd/micro/cli Module
codec Module
codec/bytes Module
codec/grpc Module
codec/json Module
codec/jsonrpc Module
codec/proto Module
codec/text Module
config Module
config/loader Module
config/reader Module
config/source Module
debug Module
debug/handler Module
debug/log Module
debug/profile Module
debug/proto Module
debug/stats Module
debug/trace Module
errors Module
events Module
examples Module
examples/http Module
grpc Module
http Module
logger Module
metadata Module
mock Module
mucp Module
options Module
plugins Module
plugins/acme Module
plugins/auth Module
plugins/codec Module
plugins/proxy Module
plugins/store Module
plugins/sync Module
pool Module
registry Module
rpc Module
runtime Module
runtime/local Module
selector Module
server Module
server/mock Module
server/proto Module
services Module
services/db Module
services/file Module
services/gifs Module
services/id Module
services/ip Module
services/otp Module
services/qr Module
services/rss Module
services/sms Module
services/time Module
services/url Module
services/user Module
store Module
sync Module
transport Module
util Module
util/addr Module
util/backoff Module
util/buf Module
util/ctx Module
util/file Module
util/grpc Module
util/http Module
util/io Module
util/jitter Module
util/log Module
util/mdns Module
util/net Module
util/pki Module
util/pool Module
util/qson Module
util/registry Module
util/ring Module
util/signal Module
util/socket Module
util/stream Module
util/sync Module
util/test Module
util/tls Module
util/wrapper Module
web Module
cligent module
cm module
cmd module
api Module
api/handler Module
api/internal Module
api/proto Module
api/resolver Module
api/router Module
api/server Module
auth Module
broker Module
broker/memory Module
cache Module
client Module
cmd/dashboard Module
cmd/micro Module
cmd/micro/cli Module
codec Module
codec/bytes Module
codec/grpc Module
codec/json Module
codec/jsonrpc Module
codec/proto Module
codec/text Module
config Module
config/loader Module
config/reader Module
config/source Module
dashboard Module
debug Module
debug/handler Module
debug/log Module
debug/profile Module
debug/proto Module
debug/stats Module
debug/trace Module
errors Module
events Module
examples Module
examples/http Module
go-micro Module
goctl Module
gomu Module
grpc Module
logger Module
macro Module
metadata Module
micro Module
micro/cli Module
micro/cli/cmd Module
micro/cli/new Module
micro/cli/run Module
micro/cmd Module
micro/debug Module
micro/micro Module
plugins Module
plugins/acme Module
plugins/auth Module
plugins/codec Module
plugins/proxy Module
plugins/store Module
plugins/sync Module
protoc Module
protoc- Module
protoc-gen-go Module
registry Module
registry/mdns Module
runtime Module
runtime/local Module
selector Module
server Module
server/http Module
server/mock Module
server/proto Module
services Module
services/db Module
services/file Module
services/gifs Module
services/id Module
services/ip Module
services/otp Module
services/qr Module
services/rss Module
services/sms Module
services/time Module
services/url Module
services/user Module
store Module
sync Module
transport Module
util Module
util/addr Module
util/backoff Module
util/buf Module
util/ctx Module
util/file Module
util/grpc Module
util/http Module
util/io Module
util/jitter Module
util/log Module
util/mdns Module
util/net Module
util/pki Module
util/pool Module
util/qson Module
util/registry Module
util/ring Module
util/signal Module
util/socket Module
util/stream Module
util/sync Module
util/test Module
util/tls Module
util/wrapper Module
web Module
cmdmicro module
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
bytes/cmd Module
client Module
cmd Module
grpc/cmd Module
json/cmd Module
jsonrpc/cmd Module
jsonrpc2 Module
proto/cmd Module
protobuf Module
protorpc/cmd Module
thrift Module
yaml Module
com module
micro Module
confi module
registry Module
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
cmd Module
encoder/cmd Module
encoder/toml Module
encoder/yaml Module
env Module
file Module
greader Module
greader/json Module
loader/cmd Module
reader/cmd Module
reader/env Module
reader/toml Module
reader/yaml Module
secrets/cmd Module
souce Module
souce/consul Module
source/cmd Module
source/consul Module
source/envvar Module
source/etcd Module
source/grpc Module
source/nacos Module
source/reader Module
source/toml Module
source/url Module
source/yaml Module
yaml Module
connect module
consul module
contact module
cors module
crypto module
currency module
db module
registry Module
debug module
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
handler/api Module
handler/cmd Module
log/cmd Module
logger Module
profile/cmd Module
proto/cmd Module
service Module
service/proto Module
stats/cmd Module
trace/cmd Module
trace/jaeger Module
discovery module
egistry module
email module
emoji module
env module
error module
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.
cmd Module
etcd module
evchargers module
event module
natsjs Module
Package events is for event streaming and storage
Package events is for event streaming and storage
nats Module
redis Module
example module
examples module
cache Module
cache/proto Module
filter Module
greeter Module
greeter/srv Module
helloworld Module
server Module
server/proto Module
service Module
service/proto Module
services Module
wang2_etcd Module
file module
forex module
function module
generator module
cmd Module
geocoding module
gifs module
github.com module
micro Module
go-config module
source Module
source/consul Module
source/etcd Module
go-grpc module
go-log module
go-micro module
broker Module
client Module
client/broker Module
config Module
plugins Module
server Module
go-micro.dev module
v4/broker Module
go-plugins module
broker Module
broker/nats Module
client Module
config Module
config/source Module
etcd Module
logger Module
logger/logrus Module
registry Module
registry/etcd Module
transport Module
wrapper Module
go-web module
google module
grpc module
client Module
grpc-go module
handler module
http Module
rpc Module
helloworld module
proto Module
holidays module
http module
broker Module
broker/memory Module
id module
ient module
selector Module
image module
ip module
joke module
json module
kubernetes module
api Module
log module
logger module
cmd Module
github.com Module
log Module
logrus Module
plugin Module
plugin/server Module
plugins Module
registry Module
slog Module
zap Module
loggger module
logrus module
me module
medata module
Package metadata is a way of defining message headers
Package metadata is a way of defining message headers
cmd Module
metrics module
micro module
config Module
go-micro Module
go-plugins Module
misc module
lib Module
lib/addr Module
network module
resolver Module
resolver/dns Module
resolver/http Module
service Module
service/proto Module
odec module
opentracing module
options module
plugin module
client Module
client/grpc Module
etcd Module
events Module
events/nats Module
grpc Module
grpc/server Module
http Module
rabbitmq Module
registry Module
registry/etcd Module
server Module
server/grcp Module
tracer Module
tracer/jaeger Module
transport Module
v4/config Module
v4/web Module
plugins module
auth Module
auth/jwt Module
blob Module
blob/main Module
broker Module
broker/grpc Module
broker/kafka Module
broker/memory Module
broker/mqtt Module
broker/nats Module
broker/nsq Module
broker/redis Module
broker/sqs Module
broker/stan Module
client Module
client/grpc Module
client/http Module
client/mock Module
client/rpc Module
cmd Module
codec Module
config Module
config/etcd Module
config/nacos Module
config/source Module
consul Module
consul/client Module
edct Module
etcd Module
etcdv3 Module
grpc Module
http Module
logger Module
logger/logrus Module
logger/zap Module
loggers Module
loggers/zap Module
logging Module
nacos Module
proxy Module
proxy/http Module
rabbitmq Module
register Module
register/etcd Module
registery Module
registry Module
registry.etcd Module
registry/etcd Module
registry/mdns Module
registry/nats Module
selector Module
server Module
server/grpc Module
server/http Module
server/rpc Module
store Module
store/redis Module
sync Module
sync/etcd Module
sync/memory Module
transport Module
transport/tcp Module
tree Module
tree/main Module
v4/broker Module
v4/broker/nsq Module
v4/client Module
v4/config Module
v4/consul Module
v4/http Module
v4/logger Module
v4/registry Module
v4/server Module
v4/sync Module
v4/sync/etcd Module
v4/wrapper Module
wrapper Module
wrapper/trace Module
prometheus module
proto module
alert Module
hello Module
registry Module
protobuf module
proto Module
protoc-gen-go Module
proxy module
grpc Module
http Module
mucp Module
pubsub module
proto Module
rabbitmq module
ransport module
regiscdtry module
register module
registery module
etcd Module
registr module
etcd Module
registry module
cache
Package cache provides a registry cache
Package cache provides a registry cache
Options Module
broker Module
cmd Module
consul Module
etcd Module
etcd/registry Module
etcd/v4/web Module
etcdd Module
etcdv3 Module
eureka Module
kubernetes Module
mdns Module
memory Module
mock Module
nacos Module
nats Module
options Module
plugins Module
registry/etcd Module
selector Module
service Module
service/proto Module
static Module
v4/registry Module
regstry module
roker module
router module
service Module
service/proto Module
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
cmd Module
local/git/cmd Module
service Module
service/proto Module
Package selector is a way to pick a list of service nodes
Package selector is a way to pick a list of service nodes
cache Module
cmd Module
random Module
registry Module
roundrobin Module
shard Module
static Module
serve module
service Module
server module
api Module
cmd Module
debug Module
debug/proto Module
grp Module
grpc Module
grpc/client Module
handler Module
headers Module
http Module
logger Module
metadata Module
metrics Module
mucp Module
plugins Module
registry Module
registry/mdns Module
web Module
serverr module
servic module
service module
api Module
auth Module
client Module
config Module
context Module
debug Module
debug/handler Module
debug/trace Module
errors Module
events Module
grpc Module
logger Module
metrics Module
network Module
proxy Module
registry Module
registry/mdns Module
registry/util Module
router Module
server Module
server/mucp Module
store Module
store/memory Module
web Module
services module
address Module
answer Module
app Module
assignment Module
avatar Module
bucket Module
bucket/pkg Module
bucket/proto Module
bucket/utils Module
cache Module
carbon Module
contact Module
crypto Module
currency Module
db Module
email Module
emoji Module
evchargers Module
event Module
file Module
forex Module
function Module
gateway Module
gateway/proto Module
geocoding Module
gifs Module
google Module
greeter Module
greeter/proto Module
helloworld Module
holidays Module
id Module
image Module
ip Module
joke Module
location Module
minecraft Module
movie Module
mq Module
news Module
nft Module
notes Module
otp Module
ping Module
place Module
postcode Module
prayer Module
qr Module
quran Module
routing Module
rss Module
search Module
sentiment Module
sms Module
space Module
spam Module
stock Module
stream Module
sunnah Module
thumbnail Module
time Module
todo Module
todo/broker Module
todo/database Module
todo/handler Module
todo/pkg Module
todo/proto Module
todo/utils Module
translate Module
twitter Module
uploader Module
uploadfile Module
url Module
user Module
user/proto Module
user/utils Module
vehicle Module
weather Module
youtube Module
sever module
grpc Module
some module
thin Module
source module
env Module
file Module
memory Module
storage module
Package store is an interface for distributed data storage.
Package store is an interface for distributed data storage.
cmd Module
cockroach Module
etcd Module
file Module
memory Module
mocks Module
mysql Module
service Module
service/proto Module
util Module
util/log Module
stream module
sync module
cmd Module
etcd Module
memory Module
Package tests implements a testing framwork, and provides default tests.
Package tests implements a testing framwork, and provides default tests.
trace module
opentracing Module
Package transport is an interface for synchronous connection based communication
Package transport is an interface for synchronous connection based communication
headers
headers is a package for internal micro global constants
headers is a package for internal micro global constants
cmd Module
codec Module
etcd Module
grpc Module
http Module
mqtt Module
nats Module
quic Module
tcp Module
tunnel module
transport Module
util module
addr
addr provides functions to retrieve local IP addresses from device interfaces.
addr provides functions to retrieve local IP addresses from device interfaces.
backoff
Package backoff provides backoff functionality
Package backoff provides backoff functionality
buf
cmd
Package cmd is an interface for parsing the command line
Package cmd is an interface for parsing the command line
ctx
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
net
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
tls
acme Module
addr/cmd Module
auth Module
auth/token Module
backoff/cmd Module
broker Module
buf/buf Module
buf/cmd Module
cache Module
codec Module
codec/bytes Module
codec/grpc Module
codec/json Module
codec/jsonrpc Module
codec/proto Module
codec/text Module
ctx/cmd Module
etcdv3 Module
go Module
go/lib Module
go/lib/addr Module
go/lib/grpc Module
grpc/cmd Module
handle Module
helper Module
http/cmd Module
json Module
kubernetes Module
lo Module
log Module
log/cmd Module
log/registry Module
log/web Module
logger Module
loggger Module
loggo Module
mdns/cmd Module
metadata Module
mux Module
net/cmd Module
opentelemetry Module
pool/cmd Module
qson/cmd Module
queue Module
registry/cmd Module
ring/cmd Module
selector Module
signal/cmd Module
socket/cmd Module
tls/cmd Module
user Module
wrapper/cmd Module
wrapper/trace Module
utils module
broker Module
cmd Module
log Module
v module
v2
api Module
broker Module
client Module
config Module
registry Module
server Module
server/grpc Module
util Module
util/cmd Module
web Module
v4
cmd Module
cmd/client Module
cmd/server Module
cmd/web Module
plugin Module
plugins Module
plugins/proxy Module
server Module
server/grpc Module
vgo-plugins module
registry Module
vmd module
micro Module
web
Package web provides web based micro services
Package web provides web based micro services
config Module
config/source Module
hand Module
plugins Module
registry Module
wrapper module
monitoring Module
ratelimiter Module
service Module
trace Module

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL