|
@ -3,55 +3,49 @@ package znet |
|
|
import ( |
|
|
import ( |
|
|
"errors" |
|
|
"errors" |
|
|
"fmt" |
|
|
"fmt" |
|
|
"sync" |
|
|
|
|
|
|
|
|
"sync/atomic" |
|
|
|
|
|
|
|
|
"github.com/aceld/zinx/ziface" |
|
|
"github.com/aceld/zinx/ziface" |
|
|
) |
|
|
) |
|
|
|
|
|
|
|
|
//ConnManager 连接管理模块
|
|
|
//ConnManager 连接管理模块
|
|
|
type ConnManager struct { |
|
|
type ConnManager struct { |
|
|
connections map[uint32]ziface.IConnection //管理的连接信息
|
|
|
|
|
|
connLock sync.RWMutex //读写连接的读写锁
|
|
|
|
|
|
|
|
|
connections atomic.Value |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
//NewConnManager 创建一个链接管理
|
|
|
//NewConnManager 创建一个链接管理
|
|
|
func NewConnManager() *ConnManager { |
|
|
func NewConnManager() *ConnManager { |
|
|
return &ConnManager{ |
|
|
|
|
|
connections: make(map[uint32]ziface.IConnection), |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
var cm = &ConnManager{} |
|
|
|
|
|
connections := make(map[uint32]ziface.IConnection) |
|
|
|
|
|
cm.connections.Store(connections) |
|
|
|
|
|
return cm |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
//Add 添加链接
|
|
|
//Add 添加链接
|
|
|
func (connMgr *ConnManager) Add(conn ziface.IConnection) { |
|
|
func (connMgr *ConnManager) Add(conn ziface.IConnection) { |
|
|
//保护共享资源Map 加写锁
|
|
|
|
|
|
connMgr.connLock.Lock() |
|
|
|
|
|
defer connMgr.connLock.Unlock() |
|
|
|
|
|
|
|
|
connections:=connMgr.connections.Load().(map[uint32]ziface.IConnection) |
|
|
|
|
|
|
|
|
//将conn连接添加到ConnMananger中
|
|
|
//将conn连接添加到ConnMananger中
|
|
|
connMgr.connections[conn.GetConnID()] = conn |
|
|
|
|
|
|
|
|
connections[conn.GetConnID()] = conn |
|
|
|
|
|
connMgr.connections.Store(connections) |
|
|
|
|
|
|
|
|
fmt.Println("connection add to ConnManager successfully: conn num = ", connMgr.Len()) |
|
|
fmt.Println("connection add to ConnManager successfully: conn num = ", connMgr.Len()) |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
//Remove 删除连接
|
|
|
//Remove 删除连接
|
|
|
func (connMgr *ConnManager) Remove(conn ziface.IConnection) { |
|
|
func (connMgr *ConnManager) Remove(conn ziface.IConnection) { |
|
|
//保护共享资源Map 加写锁
|
|
|
|
|
|
connMgr.connLock.Lock() |
|
|
|
|
|
defer connMgr.connLock.Unlock() |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
connections:=connMgr.connections.Load().(map[uint32]ziface.IConnection) |
|
|
//删除连接信息
|
|
|
//删除连接信息
|
|
|
delete(connMgr.connections, conn.GetConnID()) |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
delete(connections, conn.GetConnID()) |
|
|
|
|
|
connMgr.connections.Store(connections) |
|
|
fmt.Println("connection Remove ConnID=", conn.GetConnID(), " successfully: conn num = ", connMgr.Len()) |
|
|
fmt.Println("connection Remove ConnID=", conn.GetConnID(), " successfully: conn num = ", connMgr.Len()) |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
//Get 利用ConnID获取链接
|
|
|
//Get 利用ConnID获取链接
|
|
|
func (connMgr *ConnManager) Get(connID uint32) (ziface.IConnection, error) { |
|
|
func (connMgr *ConnManager) Get(connID uint32) (ziface.IConnection, error) { |
|
|
//保护共享资源Map 加读锁
|
|
|
|
|
|
connMgr.connLock.RLock() |
|
|
|
|
|
defer connMgr.connLock.RUnlock() |
|
|
|
|
|
|
|
|
connections:=connMgr.connections.Load().(map[uint32]ziface.IConnection) |
|
|
|
|
|
|
|
|
if conn, ok := connMgr.connections[connID]; ok { |
|
|
|
|
|
|
|
|
if conn, ok := connections[connID]; ok { |
|
|
return conn, nil |
|
|
return conn, nil |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
@ -61,37 +55,35 @@ func (connMgr *ConnManager) Get(connID uint32) (ziface.IConnection, error) { |
|
|
|
|
|
|
|
|
//Len 获取当前连接
|
|
|
//Len 获取当前连接
|
|
|
func (connMgr *ConnManager) Len() int { |
|
|
func (connMgr *ConnManager) Len() int { |
|
|
return len(connMgr.connections) |
|
|
|
|
|
|
|
|
connections:=connMgr.connections.Load().(map[uint32]ziface.IConnection) |
|
|
|
|
|
return len(connections) |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
//ClearConn 清除并停止所有连接
|
|
|
//ClearConn 清除并停止所有连接
|
|
|
func (connMgr *ConnManager) ClearConn() { |
|
|
func (connMgr *ConnManager) ClearConn() { |
|
|
//保护共享资源Map 加写锁
|
|
|
|
|
|
connMgr.connLock.Lock() |
|
|
|
|
|
defer connMgr.connLock.Unlock() |
|
|
|
|
|
|
|
|
connections:=connMgr.connections.Load().(map[uint32]ziface.IConnection) |
|
|
|
|
|
|
|
|
//停止并删除全部的连接信息
|
|
|
//停止并删除全部的连接信息
|
|
|
for connID, conn := range connMgr.connections { |
|
|
|
|
|
|
|
|
for connID, conn := range connections { |
|
|
//停止
|
|
|
//停止
|
|
|
conn.Stop() |
|
|
conn.Stop() |
|
|
//删除
|
|
|
//删除
|
|
|
delete(connMgr.connections, connID) |
|
|
|
|
|
|
|
|
delete(connections, connID) |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
connMgr.connections.Store(connections) |
|
|
fmt.Println("Clear All Connections successfully: conn num = ", connMgr.Len()) |
|
|
fmt.Println("Clear All Connections successfully: conn num = ", connMgr.Len()) |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
//ClearOneConn 利用ConnID获取一个链接 并且删除
|
|
|
//ClearOneConn 利用ConnID获取一个链接 并且删除
|
|
|
func (connMgr *ConnManager) ClearOneConn(connID uint32) { |
|
|
func (connMgr *ConnManager) ClearOneConn(connID uint32) { |
|
|
//保护共享资源Map 加写锁
|
|
|
|
|
|
connMgr.connLock.Lock() |
|
|
|
|
|
defer connMgr.connLock.Unlock() |
|
|
|
|
|
|
|
|
connections:=connMgr.connections.Load().(map[uint32]ziface.IConnection) |
|
|
|
|
|
|
|
|
if conn, ok := connMgr.connections[connID]; !ok { |
|
|
|
|
|
|
|
|
if conn, ok := connections[connID]; !ok { |
|
|
//停止
|
|
|
//停止
|
|
|
conn.Stop() |
|
|
conn.Stop() |
|
|
//删除
|
|
|
//删除
|
|
|
delete(connMgr.connections, connID) |
|
|
|
|
|
|
|
|
delete(connections, connID) |
|
|
|
|
|
connMgr.connections.Store(connections) |
|
|
fmt.Println("Clear Connections ID: ", connID, "succeed") |
|
|
fmt.Println("Clear Connections ID: ", connID, "succeed") |
|
|
return |
|
|
return |
|
|
} |
|
|
} |
|
|