micro

package module
v0.14.1 Latest Latest
Warning

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

Go to latest
Published: Nov 22, 2018 License: Apache-2.0 Imports: 16 Imported by: 0

README

Go Micro License GoDoc Travis CI Go Report Card

Go Micro is a pluggable framework for distributed systems development.

The micro philosophy is sane defaults with a pluggable architecture. We provide defaults to get you started quickly but everything can be swapped out. Plugins are available at github.com/micro/go-plugins.

Follow us on Twitter or join the Slack community.

Features

Go Micro abstracts away the details of distributed systems. Here are the main features.

  • Service Discovery - Automatic service registration and name resolution
  • Load Balancing - Client side load balancing built on discovery
  • Message Encoding - Dynamic encoding based on content-type with protobuf and json support
  • Sync Streaming - RPC based request/response with support for bidirectional streaming
  • Async Messaging - Native pubsub messaging built in for event driven architectures

Getting Started

See the docs for detailed information on the architecture, installation and use of go-micro.

Sponsors

Sixt is an Enterprise Sponsor of Micro

Become a sponsor by backing micro on Patreon

Documentation

Overview

Package micro is a pluggable RPC framework for microservices

Index

Constants

This section is empty.

Variables

View Source
var (
	HeaderPrefix = "X-Micro-"
)

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 Function

type Function interface {
	// Inherits Service interface
	Service
	// Done signals to complete execution
	Done() error
	// Handle registers an RPC handler
	Handle(v interface{}) error
	// Subscribe registers a subscriber
	Subscribe(topic string, v interface{}) error
}

Function is a one time executing Service

func NewFunction

func NewFunction(opts ...Option) Function

NewFunction returns a new Function for a one time executing Service

type Option

type Option func(*Options)

func Action

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

func AfterStart

func AfterStart(fn func() error) Option

func AfterStop

func AfterStop(fn func() error) Option

func BeforeStart

func BeforeStart(fn func() error) Option

func BeforeStop

func BeforeStop(fn func() error) Option

func Broker

func Broker(b broker.Broker) Option

func Client

func Client(c client.Client) Option

func Cmd

func Cmd(c cmd.Cmd) Option

func Context

func Context(ctx context.Context) Option

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

func Flags

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

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 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 Selector added in v0.3.0

func Selector(s selector.Selector) Option

Selector sets the selector for the service client

func Server

func Server(s server.Server) Option

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.

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 {
	Broker    broker.Broker
	Cmd       cmd.Cmd
	Client    client.Client
	Server    server.Server
	Registry  registry.Registry
	Transport transport.Transport

	// Register loop interval
	RegisterInterval time.Duration

	// Before and After funcs
	BeforeStart []func() error
	BeforeStop  []func() error
	AfterStart  []func() error
	AfterStop   []func() error

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

type Publisher

type Publisher interface {
	Publish(ctx context.Context, msg interface{}, opts ...client.PublishOption) error
}

Publisher is syntactic sugar for publishing

func NewPublisher

func NewPublisher(topic string, c client.Client) Publisher

NewPublisher returns a new Publisher

type Service

type Service interface {
	Init(...Option)
	Options() Options
	Client() client.Client
	Server() server.Server
	Run() error
	String() string
}

Service is an interface that wraps the lower level libraries within go-micro. Its a convenience method for building and initialising 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
acme module
certmagic Module
auth module
jwt Module
jwt/errors Module
jwt/server Module
jwt/token Module
Package broker is an interface used for asynchronous messaging
Package broker is an interface used for asynchronous messaging
http
Package http provides a http based message broker
Package http provides a http based message broker
gocloud Module
googlepubsub Module
grpc Module
grpc/proto Module
kafka Module
memory Module
mqtt Module
nats Module
nsq Module
proxy Module
rabbitmq Module
redis Module
redis/broker Module
segmentio Module
snssqs Module
sqs Module
stan Module
stomp Module
Package client is an interface for an RPC client
Package client is an interface for an RPC client
rpc
Package rpc provides an rpc client
Package rpc provides an rpc client
grpc Module
http Module
http/test Module
mucp Module
mucp/cmd Module
Package cmd is an interface for parsing the command line
Package cmd is an interface for parsing the command line
Package codec is an interface for encoding messages
Package codec is an interface for encoding messages
jsonrpc
Package jsonrpc provides a json-rpc 1.0 codec
Package jsonrpc provides a json-rpc 1.0 codec
protorpc
Package proto is a generated protocol buffer package.
Package proto is a generated protocol buffer package.
bsonrpc Module
json-iterator Module
jsonrpc2 Module
msgpackrpc Module
segmentio Module
config module
broker/memory Module
client/mock Module
encoder Module
encoder/cue Module
encoder/hcl Module
encoder/toml Module
encoder/xml Module
encoder/yaml Module
source Module
source/consul Module
source/etcd Module
source/grpc Module
source/mucp Module
source/nacos Module
source/pkger Module
source/url Module
source/vault 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.
events module
nats Module
redis Module
logger module
apex Module
broker/memory Module
logrus Module
zap Module
zerolog Module
zerolog/cmd Module
zerolog/codec Module
Package metadata is a way of defining message headers
Package metadata is a way of defining message headers
proxy module
http Module
Package registry is an interface for service discovery
Package registry is an interface for service discovery
cache Module
etcd Module
eureka Module
eureka/mock Module
gossip Module
gossip/proto Module
kubernetes Module
memory Module
multi Module
nacos Module
nats Module
proxy Module
zookeeper Module
Package selector is a way to load balance service nodes
Package selector is a way to load balance service nodes
cache
Package cache is a caching selector.
Package cache is a caching selector.
dns Module
label Module
registry Module
shard Module
static Module
Package server is an interface for a micro server
Package server is an interface for a micro server
debug/proto
Package debug is a generated protocol buffer package.
Package debug is a generated protocol buffer package.
rpc
Package rpc provides an rpc server
Package rpc provides an rpc server
grpc Module
grpc/proto Module
grpc/registry Module
http Module
http/errors Module
mucp Module
store module
client Module
client/mock Module
client/rpc Module
cockroach Module
consul Module
file Module
memcached Module
memory Module
mysql Module
mysql/broker Module
mysql/client Module
mysql/cmd Module
mysql/codec Module
mysql/errors Module
mysql/server Module
redis Module
selector Module
sync module
consul Module
etcd Module
memory Module
Package transport is an interface for synchronous communication
Package transport is an interface for synchronous communication
http
Package http returns a http2 transport using net/http
Package http returns a http2 transport using net/http
grpc Module
grpc/proto Module
memory Module
nats Module
quic Module
rabbitmq Module
tcp Module
utp Module
wrapper module
breaker Module
breaker/codec Module
endpoint Module
metadata Module
monitoring Module
ratelimiter Module
select Module
select/shard Module
service Module
trace Module
trace/awsxray Module
trace/datadog Module
validator Module

Jump to

Keyboard shortcuts

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