znet

package
v1.2.7 Latest Latest
Warning

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

Go to latest
Published: Aug 20, 2024 License: MIT Imports: 29 Imported by: 0

Documentation

Index

Constants

View Source
const (
	// The number of stack frames to start tracing from
	// (开始追踪堆栈信息的层数)
	StackBegin = 3
	// The number of stack frames to trace until the end
	// (追踪到最后的层数)
	StackEnd = 5
)
View Source
const (
	PRE_HANDLE  ziface.HandleStep = iota // PreHandle for pre-processing
	HANDLE                               // Handle for processing
	POST_HANDLE                          // PostHandle for post-processing

	HANDLE_OVER
)
View Source
const (
	// If the Worker goroutine pool is not started, a virtual WorkerID is assigned to the MsgHandler, which is 0, for metric counting
	// After starting the Worker goroutine pool, the ID of each worker is 0,1,2,3...
	// (如果不启动Worker协程池,则会给MsgHandler分配一个虚拟的WorkerID,这个workerID为0, 便于指标统计
	// 启动了Worker协程池后,每个worker的ID为0,1,2,3...)
	WorkerIDWithoutWorkerPool int = 0
)

Variables

View Source
var AcceptDelay *acceptDelay
View Source
var RequestPool = new(sync.Pool)

Functions

func GetRequest

func GetRequest(conn ziface.IConnection, msg ziface.IMessage) ziface.IRequest

func HeatBeatDefaultHandle

func HeatBeatDefaultHandle(req ziface.IRequest)

func NewClient

func NewClient(ip string, port int, opts ...ClientOption) ziface.IClient

func NewDefaultRouterSlicesServer

func NewDefaultRouterSlicesServer(opts ...Option) ziface.IServer

NewDefaultRouterSlicesServer creates a server handle with a default RouterRecovery processor. (创建一个默认自带一个Recover处理器的服务器句柄)

func NewFuncRequest

func NewFuncRequest(conn ziface.IConnection, callFunc func()) ziface.IRequest

func NewHeartbeatChecker

func NewHeartbeatChecker(interval time.Duration) ziface.IHeartbeatChecker

func NewRequest

func NewRequest(conn ziface.IConnection, msg ziface.IMessage) ziface.IRequest

func NewServer

func NewServer(opts ...Option) ziface.IServer

NewServer creates a server handle (创建一个服务器句柄)

func NewTLSClient

func NewTLSClient(ip string, port int, opts ...ClientOption) ziface.IClient

func NewUserConfDefaultRouterSlicesServer

func NewUserConfDefaultRouterSlicesServer(config *zconf.Config, opts ...Option) ziface.IServer

NewUserConfDefaultRouterSlicesServer creates a server handle with user-configured options and a default Recover handler. If the user does not wish to use the Use method, they should use NewUserConfServer instead. (创建一个用户配置的自带一个Recover处理器的服务器句柄,如果用户不希望Use这个方法,那么应该使用NewUserConfServer)

func NewUserConfServer

func NewUserConfServer(config *zconf.Config, opts ...Option) ziface.IServer

NewUserConfServer creates a server handle using user-defined configuration (创建一个服务器句柄)

func NewWsClient

func NewWsClient(ip string, port int, opts ...ClientOption) ziface.IClient

func PutRequest

func PutRequest(request ziface.IRequest)

func RouterRecovery

func RouterRecovery(request ziface.IRequest)

RouterRecovery If you use the server obtained from initializing with NewDefaultRouterSlicesServer method, this function will be included. It is used to catch any panics that occur during request handling and attempt to record the context information. (如果使用NewDefaultRouterSlicesServer方法初始化的获得的server将自带这个函数 作用是接收业务执行上产生的panic并且尝试记录现场信息)

func RouterTime

func RouterTime(request ziface.IRequest)

RouterTime Simply accumulates the time taken by all the routing groups, but not enabled (简单累计所有路由组的耗时,不启用)

Types

type BaseRouter

type BaseRouter struct{}

BaseRouter is used as the base class when implementing a router. Depending on the needs, the methods of this base class can be overridden. (实现router时,先嵌入这个基类,然后根据需要对这个基类的方法进行重写)

func (*BaseRouter) Handle

func (br *BaseRouter) Handle(req ziface.IRequest)

Handle -

func (*BaseRouter) PostHandle

func (br *BaseRouter) PostHandle(req ziface.IRequest)

PostHandle -

func (*BaseRouter) PreHandle

func (br *BaseRouter) PreHandle(req ziface.IRequest)

PreHandle -

type Client

type Client struct {
	// Client Name 客户端的名称
	Name string
	// IP of the target server to connect 目标链接服务器的IP
	Ip string
	// Port of the target server to connect 目标链接服务器的端口
	Port int

	// Error channel
	ErrChan chan error
	// contains filtered or unexported fields
}

func (*Client) AddInterceptor

func (c *Client) AddInterceptor(interceptor ziface.IInterceptor)

func (*Client) AddRouter

func (c *Client) AddRouter(msgID uint32, router ziface.IRouter)

func (*Client) Conn

func (c *Client) Conn() ziface.IConnection

func (*Client) GetErrChan

func (c *Client) GetErrChan() chan error

func (*Client) GetLengthField

func (c *Client) GetLengthField() *ziface.LengthField

func (*Client) GetMsgHandler

func (c *Client) GetMsgHandler() ziface.IMsgHandle

func (*Client) GetName

func (c *Client) GetName() string

func (*Client) GetOnConnStart

func (c *Client) GetOnConnStart() func(ziface.IConnection)

func (*Client) GetOnConnStop

func (c *Client) GetOnConnStop() func(ziface.IConnection)

func (*Client) GetPacket

func (c *Client) GetPacket() ziface.IDataPack

func (*Client) Restart

func (c *Client) Restart()

Start starts the client, sends requests and establishes a connection. (重新启动客户端,发送请求且建立连接)

func (*Client) SetDecoder

func (c *Client) SetDecoder(decoder ziface.IDecoder)

func (*Client) SetName

func (c *Client) SetName(name string)

func (*Client) SetOnConnStart

func (c *Client) SetOnConnStart(hookFunc func(ziface.IConnection))

func (*Client) SetOnConnStop

func (c *Client) SetOnConnStop(hookFunc func(ziface.IConnection))

func (*Client) SetPacket

func (c *Client) SetPacket(packet ziface.IDataPack)

func (*Client) Start

func (c *Client) Start()

Start starts the client, sends requests and establishes a connection. (启动客户端,发送请求且建立链接)

func (*Client) StartHeartBeat

func (c *Client) StartHeartBeat(interval time.Duration)

StartHeartBeat starts heartbeat detection with a fixed time interval. interval: the time interval between each heartbeat message. (启动心跳检测, interval: 每次发送心跳的时间间隔)

func (*Client) StartHeartBeatWithOption

func (c *Client) StartHeartBeatWithOption(interval time.Duration, option *ziface.HeartBeatOption)

StartHeartBeatWithOption starts heartbeat detection with a custom callback function. interval: the time interval between each heartbeat message. option: a HeartBeatOption struct that contains the custom callback function and message 启动心跳检测(自定义回调)

func (*Client) Stop

func (c *Client) Stop()

type ClientOption

type ClientOption func(c ziface.IClient)

Options for Client

func WithNameClient

func WithNameClient(name string) ClientOption

Set client name

func WithPacketClient

func WithPacketClient(pack ziface.IDataPack) ClientOption

Implement custom data packet format by implementing the Packet interface for client, otherwise use the default data packet format

type ConnManager

type ConnManager struct {
	// contains filtered or unexported fields
}

func (*ConnManager) Add

func (connMgr *ConnManager) Add(conn ziface.IConnection)

func (*ConnManager) ClearConn

func (connMgr *ConnManager) ClearConn()

func (*ConnManager) Get

func (connMgr *ConnManager) Get(connID uint64) (ziface.IConnection, error)

func (*ConnManager) Get2

func (connMgr *ConnManager) Get2(strConnId string) (ziface.IConnection, error)

Get2 It is recommended to use this method to obtain connection instances

func (*ConnManager) GetAllConnID

func (connMgr *ConnManager) GetAllConnID() []uint64

func (*ConnManager) GetAllConnIdStr

func (connMgr *ConnManager) GetAllConnIdStr() []string

func (*ConnManager) Len

func (connMgr *ConnManager) Len() int

func (*ConnManager) Range

func (connMgr *ConnManager) Range(cb func(uint64, ziface.IConnection, interface{}) error, args interface{}) (err error)

func (*ConnManager) Range2

func (connMgr *ConnManager) Range2(cb func(string, ziface.IConnection, interface{}) error, args interface{}) (err error)

Range2 It is recommended to use this method to 'Range'

func (*ConnManager) Remove

func (connMgr *ConnManager) Remove(conn ziface.IConnection)

type Connection

type Connection struct {
	// contains filtered or unexported fields
}

Connection TCP connection module Used to handle the read and write business of TCP connections, one Connection corresponds to one connection (用于处理Tcp连接的读写业务 一个连接对应一个Connection)

func (*Connection) AddCloseCallback

func (s *Connection) AddCloseCallback(handler, key interface{}, f func())

func (*Connection) Context

func (c *Connection) Context() context.Context

func (*Connection) GetConnID

func (c *Connection) GetConnID() uint64

func (*Connection) GetConnIdStr

func (c *Connection) GetConnIdStr() string

func (*Connection) GetConnection

func (c *Connection) GetConnection() net.Conn

func (*Connection) GetMsgHandler

func (c *Connection) GetMsgHandler() ziface.IMsgHandle

func (*Connection) GetName

func (c *Connection) GetName() string

func (*Connection) GetProperty

func (c *Connection) GetProperty(key string) (interface{}, error)

func (*Connection) GetTCPConnection deprecated

func (c *Connection) GetTCPConnection() net.Conn

Deprecated: use GetConnection instead

func (*Connection) GetWorkerID

func (c *Connection) GetWorkerID() uint32

func (*Connection) GetWsConn

func (c *Connection) GetWsConn() *websocket.Conn

func (*Connection) InvokeCloseCallbacks

func (s *Connection) InvokeCloseCallbacks()

func (*Connection) IsAlive

func (c *Connection) IsAlive() bool

func (*Connection) LocalAddr

func (c *Connection) LocalAddr() net.Addr

func (*Connection) LocalAddrString

func (c *Connection) LocalAddrString() string

func (*Connection) RemoteAddr

func (c *Connection) RemoteAddr() net.Addr

func (*Connection) RemoteAddrString

func (c *Connection) RemoteAddrString() string

func (*Connection) RemoveCloseCallback

func (s *Connection) RemoveCloseCallback(handler, key interface{})

func (*Connection) RemoveProperty

func (c *Connection) RemoveProperty(key string)

func (*Connection) Send

func (c *Connection) Send(data []byte) error

func (*Connection) SendBuffMsg

func (c *Connection) SendBuffMsg(msgID uint32, data []byte) error

func (*Connection) SendMsg

func (c *Connection) SendMsg(msgID uint32, data []byte) error

SendMsg directly sends Message data to the remote TCP client. (直接将Message数据发送数据给远程的TCP客户端)

func (*Connection) SendToQueue

func (c *Connection) SendToQueue(data []byte) error

func (*Connection) SetHeartBeat

func (c *Connection) SetHeartBeat(checker ziface.IHeartbeatChecker)

func (*Connection) SetProperty

func (c *Connection) SetProperty(key string, value interface{})

func (*Connection) Start

func (c *Connection) Start()

Start starts the connection and makes the current connection work. (启动连接,让当前连接开始工作)

func (*Connection) StartReader

func (c *Connection) StartReader()

StartReader is a goroutine that reads data from the client (读消息Goroutine,用于从客户端中读取数据)

func (*Connection) StartWriter

func (c *Connection) StartWriter()

StartWriter is the goroutine that writes messages to the client (写消息Goroutine, 用户将数据发送给客户端)

func (*Connection) Stop

func (c *Connection) Stop()

Stop stops the connection and ends the current connection state. (停止连接,结束当前连接状态)

type GroupRouter

type GroupRouter struct {
	Handlers []ziface.RouterHandler
	// contains filtered or unexported fields
}

func NewGroup

func NewGroup(start, end uint32, router *RouterSlices, Handlers ...ziface.RouterHandler) *GroupRouter

func (*GroupRouter) AddHandler

func (g *GroupRouter) AddHandler(MsgId uint32, Handlers ...ziface.RouterHandler)

func (*GroupRouter) Use

func (g *GroupRouter) Use(Handlers ...ziface.RouterHandler)

type HeartbeatChecker

type HeartbeatChecker struct {
	// contains filtered or unexported fields
}

func (*HeartbeatChecker) BindConn

func (h *HeartbeatChecker) BindConn(conn ziface.IConnection)

func (*HeartbeatChecker) BindRouter

func (h *HeartbeatChecker) BindRouter(msgID uint32, router ziface.IRouter)

func (*HeartbeatChecker) BindRouterSlices

func (h *HeartbeatChecker) BindRouterSlices(msgID uint32, handlers ...ziface.RouterHandler)

func (*HeartbeatChecker) Clone

Clone clones to a specified connection (克隆到一个指定的链接上)

func (*HeartbeatChecker) MsgID

func (h *HeartbeatChecker) MsgID() uint32

func (*HeartbeatChecker) Router

func (h *HeartbeatChecker) Router() ziface.IRouter

func (*HeartbeatChecker) RouterSlices

func (h *HeartbeatChecker) RouterSlices() []ziface.RouterHandler

func (*HeartbeatChecker) SendHeartBeatMsg

func (h *HeartbeatChecker) SendHeartBeatMsg() error

func (*HeartbeatChecker) SetHeartbeatFunc

func (h *HeartbeatChecker) SetHeartbeatFunc(beatFunc ziface.HeartBeatFunc)

func (*HeartbeatChecker) SetHeartbeatMsgFunc

func (h *HeartbeatChecker) SetHeartbeatMsgFunc(f ziface.HeartBeatMsgFunc)

func (*HeartbeatChecker) SetOnRemoteNotAlive

func (h *HeartbeatChecker) SetOnRemoteNotAlive(f ziface.OnRemoteNotAlive)

func (*HeartbeatChecker) Start

func (h *HeartbeatChecker) Start()

func (*HeartbeatChecker) Stop

func (h *HeartbeatChecker) Stop()

type HeatBeatDefaultRouter

type HeatBeatDefaultRouter struct {
	BaseRouter
}

Default callback routing business for receiving remote heartbeat messages (收到remote心跳消息的默认回调路由业务)

func (*HeatBeatDefaultRouter) Handle

func (r *HeatBeatDefaultRouter) Handle(req ziface.IRequest)

type KcpConfig

type KcpConfig struct {
	// changes ack flush option, set true to flush ack immediately,
	// (改变ack刷新选项,设置为true立即刷新ack)
	KcpACKNoDelay bool
	// toggles the stream mode on/off
	// (切换流模式开/关)
	KcpStreamMode bool
	// Whether nodelay mode is enabled, 0 is not enabled; 1 enabled.
	// (是否启用nodelay模式,0不启用;1启用)
	KcpNoDelay int
	// Protocol internal work interval, in milliseconds, such as 10 ms or 20 ms.
	// (协议内部工作的间隔,单位毫秒,比如10ms或者20ms)
	KcpInterval int
	// Fast retransmission mode, 0 represents off by default, 2 can be set (2 ACK spans will result in direct retransmission)
	// (快速重传模式,默认为0关闭,可以设置2(2次ACK跨越将会直接重传)
	KcpResend int
	// Whether to turn off flow control, 0 represents “Do not turn off” by default, 1 represents “Turn off”.
	// (是否关闭流控,默认是0代表不关闭,1代表关闭)
	KcpNc int
	// SND_BUF, this unit is the packet, default 32.
	// (SND_BUF发送缓冲区大小,单位是包,默认是32)
	KcpSendWindow int
	// RCV_BUF, this unit is the packet, default 32.
	// (RCV_BUF接收缓冲区大小,单位是包,默认是32)
	KcpRecvWindow int
	// FEC data shards, default 0.
	// (FEC数据分片,用于前向纠错比例配制) 默认是0
	KcpFecDataShards int
	// FEC parity shards, default 0.
	// (FEC校验分片,用于前向纠错比例配制) 默认是0
	KcpFecParityShards int
}

type KcpConnection

type KcpConnection struct {
	// contains filtered or unexported fields
}

Connection KCP connection module Used to handle the read and write business of KCP connections, one Connection corresponds to one connection (用于处理KCP连接的读写业务 一个连接对应一个Connection)

func (*KcpConnection) AddCloseCallback

func (s *KcpConnection) AddCloseCallback(handler, key interface{}, f func())

func (*KcpConnection) Context

func (c *KcpConnection) Context() context.Context

func (*KcpConnection) GetConnID

func (c *KcpConnection) GetConnID() uint64

func (*KcpConnection) GetConnIdStr

func (c *KcpConnection) GetConnIdStr() string

func (*KcpConnection) GetConnection

func (c *KcpConnection) GetConnection() net.Conn

func (*KcpConnection) GetMsgHandler

func (c *KcpConnection) GetMsgHandler() ziface.IMsgHandle

func (*KcpConnection) GetName

func (c *KcpConnection) GetName() string

func (*KcpConnection) GetProperty

func (c *KcpConnection) GetProperty(key string) (interface{}, error)

func (*KcpConnection) GetTCPConnection deprecated

func (c *KcpConnection) GetTCPConnection() net.Conn

Deprecated: use GetConnection instead

func (*KcpConnection) GetWorkerID

func (c *KcpConnection) GetWorkerID() uint32

func (*KcpConnection) GetWsConn

func (c *KcpConnection) GetWsConn() *websocket.Conn

func (*KcpConnection) InvokeCloseCallbacks

func (s *KcpConnection) InvokeCloseCallbacks()

invokeCloseCallbacks 触发 close callback, 在独立协程完成

func (*KcpConnection) IsAlive

func (c *KcpConnection) IsAlive() bool

func (*KcpConnection) LocalAddr

func (c *KcpConnection) LocalAddr() net.Addr

func (*KcpConnection) LocalAddrString

func (c *KcpConnection) LocalAddrString() string

func (*KcpConnection) RemoteAddr

func (c *KcpConnection) RemoteAddr() net.Addr

func (*KcpConnection) RemoteAddrString

func (c *KcpConnection) RemoteAddrString() string

func (*KcpConnection) RemoveCloseCallback

func (s *KcpConnection) RemoveCloseCallback(handler, key interface{})

func (*KcpConnection) RemoveProperty

func (c *KcpConnection) RemoveProperty(key string)

func (*KcpConnection) Send

func (c *KcpConnection) Send(data []byte) error

func (*KcpConnection) SendBuffMsg

func (c *KcpConnection) SendBuffMsg(msgID uint32, data []byte) error

func (*KcpConnection) SendMsg

func (c *KcpConnection) SendMsg(msgID uint32, data []byte) error

SendMsg directly sends Message data to the remote KCP client. (直接将Message数据发送数据给远程的KCP客户端)

func (*KcpConnection) SendToQueue

func (c *KcpConnection) SendToQueue(data []byte) error

func (*KcpConnection) SetHeartBeat

func (c *KcpConnection) SetHeartBeat(checker ziface.IHeartbeatChecker)

func (*KcpConnection) SetProperty

func (c *KcpConnection) SetProperty(key string, value interface{})

func (*KcpConnection) Start

func (c *KcpConnection) Start()

Start starts the connection and makes the current connection work. (启动连接,让当前连接开始工作)

func (*KcpConnection) StartReader

func (c *KcpConnection) StartReader()

StartReader is a goroutine that reads data from the client (读消息Goroutine,用于从客户端中读取数据)

func (*KcpConnection) StartWriter

func (c *KcpConnection) StartWriter()

StartWriter is the goroutine that writes messages to the client (写消息Goroutine, 用户将数据发送给客户端)

func (*KcpConnection) Stop

func (c *KcpConnection) Stop()

Stop stops the connection and ends the current connection state. (停止连接,结束当前连接状态)

type MsgHandle

type MsgHandle struct {
	// A map property that stores the processing methods for each MsgID
	// (存放每个MsgID 所对应的处理方法的map属性)
	Apis map[uint32]ziface.IRouter

	// The number of worker goroutines in the business work Worker pool
	// (业务工作Worker池的数量)
	WorkerPoolSize uint32

	// A message queue for workers to take tasks
	// (Worker负责取任务的消息队列)
	TaskQueue []chan ziface.IRequest

	RouterSlices *RouterSlices
	// contains filtered or unexported fields
}

MsgHandle is the module for handling message processing callbacks (对消息的处理回调模块)

func (*MsgHandle) AddInterceptor

func (mh *MsgHandle) AddInterceptor(interceptor ziface.IInterceptor)

func (*MsgHandle) AddRouter

func (mh *MsgHandle) AddRouter(msgID uint32, router ziface.IRouter)

AddRouter adds specific processing logic for messages (为消息添加具体的处理逻辑)

func (*MsgHandle) AddRouterSlices

func (mh *MsgHandle) AddRouterSlices(msgId uint32, handler ...ziface.RouterHandler) ziface.IRouterSlices

AddRouterSlices adds router handlers using slices (切片路由添加)

func (*MsgHandle) Execute

func (mh *MsgHandle) Execute(request ziface.IRequest)

func (*MsgHandle) Group

func (mh *MsgHandle) Group(start, end uint32, Handlers ...ziface.RouterHandler) ziface.IGroupRouterSlices

Group routes into a group (路由分组)

func (*MsgHandle) Intercept

func (mh *MsgHandle) Intercept(chain ziface.IChain) ziface.IcResp

Data processing interceptor that is necessary by default in Zinx (Zinx默认必经的数据处理拦截器)

func (*MsgHandle) SendMsgToTaskQueue

func (mh *MsgHandle) SendMsgToTaskQueue(request ziface.IRequest)

SendMsgToTaskQueue sends the message to the TaskQueue for processing by the worker (将消息交给TaskQueue,由worker进行处理)

func (*MsgHandle) SetHeadInterceptor

func (mh *MsgHandle) SetHeadInterceptor(interceptor ziface.IInterceptor)

SetHeadInterceptor sets the head interceptor of the responsibility chain, which is the first interceptor to be executed (SetHeadInterceptor 设置责任链的头拦截器,也就是第一个要执行的拦截器) will replace the default head interceptor

func (*MsgHandle) StartOneWorker

func (mh *MsgHandle) StartOneWorker(workerID int, taskQueue chan ziface.IRequest)

StartOneWorker starts a worker workflow (启动一个Worker工作流程)

func (*MsgHandle) StartWorkerPool

func (mh *MsgHandle) StartWorkerPool()

StartWorkerPool starts the worker pool

func (*MsgHandle) Use

func (mh *MsgHandle) Use(Handlers ...ziface.RouterHandler) ziface.IRouterSlices

type Option

type Option func(s *Server)

Options for Server (Server的服务Option)

func WithPacket

func WithPacket(pack ziface.IDataPack) Option

Implement custom data packet format by implementing the Packet interface, otherwise use the default data packet format (只要实现Packet 接口可自由实现数据包解析格式,如果没有则使用默认解析格式)

type Request

type Request struct {
	ziface.BaseRequest
	// contains filtered or unexported fields
}

Request 请求

func (*Request) Abort

func (r *Request) Abort()

func (*Request) BindRouter

func (r *Request) BindRouter(router ziface.IRouter)

func (*Request) BindRouterSlices

func (r *Request) BindRouterSlices(handlers []ziface.RouterHandler)

BindRouterSlices New version

func (*Request) Call

func (r *Request) Call()

func (*Request) Copy

func (r *Request) Copy() ziface.IRequest

Copy 在执行路由函数的时候可能会出现需要再起一个协程的需求,但是 Request 对象由对象池管理后无法保证新协程中的 Request 参数一致 通过 Copy 方法复制一份 Request 对象保持创建协程时候的参数一致。但新开的协程不应该在对原始的执行过程有影响,所以不包含连接和路由对象。 但如果一定对连接信息有所需要可以在 Copy 后手动 set 一份参数在 Request 对象中

func (*Request) Get

func (r *Request) Get(key string) (value interface{}, exists bool)

Get 在 Request 中取出一个上下文信息

func (*Request) GetConnection

func (r *Request) GetConnection() ziface.IConnection

func (*Request) GetData

func (r *Request) GetData() []byte

func (*Request) GetMessage

func (r *Request) GetMessage() ziface.IMessage

func (*Request) GetMsgID

func (r *Request) GetMsgID() uint32

func (*Request) GetResponse

func (r *Request) GetResponse() ziface.IcResp

func (*Request) Goto

func (r *Request) Goto(step ziface.HandleStep)

func (*Request) Reset

func (r *Request) Reset(conn ziface.IConnection, msg ziface.IMessage)

func (*Request) RouterSlicesNext

func (r *Request) RouterSlicesNext()

func (*Request) Set

func (r *Request) Set(key string, value interface{})

Set 在 Request 中存放一个上下文,如果 keys 为空会实例化一个

func (*Request) SetResponse

func (r *Request) SetResponse(response ziface.IcResp)

type RequestFunc

type RequestFunc struct {
	ziface.BaseRequest
	// contains filtered or unexported fields
}

func (*RequestFunc) CallFunc

func (rf *RequestFunc) CallFunc()

func (*RequestFunc) GetConnection

func (rf *RequestFunc) GetConnection() ziface.IConnection

type RouterSlices

type RouterSlices struct {
	Apis     map[uint32][]ziface.RouterHandler
	Handlers []ziface.RouterHandler
	sync.RWMutex
}

func NewRouterSlices

func NewRouterSlices() *RouterSlices

func (*RouterSlices) AddHandler

func (r *RouterSlices) AddHandler(msgId uint32, Handlers ...ziface.RouterHandler)

func (*RouterSlices) GetHandlers

func (r *RouterSlices) GetHandlers(MsgId uint32) ([]ziface.RouterHandler, bool)

func (*RouterSlices) Group

func (r *RouterSlices) Group(start, end uint32, Handlers ...ziface.RouterHandler) ziface.IGroupRouterSlices

func (*RouterSlices) Use

func (r *RouterSlices) Use(handles ...ziface.RouterHandler)

type Server

type Server struct {
	// Name of the server (服务器的名称)
	Name string
	//tcp4 or other
	IPVersion string
	// IP version (e.g. "tcp4") - 服务绑定的IP地址
	IP string
	// IP address the server is bound to (服务绑定的端口)
	Port int
	// 服务绑定的websocket 端口 (Websocket port the server is bound to)
	WsPort int
	// 服务绑定的kcp 端口 (kcp port the server is bound to)
	KcpPort int

	// Routing mode (路由模式)
	RouterSlicesMode bool
	// Request 对象池模式
	RequestPoolMode bool
	// Current server's connection manager (当前Server的链接管理器)
	ConnMgr ziface.IConnManager
	// contains filtered or unexported fields
}

Server interface implementation, defines a Server service class (接口实现,定义一个Server服务类)

func (*Server) AddInterceptor

func (s *Server) AddInterceptor(interceptor ziface.IInterceptor)

func (*Server) AddRouter

func (s *Server) AddRouter(msgID uint32, router ziface.IRouter)

func (*Server) AddRouterSlices

func (s *Server) AddRouterSlices(msgID uint32, router ...ziface.RouterHandler) ziface.IRouterSlices

func (*Server) GetConnMgr

func (s *Server) GetConnMgr() ziface.IConnManager

func (*Server) GetHeartBeat

func (s *Server) GetHeartBeat() ziface.IHeartbeatChecker

func (*Server) GetLengthField

func (s *Server) GetLengthField() *ziface.LengthField

func (*Server) GetMsgHandler

func (s *Server) GetMsgHandler() ziface.IMsgHandle

func (*Server) GetOnConnStart

func (s *Server) GetOnConnStart() func(ziface.IConnection)

func (*Server) GetOnConnStop

func (s *Server) GetOnConnStop() func(ziface.IConnection)

func (*Server) GetPacket

func (s *Server) GetPacket() ziface.IDataPack

func (*Server) Group

func (s *Server) Group(start, end uint32, Handlers ...ziface.RouterHandler) ziface.IGroupRouterSlices

func (*Server) ListenKcpConn

func (s *Server) ListenKcpConn()

func (*Server) ListenTcpConn

func (s *Server) ListenTcpConn()

func (*Server) ListenWebsocketConn

func (s *Server) ListenWebsocketConn()

func (*Server) Serve

func (s *Server) Serve()

Serve runs the server (运行服务)

func (*Server) ServerName

func (s *Server) ServerName() string

func (*Server) SetDecoder

func (s *Server) SetDecoder(decoder ziface.IDecoder)

func (*Server) SetOnConnStart

func (s *Server) SetOnConnStart(hookFunc func(ziface.IConnection))

func (*Server) SetOnConnStop

func (s *Server) SetOnConnStop(hookFunc func(ziface.IConnection))

func (*Server) SetPacket

func (s *Server) SetPacket(packet ziface.IDataPack)

func (*Server) SetWebsocketAuth

func (s *Server) SetWebsocketAuth(f func(r *http.Request) error)

func (*Server) Start

func (s *Server) Start()

Start the network service (开启网络服务)

func (*Server) StartConn

func (s *Server) StartConn(conn ziface.IConnection)

func (*Server) StartHeartBeat

func (s *Server) StartHeartBeat(interval time.Duration)

StartHeartBeat starts the heartbeat check. interval is the time interval between each heartbeat. (启动心跳检测 interval 每次发送心跳的时间间隔)

func (*Server) StartHeartBeatWithOption

func (s *Server) StartHeartBeatWithOption(interval time.Duration, option *ziface.HeartBeatOption)

StartHeartBeatWithOption starts the heartbeat detection with the given configuration. interval is the time interval for sending heartbeat messages. option is the configuration for heartbeat detection. 启动心跳检测 (option 心跳检测的配置)

func (*Server) Stop

func (s *Server) Stop()

Stop stops the server (停止服务)

func (*Server) Use

func (s *Server) Use(Handlers ...ziface.RouterHandler) ziface.IRouterSlices

type WsConnection

type WsConnection struct {
	// contains filtered or unexported fields
}

WsConnection is a module for handling the read and write operations of a WebSocket connection. (Websocket连接模块, 用于处理 Websocket 连接的读写业务 一个连接对应一个Connection)

func (*WsConnection) AddCloseCallback

func (s *WsConnection) AddCloseCallback(handler, key interface{}, f func())

func (*WsConnection) Context

func (c *WsConnection) Context() context.Context

Context returns the context for the connection, which can be used by user-defined goroutines to get the connection exit status. (返回ctx,用于用户自定义的go程获取连接退出状态)

func (*WsConnection) GetConnID

func (c *WsConnection) GetConnID() uint64

func (*WsConnection) GetConnIdStr

func (c *WsConnection) GetConnIdStr() string

func (*WsConnection) GetConnection

func (c *WsConnection) GetConnection() net.Conn

func (*WsConnection) GetMsgHandler

func (c *WsConnection) GetMsgHandler() ziface.IMsgHandle

func (*WsConnection) GetName

func (c *WsConnection) GetName() string

func (*WsConnection) GetProperty

func (c *WsConnection) GetProperty(key string) (interface{}, error)

func (*WsConnection) GetTCPConnection deprecated

func (c *WsConnection) GetTCPConnection() net.Conn

Deprecated: use GetConnection instead

func (*WsConnection) GetWorkerID

func (c *WsConnection) GetWorkerID() uint32

func (*WsConnection) GetWsConn

func (c *WsConnection) GetWsConn() *websocket.Conn

func (*WsConnection) InvokeCloseCallbacks

func (s *WsConnection) InvokeCloseCallbacks()

func (*WsConnection) IsAlive

func (c *WsConnection) IsAlive() bool

func (*WsConnection) LocalAddr

func (c *WsConnection) LocalAddr() net.Addr

func (*WsConnection) LocalAddrString

func (c *WsConnection) LocalAddrString() string

func (*WsConnection) RemoteAddr

func (c *WsConnection) RemoteAddr() net.Addr

func (*WsConnection) RemoteAddrString

func (c *WsConnection) RemoteAddrString() string

func (*WsConnection) RemoveCloseCallback

func (s *WsConnection) RemoveCloseCallback(handler, key interface{})

func (*WsConnection) RemoveProperty

func (c *WsConnection) RemoveProperty(key string)

func (*WsConnection) Send

func (c *WsConnection) Send(data []byte) error

func (*WsConnection) SendBuffMsg

func (c *WsConnection) SendBuffMsg(msgID uint32, data []byte) error

SendBuffMsg sends BuffMsg

func (*WsConnection) SendMsg

func (c *WsConnection) SendMsg(msgID uint32, data []byte) error

SendMsg directly sends the Message data to the remote TCP client. (直接将Message数据发送数据给远程的TCP客户端)

func (*WsConnection) SendToQueue

func (c *WsConnection) SendToQueue(data []byte) error

func (*WsConnection) SetHeartBeat

func (c *WsConnection) SetHeartBeat(checker ziface.IHeartbeatChecker)

func (*WsConnection) SetProperty

func (c *WsConnection) SetProperty(key string, value interface{})

func (*WsConnection) Start

func (c *WsConnection) Start()

Start starts the connection and makes it work. (Start 启动连接,让当前连接开始工作)

func (*WsConnection) StartReader

func (c *WsConnection) StartReader()

StartReader is a Goroutine that reads messages from the client. (StartReader 读消息Goroutine,用于从客户端中读取数据)

func (*WsConnection) StartWriter

func (c *WsConnection) StartWriter()

StartWriter is a Goroutine that sends messages to the client (StartWriter 写消息Goroutine, 用户将数据发送给客户端)

func (*WsConnection) Stop

func (c *WsConnection) Stop()

Stop stops the connection and ends its current state. (停止连接,结束当前连接状态)

Jump to

Keyboard shortcuts

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