2015-05-27 00:39:48 +03:00
|
|
|
package server
|
|
|
|
|
|
|
|
import (
|
2018-03-03 14:53:52 +03:00
|
|
|
"context"
|
2020-02-15 18:10:26 +03:00
|
|
|
"crypto/tls"
|
2020-12-15 11:52:05 +03:00
|
|
|
"net"
|
2019-05-27 16:17:57 +03:00
|
|
|
"sync"
|
2016-01-27 02:32:27 +03:00
|
|
|
"time"
|
|
|
|
|
2023-04-11 22:20:37 +03:00
|
|
|
"go.unistack.org/micro/v4/codec"
|
|
|
|
"go.unistack.org/micro/v4/logger"
|
|
|
|
"go.unistack.org/micro/v4/metadata"
|
|
|
|
"go.unistack.org/micro/v4/meter"
|
|
|
|
"go.unistack.org/micro/v4/options"
|
|
|
|
"go.unistack.org/micro/v4/register"
|
2024-03-11 16:25:44 +03:00
|
|
|
msync "go.unistack.org/micro/v4/sync"
|
2023-04-11 22:20:37 +03:00
|
|
|
"go.unistack.org/micro/v4/tracer"
|
|
|
|
"go.unistack.org/micro/v4/util/id"
|
2015-05-27 00:39:48 +03:00
|
|
|
)
|
|
|
|
|
2020-11-02 13:25:29 +03:00
|
|
|
// Options server struct
|
2015-12-31 21:11:46 +03:00
|
|
|
type Options struct {
|
2021-03-06 19:45:13 +03:00
|
|
|
// Context holds the external options and can be used for server shutdown
|
|
|
|
Context context.Context
|
|
|
|
// Register holds the register
|
|
|
|
Register register.Register
|
|
|
|
// Tracer holds the tracer
|
|
|
|
Tracer tracer.Tracer
|
|
|
|
// Logger holds the logger
|
|
|
|
Logger logger.Logger
|
|
|
|
// Meter holds the meter
|
|
|
|
Meter meter.Meter
|
2020-12-15 11:52:05 +03:00
|
|
|
// Listener may be passed if already created
|
|
|
|
Listener net.Listener
|
2021-03-06 19:45:13 +03:00
|
|
|
// Wait group
|
2024-03-11 16:25:44 +03:00
|
|
|
Wait *msync.WaitGroup
|
2021-03-06 19:45:13 +03:00
|
|
|
// TLSConfig specifies tls.Config for secure serving
|
|
|
|
TLSConfig *tls.Config
|
|
|
|
// Metadata holds the server metadata
|
|
|
|
Metadata metadata.Metadata
|
|
|
|
// RegisterCheck run before register server
|
|
|
|
RegisterCheck func(context.Context) error
|
|
|
|
// Codecs map to handle content-type
|
|
|
|
Codecs map[string]codec.Codec
|
2021-04-27 08:32:47 +03:00
|
|
|
// ID holds the id of the server
|
|
|
|
ID string
|
2021-03-06 19:45:13 +03:00
|
|
|
// Namespace for te server
|
|
|
|
Namespace string
|
|
|
|
// Name holds the server name
|
|
|
|
Name string
|
|
|
|
// Address holds the server address
|
|
|
|
Address string
|
2021-03-06 23:33:37 +03:00
|
|
|
// Advertise holds the advertise address
|
2021-03-06 19:45:13 +03:00
|
|
|
Advertise string
|
|
|
|
// Version holds the server version
|
|
|
|
Version string
|
|
|
|
// RegisterAttempts holds the number of register attempts before error
|
|
|
|
RegisterAttempts int
|
|
|
|
// RegisterInterval holds he interval for re-register
|
|
|
|
RegisterInterval time.Duration
|
|
|
|
// RegisterTTL specifies TTL for register record
|
|
|
|
RegisterTTL time.Duration
|
|
|
|
// MaxConn limits number of connections
|
2020-12-15 11:46:26 +03:00
|
|
|
MaxConn int
|
2021-03-06 19:45:13 +03:00
|
|
|
// DeregisterAttempts holds the number of deregister attempts before error
|
|
|
|
DeregisterAttempts int
|
2023-07-29 00:40:58 +03:00
|
|
|
// Hooks may contains HandleWrapper or Server func wrapper
|
2023-03-24 00:25:47 +03:00
|
|
|
Hooks options.Hooks
|
2024-02-29 13:28:27 +03:00
|
|
|
// GracefulTimeout timeout for graceful stop server
|
|
|
|
GracefulTimeout time.Duration
|
2015-12-31 21:11:46 +03:00
|
|
|
}
|
|
|
|
|
2020-11-02 13:25:29 +03:00
|
|
|
// NewOptions returns new options struct with default or passed values
|
2023-07-29 00:40:58 +03:00
|
|
|
func NewOptions(opts ...options.Option) Options {
|
2020-09-10 00:25:33 +03:00
|
|
|
options := Options{
|
2020-11-23 16:18:47 +03:00
|
|
|
Codecs: make(map[string]codec.Codec),
|
2020-09-05 02:11:29 +03:00
|
|
|
Context: context.Background(),
|
2020-11-18 16:50:41 +03:00
|
|
|
Metadata: metadata.New(0),
|
2019-09-23 19:59:34 +03:00
|
|
|
RegisterInterval: DefaultRegisterInterval,
|
|
|
|
RegisterTTL: DefaultRegisterTTL,
|
2020-09-05 02:11:29 +03:00
|
|
|
RegisterCheck: DefaultRegisterCheck,
|
2020-10-16 09:38:57 +03:00
|
|
|
Logger: logger.DefaultLogger,
|
2021-01-22 23:32:33 +03:00
|
|
|
Meter: meter.DefaultMeter,
|
2020-10-16 09:38:57 +03:00
|
|
|
Tracer: tracer.DefaultTracer,
|
2021-01-29 13:17:32 +03:00
|
|
|
Register: register.DefaultRegister,
|
2020-09-05 02:11:29 +03:00
|
|
|
Address: DefaultAddress,
|
|
|
|
Name: DefaultName,
|
|
|
|
Version: DefaultVersion,
|
2021-11-24 00:57:59 +03:00
|
|
|
ID: id.Must(),
|
2024-02-29 13:28:27 +03:00
|
|
|
GracefulTimeout: DefaultGracefulTimeout,
|
2015-11-25 22:50:05 +03:00
|
|
|
}
|
2020-09-10 00:25:33 +03:00
|
|
|
|
|
|
|
for _, o := range opts {
|
|
|
|
o(&options)
|
|
|
|
}
|
|
|
|
|
|
|
|
return options
|
2015-05-27 00:39:48 +03:00
|
|
|
}
|
|
|
|
|
2021-04-27 08:32:47 +03:00
|
|
|
// ID unique server id
|
2023-07-29 00:40:58 +03:00
|
|
|
func ID(id string) options.Option {
|
|
|
|
return func(src interface{}) error {
|
|
|
|
return options.Set(src, id, ".ID")
|
2015-06-03 03:25:37 +03:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2015-11-26 03:23:36 +03:00
|
|
|
// Version of the service
|
2023-07-29 00:40:58 +03:00
|
|
|
func Version(v string) options.Option {
|
|
|
|
return func(src interface{}) error {
|
|
|
|
return options.Set(src, v, ".Version")
|
2015-06-03 03:25:37 +03:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-11-03 01:08:23 +03:00
|
|
|
// Advertise the address to advertise for discovery - host:port
|
2023-07-29 00:40:58 +03:00
|
|
|
func Advertise(a string) options.Option {
|
|
|
|
return func(src interface{}) error {
|
|
|
|
return options.Set(src, a, ".Advertise")
|
2015-06-03 03:25:37 +03:00
|
|
|
}
|
|
|
|
}
|
2015-12-02 03:47:52 +03:00
|
|
|
|
2021-01-29 13:17:32 +03:00
|
|
|
// RegisterCheck run func before register service
|
2023-07-29 00:40:58 +03:00
|
|
|
func RegisterCheck(fn func(context.Context) error) options.Option {
|
|
|
|
return func(src interface{}) error {
|
|
|
|
return options.Set(src, fn, ".RegisterCheck")
|
2019-05-13 01:39:42 +03:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-11-03 01:08:23 +03:00
|
|
|
// RegisterTTL registers service with a TTL
|
2023-07-29 00:40:58 +03:00
|
|
|
func RegisterTTL(td time.Duration) options.Option {
|
|
|
|
return func(src interface{}) error {
|
|
|
|
return options.Set(src, td, ".RegisterTTL")
|
2016-01-27 15:23:18 +03:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-11-03 01:08:23 +03:00
|
|
|
// RegisterInterval registers service with at interval
|
2023-07-29 00:40:58 +03:00
|
|
|
func RegisterInterval(td time.Duration) options.Option {
|
|
|
|
return func(src interface{}) error {
|
|
|
|
return options.Set(src, td, ".RegisterInterval")
|
2020-02-15 18:10:26 +03:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-05-31 21:47:50 +03:00
|
|
|
// Wait tells the server to wait for requests to finish before exiting
|
2019-05-27 16:17:57 +03:00
|
|
|
// If `wg` is nil, server only wait for completion of rpc handler.
|
|
|
|
// For user need finer grained control, pass a concrete `wg` here, server will
|
|
|
|
// wait against it on stop.
|
2023-07-29 00:40:58 +03:00
|
|
|
func Wait(wg *sync.WaitGroup) options.Option {
|
|
|
|
if wg == nil {
|
|
|
|
wg = new(sync.WaitGroup)
|
2017-05-31 21:47:50 +03:00
|
|
|
}
|
2024-03-12 10:59:18 +03:00
|
|
|
|
|
|
|
wrap := msync.WrapWaitGroup(wg)
|
|
|
|
|
2023-07-29 00:40:58 +03:00
|
|
|
return func(src interface{}) error {
|
2024-03-12 10:59:18 +03:00
|
|
|
return options.Set(src, wrap, ".Wait")
|
2015-12-02 03:47:52 +03:00
|
|
|
}
|
|
|
|
}
|
2015-12-02 14:54:36 +03:00
|
|
|
|
2020-12-15 11:52:05 +03:00
|
|
|
// MaxConn specifies maximum number of max simultaneous connections to server
|
2023-07-29 00:40:58 +03:00
|
|
|
func MaxConn(n int) options.Option {
|
|
|
|
return func(src interface{}) error {
|
|
|
|
return options.Set(src, n, ".MaxConn")
|
2020-12-15 11:52:05 +03:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Listener specifies the net.Listener to use instead of the default
|
2023-07-29 00:40:58 +03:00
|
|
|
func Listener(nl net.Listener) options.Option {
|
|
|
|
return func(src interface{}) error {
|
|
|
|
return options.Set(src, nl, ".Listener")
|
2020-12-15 11:52:05 +03:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2024-02-29 23:27:18 +03:00
|
|
|
func GracefulTimeout(td time.Duration) options.Option {
|
2024-02-29 13:28:27 +03:00
|
|
|
return func(src interface{}) error {
|
2024-02-29 23:27:18 +03:00
|
|
|
return options.Set(src, td, ".GracefulTimeout")
|
2024-02-29 13:28:27 +03:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2023-07-29 00:40:58 +03:00
|
|
|
// HandleOptions struct
|
|
|
|
type HandleOptions struct {
|
2021-03-06 19:45:13 +03:00
|
|
|
// Context holds external options
|
|
|
|
Context context.Context
|
2023-02-13 23:31:38 +03:00
|
|
|
// Metadata for handler
|
2020-11-18 16:50:41 +03:00
|
|
|
Metadata map[string]metadata.Metadata
|
2020-10-16 09:38:57 +03:00
|
|
|
}
|
|
|
|
|
2023-07-29 00:40:58 +03:00
|
|
|
// NewHandleOptions creates new HandleOptions
|
|
|
|
func NewHandleOptions(opts ...options.Option) HandleOptions {
|
|
|
|
options := HandleOptions{
|
2021-01-10 03:36:23 +03:00
|
|
|
Context: context.Background(),
|
|
|
|
Metadata: make(map[string]metadata.Metadata),
|
2020-10-16 09:38:57 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
for _, o := range opts {
|
|
|
|
o(&options)
|
|
|
|
}
|
|
|
|
|
|
|
|
return options
|
|
|
|
}
|