 Documentation
      ¶
      Documentation
      ¶
    
    
  
    
  
    Overview ¶
Package micro is a pluggable RPC framework for microservices
Index ¶
- Variables
- func NewContext(ctx context.Context, s Service) context.Context
- 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 Function
- type Option
- func Action(a func(*cli.Context)) Option
- func AfterStart(fn func() error) Option
- func AfterStop(fn func() error) Option
- func BeforeStart(fn func() error) Option
- func BeforeStop(fn func() error) Option
- func Broker(b broker.Broker) Option
- func Client(c client.Client) Option
- func Cmd(c cmd.Cmd) Option
- func Context(ctx context.Context) Option
- func Flags(flags ...cli.Flag) Option
- func Metadata(md map[string]string) Option
- func Name(n string) Option
- func RegisterInterval(t time.Duration) Option
- func RegisterTTL(t time.Duration) Option
- func Registry(r registry.Registry) Option
- func Selector(s selector.Selector) Option
- func Server(s server.Server) Option
- func Transport(t transport.Transport) 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 (
	HeaderPrefix = "X-Micro-"
)
    Functions ¶
func NewContext ¶
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 ¶
NewFunction returns a new Function for a one time executing Service
type Option ¶
type Option func(*Options)
func AfterStart ¶
func BeforeStart ¶
func BeforeStop ¶
func Context ¶
Context specifies a context for the service. Can be used to signal shutdown of the service. Can be used for extra option values.
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 {
	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
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 ¶
FromContext retrieves a Service from the Context.
func NewService ¶
NewService creates and returns a new Service based on the packages within.
       Source Files
      ¶
      Source Files
      ¶
    
  
       Directories
      ¶
      Directories
      ¶
    
    | Path | Synopsis | 
|---|---|
| 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 | 
| 
          
            mock
            
            
          
           Package mock provides a mock broker for testing | Package mock provides a mock broker for testing | 
| Package client is an interface for an RPC client | Package client is an interface for an RPC client | 
| 
          
            mock
            
            
          
           Package mock provides a mock client for testing | Package mock provides a mock client for testing | 
| 
          
            rpc
            
            
          
           Package rpc provides an rpc client | Package rpc provides an rpc client | 
| 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 | 
| 
          
            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
            
            
          
           Package proto is a generated protocol buffer package. | Package proto is a generated protocol buffer package. | 
| 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. | 
| go-micro
            module
           | |
| 
          
            broker
            module
            
          
          
         | |
| 
          
            codec/json
            module
            
          
          
         | |
| 
          
            codec/jsonrpc
            module
            
          
          
         | |
| 
          
            logger
            module
            
          
          
         | |
| Package metadata is a way of defining message headers | Package metadata is a way of defining message headers | 
| Package registry is an interface for service discovery | Package registry is an interface for service discovery | 
| 
          
            consul
            
            
          
           Package consul provides a consul based registry and is the default discovery system | Package consul provides a consul based registry and is the default discovery system | 
| 
          
            gossip
            
            
          
           Package Gossip provides a gossip registry based on hashicorp/memberlist | Package Gossip provides a gossip registry based on hashicorp/memberlist | 
| 
          
            gossip/proto
            
            
          
           Package gossip is a generated protocol buffer package. | Package gossip is a generated protocol buffer package. | 
| 
          
            mdns
            
            
          
           Package mdns is a multicast dns registry | Package mdns is a multicast dns registry | 
| 
          
            mock
            
            
          
           Package mock provides a mock registry for testing | Package mock provides a mock registry for testing | 
| Package selector is a way to pick a list of service nodes | Package selector is a way to pick a list of service nodes | 
| 
          
            dns
            
            
          
           Package dns provides a dns SRV selector | Package dns provides a dns SRV selector | 
| 
          
            registry
            
            
          
           Package registry uses the go-micro registry for selection | Package registry uses the go-micro registry for selection | 
| 
          
            static
            
            
          
           Package static provides a static resolver which returns the name/ip passed in without any change | Package static provides a static resolver which returns the name/ip passed in without any change | 
| 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 | 
| 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 | 
 
