Documentation ¶
Index ¶
- Constants
- Variables
- func Auth(fn AuthorizationFunc) error
- func Close() error
- func GetListenedAddress() string
- func NewCompressConn(conn net.Conn, compressType CompressType) net.Conn
- func NewDirectHTTPRPCClient(c *Client, clientCodecFunc ClientCodecFunc, network, address string, ...) (*core.Client, error)
- func NewDirectKCPRPCClient(c *Client, clientCodecFunc ClientCodecFunc, network, address string, ...) (*core.Client, error)
- func NewDirectQuicRPCClient(c *Client, clientCodecFunc ClientCodecFunc, network, address string, ...) (*core.Client, error)
- func NewDirectRPCClient(c *Client, clientCodecFunc ClientCodecFunc, network, address string, ...) (*core.Client, error)
- func RegisterName(name string, service interface{}, metadata ...string)
- func Serve(n, address string) (err error)
- func ServeByHTTP(ln net.Listener)
- func ServeByMux(ln net.Listener, mux *http.ServeMux)
- func ServeListener(ln net.Listener)
- func ServeTLS(n, address string, config *tls.Config) (err error)
- func SetServerCodecFunc(fn ServerCodecFunc)
- func Start(n, address string) (err error)
- func StartTLS(n, address string, config *tls.Config) (err error)
- type ArgsContext
- type AuthorizationAndServiceMethod
- type AuthorizationClientPlugin
- type AuthorizationFunc
- type AuthorizationServerPlugin
- type Client
- func (c *Client) Auth(authorization, tag string) error
- func (c *Client) Call(ctx context.Context, serviceMethod string, args interface{}, reply interface{}) (err error)
- func (c *Client) Close() error
- func (c *Client) Go(ctx context.Context, serviceMethod string, args interface{}, reply interface{}, ...) *core.Call
- type ClientCodecFunc
- type ClientCodecWrapper
- type ClientPluginContainer
- func (p *ClientPluginContainer) Add(plugin IPlugin) error
- func (p *ClientPluginContainer) DoPostCall(ctx context.Context, serviceMethod string, args interface{}, reply interface{}) error
- func (p *ClientPluginContainer) DoPostConnected(conn net.Conn) (net.Conn, bool)
- func (p *ClientPluginContainer) DoPostReadResponseBody(body interface{}) error
- func (p *ClientPluginContainer) DoPostReadResponseHeader(r *core.Response) error
- func (p *ClientPluginContainer) DoPostWriteRequest(ctx context.Context, r *core.Request, body interface{}) error
- func (p *ClientPluginContainer) DoPreCall(ctx context.Context, serviceMethod string, args interface{}, reply interface{}) error
- func (p *ClientPluginContainer) DoPreReadResponseBody(body interface{}) error
- func (p *ClientPluginContainer) DoPreReadResponseHeader(r *core.Response) error
- func (p *ClientPluginContainer) DoPreWriteRequest(ctx context.Context, r *core.Request, body interface{}) error
- func (p *ClientPluginContainer) GetAll() []IPlugin
- func (p *ClientPluginContainer) GetByName(pluginName string) IPlugin
- func (p *ClientPluginContainer) GetName(plugin IPlugin) string
- func (p *ClientPluginContainer) Remove(pluginName string) error
- type ClientSelector
- type CompressConn
- type CompressType
- type DirectClientSelector
- func (s *DirectClientSelector) AllClients(clientCodecFunc ClientCodecFunc) []*core.Client
- func (s *DirectClientSelector) HandleFailedClient(client *core.Client)
- func (s *DirectClientSelector) Select(clientCodecFunc ClientCodecFunc, options ...interface{}) (*core.Client, error)
- func (s *DirectClientSelector) SetClient(c *Client)
- func (s *DirectClientSelector) SetSelectMode(sm SelectMode)
- type FailMode
- type IClientPluginContainer
- type IPlugin
- type IPostCallPlugin
- type IPostConnAcceptPlugin
- type IPostConnectedPlugin
- type IPostReadRequestBodyPlugin
- type IPostReadRequestHeaderPlugin
- type IPostReadResponseBodyPlugin
- type IPostReadResponseHeaderPlugin
- type IPostWriteRequestPlugin
- type IPostWriteResponsePlugin
- type IPreCallPlugin
- type IPreReadRequestBodyPlugin
- type IPreReadRequestHeaderPlugin
- type IPreReadResponseBodyPlugin
- type IPreReadResponseHeaderPlugin
- type IPreWriteRequestPlugin
- type IPreWriteResponsePlugin
- type IRegisterPlugin
- type IServerCodecPlugin
- type IServerPluginContainer
- type KCPConfig
- type MultiError
- type QUICConfig
- type RPCError
- type ReconnectFunc
- type SelectMode
- type Server
- func (s *Server) Address() string
- func (s *Server) Auth(fn AuthorizationFunc) error
- func (s *Server) Close() error
- func (s *Server) RegisterName(name string, service interface{}, metadata ...string)
- func (s *Server) Serve(network, address string) (err error)
- func (s *Server) ServeByHTTP(ln net.Listener, rpcPath string)
- func (s *Server) ServeByMux(ln net.Listener, rpcPath string, mux *http.ServeMux)
- func (s *Server) ServeHTTP(w http.ResponseWriter, req *http.Request)
- func (s *Server) ServeListener(ln net.Listener)
- func (s *Server) ServeTLS(network, address string, config *tls.Config) (err error)
- func (s *Server) Start(network, address string) (err error)
- func (s *Server) StartTLS(network, address string, config *tls.Config) (err error)
- type ServerCodecFunc
- type ServerPluginContainer
- func (p *ServerPluginContainer) Add(plugin IPlugin) error
- func (p *ServerPluginContainer) DoPostConnAccept(conn net.Conn) (net.Conn, bool)
- func (p *ServerPluginContainer) DoPostReadRequestBody(ctx context.Context, body interface{}) error
- func (p *ServerPluginContainer) DoPostReadRequestHeader(ctx context.Context, r *core.Request) error
- func (p *ServerPluginContainer) DoPostWriteResponse(ctx context.Context, resp *core.Response, body interface{}) error
- func (p *ServerPluginContainer) DoPreReadRequestBody(ctx context.Context, body interface{}) error
- func (p *ServerPluginContainer) DoPreReadRequestHeader(ctx context.Context, r *core.Request) error
- func (p *ServerPluginContainer) DoPreWriteResponse(ctx context.Context, resp *core.Response, body interface{}) error
- func (p *ServerPluginContainer) DoRegister(name string, rcvr interface{}, metadata ...string) error
- func (p *ServerPluginContainer) GetAll() []IPlugin
- func (p *ServerPluginContainer) GetByName(pluginName string) IPlugin
- func (p *ServerPluginContainer) GetName(plugin IPlugin) string
- func (p *ServerPluginContainer) Remove(pluginName string) error
Constants ¶
const (
//DefaultRPCPath is the defaut HTTP RPC PATH
DefaultRPCPath = "/_goRPC_"
)
Variables ¶
var ( ErrPluginAlreadyExists = NewRPCError("cannot use the same plugin again, '%s' is already exists") ErrPluginActivate = NewRPCError("while trying to activate plugin '%s'. Trace: %s") ErrPluginRemoveNoPlugins = NewRPCError("no plugins are registed yet, you cannot remove a plugin from an empty list!") ErrPluginRemoveEmptyName = NewRPCError("plugin with an empty name cannot be removed") ErrPluginRemoveNotFound = NewRPCError("cannot remove a plugin which doesn't exists") ErrWrongServiceMethod = NewRPCError("? is not allowed in service method name):%s") )
var IP4Reg = regexp.MustCompile(`^(([0-9]|[1-9][0-9]|1[0-9]{2}|2[0-4][0-9]|25[0-5])\.){3}([0-9]|[1-9][0-9]|1[0-9]{2}|2[0-4][0-9]|25[0-5])$`)
Functions ¶
func GetListenedAddress ¶
func GetListenedAddress() string
GetListenedAddress return the listening address.
func NewCompressConn ¶
func NewCompressConn(conn net.Conn, compressType CompressType) net.Conn
NewCompressConn creates a wrapped net.Conn with CompressType
func NewDirectHTTPRPCClient ¶
func NewDirectHTTPRPCClient(c *Client, clientCodecFunc ClientCodecFunc, network, address string, path string, timeout time.Duration) (*core.Client, error)
NewDirectHTTPRPCClient creates a rpc http client
func NewDirectKCPRPCClient ¶
func NewDirectKCPRPCClient(c *Client, clientCodecFunc ClientCodecFunc, network, address string, path string, timeout time.Duration) (*core.Client, error)
NewDirectKCPRPCClient creates a kcp client. kcp project: https://github.com/xtaci/kcp-go
func NewDirectQuicRPCClient ¶
func NewDirectQuicRPCClient(c *Client, clientCodecFunc ClientCodecFunc, network, address string, path string, timeout time.Duration) (*core.Client, error)
NewDirectQuicRPCClient creates a quic client.
func NewDirectRPCClient ¶
func NewDirectRPCClient(c *Client, clientCodecFunc ClientCodecFunc, network, address string, timeout time.Duration) (*core.Client, error)
NewDirectRPCClient creates a rpc client
func RegisterName ¶
RegisterName publishes in the server the set of methods .
func Serve ¶
Serve starts and listens RPC requests. It is blocked until receiving connectings from clients.
func ServeByMux ¶
ServeByMux implements RPC via HTTP with customized mux
func ServeTLS ¶
ServeTLS starts and listens RPC requests. It is blocked until receiving connectings from clients.
func SetServerCodecFunc ¶
func SetServerCodecFunc(fn ServerCodecFunc)
SetServerCodecFunc sets a ServerCodecFunc
Types ¶
type ArgsContext ¶
type ArgsContext interface { Value(key string) interface{} SetValue(key string, value interface{}) }
ArgsContext contains net.Conn so services can get net.Conn info, for example, remote address.
type AuthorizationAndServiceMethod ¶
type AuthorizationAndServiceMethod struct { Authorization string // Authorization ServiceMethod string // real ServiceMethod name Tag string // extra tag for Authorization }
AuthorizationAndServiceMethod represents Authorization header and ServiceMethod.
func (*AuthorizationAndServiceMethod) String ¶
func (aasm *AuthorizationAndServiceMethod) String() string
type AuthorizationClientPlugin ¶
type AuthorizationClientPlugin struct {
AuthorizationAndServiceMethod *AuthorizationAndServiceMethod
}
AuthorizationClientPlugin is used to set Authorization info at client side.
func NewAuthorizationClientPlugin ¶
func NewAuthorizationClientPlugin(authorization, tag string) *AuthorizationClientPlugin
NewAuthorizationClientPlugin creates a AuthorizationClientPlugin with authorization header and tag
func (*AuthorizationClientPlugin) Name ¶
func (plugin *AuthorizationClientPlugin) Name() string
Name return name of this plugin.
func (*AuthorizationClientPlugin) PreWriteRequest ¶
func (plugin *AuthorizationClientPlugin) PreWriteRequest(ctx context.Context, r *core.Request, body interface{}) error
PreWriteRequest adds Authorization info in requests
type AuthorizationFunc ¶
type AuthorizationFunc func(p *AuthorizationAndServiceMethod) error
AuthorizationFunc defines a method type which handles Authorization info
type AuthorizationServerPlugin ¶
type AuthorizationServerPlugin struct {
AuthorizationFunc AuthorizationFunc
}
AuthorizationServerPlugin is used to authorize clients.
func (*AuthorizationServerPlugin) Name ¶
func (plugin *AuthorizationServerPlugin) Name() string
Name return name of this plugin.
func (*AuthorizationServerPlugin) PostReadRequestHeader ¶
func (plugin *AuthorizationServerPlugin) PostReadRequestHeader(ctx context.Context, r *core.Request) (err error)
PostReadRequestHeader extracts Authorization header from ServiceMethod field.
type Client ¶
type Client struct { ClientSelector ClientSelector ClientCodecFunc ClientCodecFunc PluginContainer IClientPluginContainer FailMode FailMode TLSConfig *tls.Config Block kcp.BlockCrypt Retries int //Timeout sets deadline for underlying net.Conns Timeout time.Duration //Timeout sets readdeadline for underlying net.Conns ReadTimeout time.Duration //Timeout sets writedeadline for underlying net.Conns WriteTimeout time.Duration }
Client represents a RPC client.
func (*Client) Call ¶
func (c *Client) Call(ctx context.Context, serviceMethod string, args interface{}, reply interface{}) (err error)
Call invokes the named function, waits for it to complete, and returns its error status.
func (*Client) Go ¶
func (c *Client) Go(ctx context.Context, serviceMethod string, args interface{}, reply interface{}, done chan *core.Call) *core.Call
Go invokes the function asynchronously. It returns the Call structure representing the invocation. The done channel will signal when the call is complete by returning the same Call object. If done is nil, Go will allocate a new channel. If non-nil, done must be buffered or Go will deliberately crash.
type ClientCodecFunc ¶
type ClientCodecFunc func(conn io.ReadWriteCloser) core.ClientCodec
ClientCodecFunc is used to create a core.ClientCodecFunc from net.Conn.
type ClientCodecWrapper ¶
type ClientCodecWrapper struct { core.ClientCodec ClientCodecFunc PluginContainer IClientPluginContainer Timeout time.Duration ReadTimeout time.Duration WriteTimeout time.Duration Conn net.Conn }
func (*ClientCodecWrapper) Close ¶
func (w *ClientCodecWrapper) Close() error
func (*ClientCodecWrapper) ReadRequestBody ¶
func (w *ClientCodecWrapper) ReadRequestBody(body interface{}) error
func (*ClientCodecWrapper) ReadRequestHeader ¶
func (w *ClientCodecWrapper) ReadRequestHeader(r *core.Response) error
func (*ClientCodecWrapper) WriteRequest ¶
type ClientPluginContainer ¶
type ClientPluginContainer struct {
// contains filtered or unexported fields
}
ClientPluginContainer implements IPluginContainer interface.
func (*ClientPluginContainer) Add ¶
func (p *ClientPluginContainer) Add(plugin IPlugin) error
Add adds a plugin.
func (*ClientPluginContainer) DoPostCall ¶
func (p *ClientPluginContainer) DoPostCall(ctx context.Context, serviceMethod string, args interface{}, reply interface{}) error
DoPostCall executes after call
func (*ClientPluginContainer) DoPostConnected ¶
DoPostConnected handles connected
func (*ClientPluginContainer) DoPostReadResponseBody ¶
func (p *ClientPluginContainer) DoPostReadResponseBody(body interface{}) error
DoPostReadResponseBody invokes DoPostReadResponseBody plugin.
func (*ClientPluginContainer) DoPostReadResponseHeader ¶
func (p *ClientPluginContainer) DoPostReadResponseHeader(r *core.Response) error
DoPostReadResponseHeader invokes DoPostReadResponseHeader plugin.
func (*ClientPluginContainer) DoPostWriteRequest ¶
func (p *ClientPluginContainer) DoPostWriteRequest(ctx context.Context, r *core.Request, body interface{}) error
DoPostWriteRequest invokes DoPostWriteRequest plugin.
func (*ClientPluginContainer) DoPreCall ¶
func (p *ClientPluginContainer) DoPreCall(ctx context.Context, serviceMethod string, args interface{}, reply interface{}) error
DoPreCall executes before call
func (*ClientPluginContainer) DoPreReadResponseBody ¶
func (p *ClientPluginContainer) DoPreReadResponseBody(body interface{}) error
DoPreReadResponseBody invokes DoPreReadResponseBody plugin.
func (*ClientPluginContainer) DoPreReadResponseHeader ¶
func (p *ClientPluginContainer) DoPreReadResponseHeader(r *core.Response) error
DoPreReadResponseHeader invokes DoPreReadResponseHeader plugin.
func (*ClientPluginContainer) DoPreWriteRequest ¶
func (p *ClientPluginContainer) DoPreWriteRequest(ctx context.Context, r *core.Request, body interface{}) error
DoPreWriteRequest invokes DoPreWriteRequest plugin.
func (*ClientPluginContainer) GetAll ¶
func (p *ClientPluginContainer) GetAll() []IPlugin
GetAll returns all activated plugins
func (*ClientPluginContainer) GetByName ¶
func (p *ClientPluginContainer) GetByName(pluginName string) IPlugin
GetByName returns a plugin instance by it's name
func (*ClientPluginContainer) GetName ¶
func (p *ClientPluginContainer) GetName(plugin IPlugin) string
GetName returns the name of a plugin, if no GetName() implemented it returns an empty string ""
func (*ClientPluginContainer) Remove ¶
func (p *ClientPluginContainer) Remove(pluginName string) error
Remove removes a plugin by it's name.
type ClientSelector ¶
type ClientSelector interface { //Select returns a new client and it also update current client Select(clientCodecFunc ClientCodecFunc, options ...interface{}) (*core.Client, error) //SetClient set current client SetClient(*Client) SetSelectMode(SelectMode) //AllClients returns all Clients AllClients(clientCodecFunc ClientCodecFunc) []*core.Client //handle failed client HandleFailedClient(client *core.Client) }
ClientSelector defines an interface to create a core.Client from cluster or standalone.
type CompressConn ¶
CompressConn wraps a net.Conn and supports compression
type CompressType ¶
type CompressType byte
CompressType is compression type. Currently only support zip and snappy
const ( // CompressNone represents no compression CompressNone CompressType = iota // CompressFlate represents zip CompressFlate // CompressSnappy represents snappy CompressSnappy // CompressZstd represents Facebook/Zstandard // CompressZstd // CompressLZ4 represents LZ4 (http://www.lz4.org) CompressLZ4 )
type DirectClientSelector ¶
type DirectClientSelector struct {
Network, Address string
DialTimeout time.Duration
Client *Client
sync.Mutex
// contains filtered or unexported fields
}
DirectClientSelector is used to a direct rpc server. It don't select a node from service cluster but a specific rpc server.
func (*DirectClientSelector) AllClients ¶
func (s *DirectClientSelector) AllClients(clientCodecFunc ClientCodecFunc) []*core.Client
AllClients returns core.Clients to all servers
func (*DirectClientSelector) HandleFailedClient ¶
func (s *DirectClientSelector) HandleFailedClient(client *core.Client)
func (*DirectClientSelector) Select ¶
func (s *DirectClientSelector) Select(clientCodecFunc ClientCodecFunc, options ...interface{}) (*core.Client, error)
Select returns a rpc client.
func (*DirectClientSelector) SetClient ¶
func (s *DirectClientSelector) SetClient(c *Client)
SetClient sets the unique client.
func (*DirectClientSelector) SetSelectMode ¶
func (s *DirectClientSelector) SetSelectMode(sm SelectMode)
SetSelectMode is meaningless for DirectClientSelector because there is only one client.
type FailMode ¶
type FailMode int
FailMode is a feature to decide client actions when clients fail to invoke services
const ( //Failover selects another server automaticaly Failover FailMode = iota //Failfast returns error immediately Failfast //Failtry use current client again Failtry //Broadcast sends requests to all servers and Success only when all servers return OK Broadcast //Forking sends requests to all servers and Success once one server returns OK Forking )
type IClientPluginContainer ¶
type IClientPluginContainer interface { Add(plugin IPlugin) error Remove(pluginName string) error GetName(plugin IPlugin) string GetByName(pluginName string) IPlugin GetAll() []IPlugin DoPostConnected(net.Conn) (net.Conn, bool) DoPreReadResponseHeader(*core.Response) error DoPostReadResponseHeader(*core.Response) error DoPreReadResponseBody(interface{}) error DoPostReadResponseBody(interface{}) error DoPreWriteRequest(context.Context, *core.Request, interface{}) error DoPostWriteRequest(context.Context, *core.Request, interface{}) error DoPreCall(ctx context.Context, serviceMethod string, args interface{}, reply interface{}) error DoPostCall(ctx context.Context, serviceMethod string, args interface{}, reply interface{}) error }
IClientPluginContainer represents a plugin container that defines all methods to manage plugins. And it also defines all extension points.
type IPostCallPlugin ¶
type IPostCallPlugin interface {
DoPostCall(ctx context.Context, serviceMethod string, args interface{}, reply interface{}) error
}
IPostCallPlugin is invoked after the client calls a server.
type IPostConnAcceptPlugin ¶
IPostConnAcceptPlugin represents connection accept plugin. if returns false, it means subsequent IPostConnAcceptPlugins should not contiune to handle this conn and this conn has been closed.
type IPostConnectedPlugin ¶
IPostConnectedPlugin represents connected plugin.
type IPostReadRequestBodyPlugin ¶
type IPostReadRequestBodyPlugin interface {
PostReadRequestBody(ctx context.Context, body interface{}) error
}
IPostReadRequestBodyPlugin represents .
type IPostReadRequestHeaderPlugin ¶
type IPostReadRequestHeaderPlugin interface {
PostReadRequestHeader(ctx context.Context, r *core.Request) error
}
IPostReadRequestHeaderPlugin represents .
type IPostReadResponseBodyPlugin ¶
type IPostReadResponseBodyPlugin interface {
PostReadResponseBody(interface{}) error
}
IPostReadResponseBodyPlugin represents .
type IPostReadResponseHeaderPlugin ¶
IPostReadResponseHeaderPlugin represents .
type IPostWriteRequestPlugin ¶
type IPostWriteRequestPlugin interface {
PostWriteRequest(context.Context, *core.Request, interface{}) error
}
IPostWriteRequestPlugin represents .
type IPostWriteResponsePlugin ¶
type IPostWriteResponsePlugin interface {
PostWriteResponse(context.Context, *core.Response, interface{}) error
}
IPostWriteResponsePlugin represents .
type IPreCallPlugin ¶
type IPreCallPlugin interface {
DoPreCall(ctx context.Context, serviceMethod string, args interface{}, reply interface{}) error
}
IPreCallPlugin is invoked before the client calls a server.
type IPreReadRequestBodyPlugin ¶
type IPreReadRequestBodyPlugin interface {
PreReadRequestBody(ctx context.Context, body interface{}) error
}
IPreReadRequestBodyPlugin represents .
type IPreReadRequestHeaderPlugin ¶
type IPreReadRequestHeaderPlugin interface {
PreReadRequestHeader(ctx context.Context, r *core.Request) error
}
IPreReadRequestHeaderPlugin represents .
type IPreReadResponseBodyPlugin ¶
type IPreReadResponseBodyPlugin interface {
PreReadResponseBody(interface{}) error
}
IPreReadResponseBodyPlugin represents .
type IPreReadResponseHeaderPlugin ¶
IPreReadResponseHeaderPlugin represents .
type IPreWriteRequestPlugin ¶
type IPreWriteRequestPlugin interface {
PreWriteRequest(context.Context, *core.Request, interface{}) error
}
IPreWriteRequestPlugin represents .
type IPreWriteResponsePlugin ¶
type IPreWriteResponsePlugin interface {
PreWriteResponse(context.Context, *core.Response, interface{}) error
}
IPreWriteResponsePlugin represents .
type IRegisterPlugin ¶
type IRegisterPlugin interface {
Register(name string, rcvr interface{}, metadata ...string) error
}
IRegisterPlugin represents register plugin.
type IServerCodecPlugin ¶
type IServerCodecPlugin interface { IPreReadRequestHeaderPlugin IPostReadRequestHeaderPlugin IPreReadRequestBodyPlugin IPostReadRequestBodyPlugin IPreWriteResponsePlugin IPostWriteResponsePlugin }
IServerCodecPlugin represents .
type IServerPluginContainer ¶
type IServerPluginContainer interface { Add(plugin IPlugin) error Remove(pluginName string) error GetName(plugin IPlugin) string GetByName(pluginName string) IPlugin GetAll() []IPlugin DoRegister(name string, rcvr interface{}, metadata ...string) error DoPostConnAccept(net.Conn) (net.Conn, bool) DoPreReadRequestHeader(ctx context.Context, r *core.Request) error DoPostReadRequestHeader(ctx context.Context, r *core.Request) error DoPreReadRequestBody(ctx context.Context, body interface{}) error DoPostReadRequestBody(ctx context.Context, body interface{}) error DoPreWriteResponse(context.Context, *core.Response, interface{}) error DoPostWriteResponse(context.Context, *core.Response, interface{}) error }
IServerPluginContainer represents a plugin container that defines all methods to manage plugins. And it also defines all extension points.
func GetPluginContainer ¶
func GetPluginContainer() IServerPluginContainer
GetPluginContainer get PluginContainer of default server.
type KCPConfig ¶
type KCPConfig struct {
BlockCrypt kcp.BlockCrypt
}
type MultiError ¶
type MultiError struct {
Errors []error
}
MultiError holds multiple errors
func NewMultiError ¶
func NewMultiError(errors []error) *MultiError
NewMultiError creates and returns an Error with error splice
func (*MultiError) Error ¶
func (e *MultiError) Error() string
Error returns the message of the actual error
type QUICConfig ¶
type RPCError ¶
type RPCError struct {
// contains filtered or unexported fields
}
RPCError holds the error
func NewRPCError ¶
NewRPCError creates and returns an Error with a message
func (*RPCError) Panicf ¶
func (e *RPCError) Panicf(args ...interface{})
Panicf output the formatted message and after panics
type ReconnectFunc ¶
type ReconnectFunc func(client *core.Client, clientAndServer map[string]*core.Client, rpcxClient *Client, dailTimeout time.Duration) bool
ReconnectFunc recnnect function.
var Reconnect ReconnectFunc = nil
Reconnect strategy. The default reconnect is to reconnect at most 3 times. var Reconnect ReconnectFunc = reconnect
type SelectMode ¶
type SelectMode int
SelectMode defines the algorithm of selecting a services from cluster
const ( //RandomSelect is selecting randomly RandomSelect SelectMode = iota //RoundRobin is selecting by round robin RoundRobin //WeightedRoundRobin is selecting by weighted round robin WeightedRoundRobin //WeightedICMP is selecting by weighted Ping time WeightedICMP //ConsistentHash is selecting by hashing ConsistentHash //Closest is selecting the closest server Closest )
func (SelectMode) String ¶
func (s SelectMode) String() string
type Server ¶
type Server struct { ServerCodecFunc ServerCodecFunc //PluginContainer must be configured before starting and Register plugins must be configured before invoking RegisterName method PluginContainer IServerPluginContainer //Metadata describes extra info about this service, for example, weight, active status Metadata string Timeout time.Duration ReadTimeout time.Duration WriteTimeout time.Duration // use for KCP KCPConfig KCPConfig // for QUIC QUICConfig QUICConfig // contains filtered or unexported fields }
Server represents a RPC Server.
func (*Server) Auth ¶
func (s *Server) Auth(fn AuthorizationFunc) error
Auth sets authorization function
func (*Server) RegisterName ¶
RegisterName publishes in the server the set of methods of the receiver value that satisfy the following conditions:
- exported method of exported type
- two arguments, both of exported type
- the second argument is a pointer
- one return value, of type error
It returns an error if the receiver is not an exported type or has no suitable methods. It also logs the error using package log. The client accesses each method using a string of the form "Type.Method", where Type is the receiver's concrete type.
func (*Server) Serve ¶
Serve starts and listens RPC requests. It is blocked until receiving connectings from clients.
func (*Server) ServeByHTTP ¶
ServeByHTTP serves
func (*Server) ServeByMux ¶
ServeByMux serves
func (*Server) ServeHTTP ¶
func (s *Server) ServeHTTP(w http.ResponseWriter, req *http.Request)
ServeHTTP implements net handler interface
func (*Server) ServeTLS ¶
ServeTLS starts and listens RPC requests. It is blocked until receiving connectings from clients.
type ServerCodecFunc ¶
type ServerCodecFunc func(conn io.ReadWriteCloser) core.ServerCodec
ServerCodecFunc is used to create a core.ServerCodec from net.Conn.
type ServerPluginContainer ¶
type ServerPluginContainer struct {
// contains filtered or unexported fields
}
ServerPluginContainer implements IPluginContainer interface.
func (*ServerPluginContainer) Add ¶
func (p *ServerPluginContainer) Add(plugin IPlugin) error
Add adds a plugin.
func (*ServerPluginContainer) DoPostConnAccept ¶
DoPostConnAccept handles accepted conn
func (*ServerPluginContainer) DoPostReadRequestBody ¶
func (p *ServerPluginContainer) DoPostReadRequestBody(ctx context.Context, body interface{}) error
DoPostReadRequestBody invokes DoPostReadRequestBody plugin.
func (*ServerPluginContainer) DoPostReadRequestHeader ¶
DoPostReadRequestHeader invokes DoPostReadRequestHeader plugin.
func (*ServerPluginContainer) DoPostWriteResponse ¶
func (p *ServerPluginContainer) DoPostWriteResponse(ctx context.Context, resp *core.Response, body interface{}) error
DoPostWriteResponse invokes DoPostWriteResponse plugin.
func (*ServerPluginContainer) DoPreReadRequestBody ¶
func (p *ServerPluginContainer) DoPreReadRequestBody(ctx context.Context, body interface{}) error
DoPreReadRequestBody invokes DoPreReadRequestBody plugin.
func (*ServerPluginContainer) DoPreReadRequestHeader ¶
DoPreReadRequestHeader invokes DoPreReadRequestHeader plugin.
func (*ServerPluginContainer) DoPreWriteResponse ¶
func (p *ServerPluginContainer) DoPreWriteResponse(ctx context.Context, resp *core.Response, body interface{}) error
DoPreWriteResponse invokes DoPreWriteResponse plugin.
func (*ServerPluginContainer) DoRegister ¶
func (p *ServerPluginContainer) DoRegister(name string, rcvr interface{}, metadata ...string) error
DoRegister invokes DoRegister plugin.
func (*ServerPluginContainer) GetAll ¶
func (p *ServerPluginContainer) GetAll() []IPlugin
GetAll returns all activated plugins
func (*ServerPluginContainer) GetByName ¶
func (p *ServerPluginContainer) GetByName(pluginName string) IPlugin
GetByName returns a plugin instance by it's name
func (*ServerPluginContainer) GetName ¶
func (p *ServerPluginContainer) GetName(plugin IPlugin) string
GetName returns the name of a plugin, if no GetName() implemented it returns an empty string ""
func (*ServerPluginContainer) Remove ¶
func (p *ServerPluginContainer) Remove(pluginName string) error
Remove removes a plugin by it's name.