Documentation ¶
Index ¶
Constants ¶
View Source
const (
//PackageLengthSize package length size
PackageLengthSize = 2
)
Variables ¶
View Source
var ErrReadMessage = errors.New("read message failed")
ErrReadMessage read message failed
View Source
var ErrReadPackageLength = errors.New("read package length failed")
ErrReadPackageLength read package length failed
Functions ¶
func NewConn ¶
func NewConn(conn net.Conn, rwQueueSize int, maxMessageSize uint32, readDeadline time.Duration) network.IConn
NewConn create tcp conn
func NewServer ¶
func NewServer(conf config.IConfig, agentFunc network.AgentCreateFunc, agentCloseFunc network.AgentCloseFunc) network.IServer
NewServer create tcp server
Types ¶
type Client ¶
type Client struct { sync.Mutex Conf *ClientConfig NewAgent network.AgentCreateFunc CloseAgent network.AgentCloseFunc // contains filtered or unexported fields }
Client tcp client
func NewClient ¶
func NewClient(conf config.IConfig, agentFunc network.AgentCreateFunc, agentCloseFunc network.AgentCloseFunc) *Client
NewClient create tcp client
type ClientConfig ¶
type ClientConfig struct { Nodes []common.NodeInfo `mapstructure:"nodes"` ConnNum int `mapstructure:"conn_num"` ConnectInterval time.Duration `mapstructure:"connect_interval"` SocketQueueSize int `mapstructure:"socket_queue_size"` MaxMessageSize uint32 `mapstructure:"max_message_size"` HandshakeTimeout time.Duration `mapstructure:"handshake_timeout"` AutoReconnect bool `mapstructure:"auto_reconnect"` Network string `mapstructure:"network"` Token string `mapstructure:"token"` UID uint64 `mapstructure:"uid"` ReadBufferSize int `mapstructure:"read_buffer_size"` WriteBufferSize int `mapstructure:"write_buffer_size"` ReadDeadline time.Duration `mapstructure:"read_dead_line"` QueueSize int `mapstructure:"queue_size"` }
ClientConfig tcp client config
func (*ClientConfig) GetQueueSize ¶
func (c *ClientConfig) GetQueueSize() int
GetQueueSize get module queue size
type Config ¶
type Config struct { Address string Network string MaxConnNum int RWQueueSize int MaxMessageSize uint32 ReadBufferSize int WriteBufferSize int ReadDeadline time.Duration }
Config tcp conn config
type Conn ¶
Conn tcp conn define
func (*Conn) ReadMessage ¶
ReadMessage goroutine not safe
func (*Conn) WriteMessage ¶
WriteMessage args must not be modified by the others goroutines buffer must packet with 2B package length
type Server ¶
type Server struct { Conf *ServerConfig NewAgent network.AgentCreateFunc CloseAgent network.AgentCloseFunc // contains filtered or unexported fields }
Server tcp server define
type ServerConfig ¶
type ServerConfig struct { Address string `mapstructure:"address"` Network string `mapstructure:"network"` MaxConnNum int `mapstructure:"max_conn_num"` SocketQueueSize int `mapstructure:"socket_queue_size"` MaxMessageSize uint32 `mapstructure:"max_message_size"` ReadBufferSize int `mapstructure:"read_buffer_size"` WriteBufferSize int `mapstructure:"write_buffer_size"` ReadDeadline time.Duration `mapstructure:"read_dead_line"` QueueSize int `mapstructure:"queue_size"` }
ServerConfig tcp server config
func (*ServerConfig) GetQueueSize ¶
func (s *ServerConfig) GetQueueSize() int
GetQueueSize get module queue size
Click to show internal directories.
Click to hide internal directories.