netService

package
v1.3.1 Latest Latest
Warning

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

Go to latest
Published: Sep 8, 2021 License: Apache-2.0 Imports: 12 Imported by: 0

Documentation

Index

Constants

This section is empty.

Variables

This section is empty.

Functions

func NewConnManager

func NewConnManager() netInterface.IConnManager

实例化管理

func NewService

func NewService(config *Config) netInterface.IService

初始化

Types

type AcceptTask

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

连接接入任务

func (*AcceptTask) CallOutTime

func (a *AcceptTask) CallOutTime()

超时回调

func (*AcceptTask) GetTaskId

func (a *AcceptTask) GetTaskId() uint64

获取连接id

func (*AcceptTask) RunTask

func (a *AcceptTask) RunTask() int

处理数据

type Config

type Config struct {
	Scheme               string        //网络:ws,wss
	AddrAry              []string      //监听地址和端口:绑定的IP加端口:["192.168.1.24:7018",...]
	PathAry              []string      //监听路径
	ReceiveWorkerSize    uint          //(上行处理)工作池中工作线程个数
	ReceiveTaskQueueSize uint          //(上行处理)单个工作队列缓存任务大小
	ReceiveOutTime       time.Duration //(上行处理)处理任务超时时间 ,IsOutTime=true 时生效
	ReplyWorkerSize      uint          //(下行处理)工作池中工作线程个数
	ReplyTaskQueueSize   uint          //(下行处理)单个工作队列缓存任务大小
	ReplyOutTime         time.Duration //(下行处理)超时时间(完整任务) ,IsOutTime=true 时生效
	AcceptWorkerSize     uint          //(连接接入处理)工作池中工作线程个数
	AcceptTaskQueueSize  uint          //(连接接入处理)单个工作队列缓存任务大小
	AcceptOutTime        time.Duration //(连接接入处理)超时时间,IsOutTime=true 时生效
	RBufferSize          int           //读缓存尺寸(字节)
	WBufferSize          int           //写缓存尺寸(字节)
	SendOutTime          time.Duration //下行超时时间(秒)
	CertFile             string        //TLS安全连接文件【wss使用】
	KeyFile              string        //TLS安全连接key【wss使用】
	IsOutTime            bool          //是否需要支持超时
}

配置

func DefaultConfig

func DefaultConfig(scheme string, addrAry []string, pathAry []string) *Config

默认配置

type ConnManager

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

连接管理模块

func (*ConnManager) Add

func (c *ConnManager) Add(conn netInterface.IConnection)

添加链接

func (*ConnManager) ClearConn

func (c *ConnManager) ClearConn()

清除并停止所有连接

func (*ConnManager) Count

func (c *ConnManager) Count() int

获取个数

func (*ConnManager) Get

func (c *ConnManager) Get(connID uint64) (netInterface.IConnection, bool)

利用ConnID获取链接

func (*ConnManager) Range

func (c *ConnManager) Range(hFunc func(key uint64, value netInterface.IConnection) bool)

遍历连接

func (*ConnManager) Remove

func (c *ConnManager) Remove(conn netInterface.IConnection)

删除连接

type Connection

type Connection struct {
	Conn   *websocket.Conn //当前连接的ws
	ConnID uint64          //连接id
	// contains filtered or unexported fields
}

连接

func NewConnection

func NewConnection(server *Service, conn *websocket.Conn, connID uint64, path string, receiveHandler pools.ITaskWorkerPool, replyHandle pools.ITaskWorkerPool, config *Config) *Connection

初始化连接方法

func (*Connection) CallLogHandle

func (c *Connection) CallLogHandle(level netInterface.ErrLevel, msgAry ...interface{})

调用异常处理

func (*Connection) GetConnId

func (c *Connection) GetConnId() uint64

获取客户端ID

func (*Connection) GetHeartTime

func (c *Connection) GetHeartTime() time.Time

心跳时间

func (*Connection) GetIsClosed

func (c *Connection) GetIsClosed() bool

是否关闭

func (*Connection) GetLocalAddr

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

获取本地地址

func (*Connection) GetNetConn

func (c *Connection) GetNetConn() interface{}

获取连接

func (*Connection) GetPath

func (c *Connection) GetPath() string

获取路径

func (*Connection) GetProperty

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

获取连接属性

func (*Connection) GetPropertyKeys added in v1.3.1

func (c *Connection) GetPropertyKeys() []string

获取所有属性key

func (*Connection) GetRecInfo

func (c *Connection) GetRecInfo() (count, byteSize uint64)

上行当前处理的包总数(处理前,1开始),总大小(字节)

func (*Connection) GetRemoteAddr

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

获取远程客户端地址信息

func (*Connection) GetRepInfo

func (c *Connection) GetRepInfo() (count, byteSize, errCount uint64)

下行当前处理的包总数(处理后),总大小(字节)

func (*Connection) GetStartTime

func (c *Connection) GetStartTime() time.Time

连接启动时间

func (*Connection) OnReceive added in v1.3.1

func (c *Connection) OnReceive(messageType int, data []byte)

数据上传了完整一包的回调

func (*Connection) RemoveProperty

func (c *Connection) RemoveProperty(key string)

移除设置属性

func (*Connection) SendData

func (c *Connection) SendData(msgType int, data []byte) error

直接将Message数据发送数据给远程的TCP客户端消息类型 1.TextMessage(文本) 2、BinaryMessage(二进制)

func (*Connection) SendDataCall

func (c *Connection) SendDataCall(msgType int, data []byte, param interface{}, callFunc func(netInterface.IConnection, bool, interface{}, error)) error

直接将Message数据发送数据给远程的TCP客户端(带参数和回调)消息类型 1.TextMessage(文本) 2、BinaryMessage(二进制)

func (*Connection) SetProperty

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

设置连接属性

func (*Connection) Start

func (c *Connection) Start()

启动连接,让当前连接,开始工作

func (*Connection) StartReader

func (c *Connection) StartReader()

读业务

func (*Connection) Stop

func (c *Connection) Stop()

停止连接,结束当前连接工作

type ReceiveTask

type ReceiveTask struct {
	OnReceive func(int, []byte)
	// contains filtered or unexported fields
}

客户端请求内容

func (*ReceiveTask) CallOutTime

func (r *ReceiveTask) CallOutTime()

超时回调

func (*ReceiveTask) GetTaskId

func (r *ReceiveTask) GetTaskId() uint64

获取连接id

func (*ReceiveTask) RunTask

func (r *ReceiveTask) RunTask() int

处理数据

type ReplyTask

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

回复任务

func (*ReplyTask) CallOutTime

func (r *ReplyTask) CallOutTime()

任务超时

func (*ReplyTask) GetTaskId

func (r *ReplyTask) GetTaskId() uint64

获取连接ID

func (*ReplyTask) RunTask

func (r *ReplyTask) RunTask() int

运行

type Service

type Service struct {
	ConnMgr     netInterface.IConnManager                                               //连接属性
	OnConnAuth  func(netInterface.IConnection, http.ResponseWriter, *http.Request) bool //连接建立前验证(true:成功,false:失败,关闭连接)
	OnConnStart func(netInterface.IConnection)                                          //连接完成回调
	OnConnStop  func(netInterface.IConnection)                                          //关闭回调

	AcceptHandle pools.ITaskWorkerPool //连接处理池
	// contains filtered or unexported fields
}

服务

func (*Service) AddConnId

func (s *Service) AddConnId() uint64

累加并获取自增ID

func (*Service) CallLogHandle

func (s *Service) CallLogHandle(level netInterface.ErrLevel, msgAry ...interface{})

错误消息处理

func (*Service) CallOnConnStart

func (s *Service) CallOnConnStart(conn netInterface.IConnection)

调用连接之前

func (*Service) CallOnConnStop

func (s *Service) CallOnConnStop(conn netInterface.IConnection)

调用关闭之前

func (*Service) CallOnOneReceive added in v1.3.1

func (s *Service) CallOnOneReceive(conn netInterface.IConnection, msgType int, data []byte)

[第一包]数据上传完成回调

func (*Service) CallOnReceive added in v1.3.1

func (s *Service) CallOnReceive(conn netInterface.IConnection, msgType int, data []byte)

数据上传完成回调

func (*Service) CallOnReply added in v1.3.1

func (s *Service) CallOnReply(conn netInterface.IConnection, msgType int, data []byte, param interface{}, ok bool, err error)

下发后回调

func (*Service) GetAcceptQueueCount

func (s *Service) GetAcceptQueueCount() (count int64, totalCount, outTimeCount uint64)

获取连接接入队列剩余数

func (*Service) GetConn

func (s *Service) GetConn(connId uint64) (netInterface.IConnection, bool)

获取连接

func (*Service) GetConnMgr

func (s *Service) GetConnMgr() netInterface.IConnManager

得到链接管理

func (*Service) GetRecInfo

func (s *Service) GetRecInfo() (count, byteSize uint64)

上行当前处理的包总数(处理前,1开始),总大小(字节)

func (*Service) GetRepInfo

func (s *Service) GetRepInfo() (count, byteSize, errCount uint64)

下行当前处理的包总数(处理后),总大小(字节),异常数

func (*Service) GetStartTime

func (s *Service) GetStartTime() time.Time

获取连接启动时间

func (*Service) GetTotalQueueCount

func (s *Service) GetTotalQueueCount() (receiveCount int64, receiveTotalCount, receiveOutTimeCount uint64, replyCount int64, replyTotalCount, replyOutTimeCount uint64)

获取队列剩余数

func (*Service) SetLogHandle

func (s *Service) SetLogHandle(hookFunc func(level netInterface.ErrLevel, msg ...interface{}))

设置日志处理

func (*Service) SetOnConnAuth added in v1.3.1

func (s *Service) SetOnConnAuth(hookStart func(conn netInterface.IConnection, w http.ResponseWriter, r *http.Request) bool)

连接之前回调

func (*Service) SetOnConnStart

func (s *Service) SetOnConnStart(hookStart func(conn netInterface.IConnection))

连接完成回调

func (*Service) SetOnConnStop

func (s *Service) SetOnConnStop(hookStop func(conn netInterface.IConnection))

关闭之前回调

func (*Service) SetOnOneReceive added in v1.3.1

func (s *Service) SetOnOneReceive(hookFunc func(netInterface.IConnection, int, []byte))

【第一包数据】数据上传完成处理函数[分包后]

func (*Service) SetOnReceive added in v1.3.1

func (s *Service) SetOnReceive(hookFunc func(netInterface.IConnection, int, []byte))

数据上传完成处理函数[分包后]

func (*Service) SetOnReply added in v1.3.1

func (s *Service) SetOnReply(hookFunc func(netInterface.IConnection, int, []byte, interface{}, bool, error))

数据回复完成后处理函数

func (*Service) Start

func (s *Service) Start()

启动

func (*Service) Stop

func (s *Service) Stop()

停止

Jump to

Keyboard shortcuts

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