You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

163 lines
4.0 KiB

  1. package znet
  2. import (
  3. "fmt"
  4. "net"
  5. "zinx/utils"
  6. "zinx/ziface"
  7. )
  8. //iServer 接口实现,定义一个Server服务类
  9. type Server struct {
  10. //服务器的名称
  11. Name string
  12. //tcp4 or other
  13. IPVersion string
  14. //服务绑定的IP地址
  15. IP string
  16. //服务绑定的端口
  17. Port int
  18. //当前Server的消息管理模块,用来绑定MsgId和对应的处理方法
  19. msgHandler ziface.IMsgHandle
  20. //当前Server的链接管理器
  21. ConnMgr ziface.IConnManager
  22. //该Server的连接创建时Hook函数
  23. OnConnStart func(conn ziface.IConnection)
  24. //该Server的连接断开时的Hook函数
  25. OnConnStop func(conn ziface.IConnection)
  26. }
  27. /*
  28. 创建一个服务器句柄
  29. */
  30. func NewServer () ziface.IServer {
  31. utils.GlobalObject.Reload()
  32. s:= &Server {
  33. Name :utils.GlobalObject.Name,
  34. IPVersion:"tcp4",
  35. IP:utils.GlobalObject.Host,
  36. Port:utils.GlobalObject.TcpPort,
  37. msgHandler: NewMsgHandle(),
  38. ConnMgr:NewConnManager(),
  39. }
  40. return s
  41. }
  42. //============== 实现 ziface.IServer 里的全部接口方法 ========
  43. //开启网络服务
  44. func (s *Server) Start() {
  45. fmt.Printf("[START] Server name: %s,listenner at IP: %s, Port %d is starting\n", s.Name, s.IP, s.Port)
  46. fmt.Printf("[Zinx] Version: %s, MaxConn: %d, MaxPacketSize: %d\n",
  47. utils.GlobalObject.Version,
  48. utils.GlobalObject.MaxConn,
  49. utils.GlobalObject.MaxPacketSize)
  50. //开启一个go去做服务端Linster业务
  51. go func() {
  52. //0 启动worker工作池机制
  53. s.msgHandler.StartWorkerPool()
  54. //1 获取一个TCP的Addr
  55. addr, err := net.ResolveTCPAddr(s.IPVersion, fmt.Sprintf("%s:%d", s.IP, s.Port))
  56. if err != nil {
  57. fmt.Println("resolve tcp addr err: ", err)
  58. return
  59. }
  60. //2 监听服务器地址
  61. listenner, err:= net.ListenTCP(s.IPVersion, addr)
  62. if err != nil {
  63. fmt.Println("listen", s.IPVersion, "err", err)
  64. return
  65. }
  66. //已经监听成功
  67. fmt.Println("start Zinx server ", s.Name, " succ, now listenning...")
  68. //TODO server.go 应该有一个自动生成ID的方法
  69. var cid uint32
  70. cid = 0
  71. //3 启动server网络连接业务
  72. for {
  73. //3.1 阻塞等待客户端建立连接请求
  74. conn, err := listenner.AcceptTCP()
  75. if err != nil {
  76. fmt.Println("Accept err ", err)
  77. continue
  78. }
  79. fmt.Println("Get conn remote addr = ", conn.RemoteAddr().String())
  80. //3.2 设置服务器最大连接控制,如果超过最大连接,那么则关闭此新的连接
  81. if s.ConnMgr.Len() >= utils.GlobalObject.MaxConn {
  82. conn.Close()
  83. continue
  84. }
  85. //3.3 处理该新连接请求的 业务 方法, 此时应该有 handler 和 conn是绑定的
  86. dealConn := NewConntion(s, conn, cid, s.msgHandler)
  87. cid ++
  88. //3.4 启动当前链接的处理业务
  89. go dealConn.Start()
  90. }
  91. }()
  92. }
  93. //停止服务
  94. func (s *Server) Stop() {
  95. fmt.Println("[STOP] Zinx server , name " , s.Name)
  96. //将其他需要清理的连接信息或者其他信息 也要一并停止或者清理
  97. s.ConnMgr.ClearConn()
  98. }
  99. //运行服务
  100. func (s *Server) Serve() {
  101. s.Start()
  102. //TODO Server.Serve() 是否在启动服务的时候 还要处理其他的事情呢 可以在这里添加
  103. //阻塞,否则主Go退出, listenner的go将会退出
  104. select{}
  105. }
  106. //路由功能:给当前服务注册一个路由业务方法,供客户端链接处理使用
  107. func (s *Server)AddRouter(msgId uint32, router ziface.IRouter) {
  108. s.msgHandler.AddRouter(msgId, router)
  109. }
  110. //得到链接管理
  111. func (s *Server) GetConnMgr() ziface.IConnManager {
  112. return s.ConnMgr
  113. }
  114. //设置该Server的连接创建时Hook函数
  115. func (s *Server) SetOnConnStart(hookFunc func (ziface.IConnection)) {
  116. s.OnConnStart = hookFunc
  117. }
  118. //设置该Server的连接断开时的Hook函数
  119. func (s *Server) SetOnConnStop(hookFunc func (ziface.IConnection)) {
  120. s.OnConnStop = hookFunc
  121. }
  122. //调用连接OnConnStart Hook函数
  123. func (s *Server) CallOnConnStart(conn ziface.IConnection) {
  124. if s.OnConnStart != nil {
  125. fmt.Println("---> CallOnConnStart....")
  126. s.OnConnStart(conn)
  127. }
  128. }
  129. //调用连接OnConnStop Hook函数
  130. func (s *Server) CallOnConnStop(conn ziface.IConnection) {
  131. if s.OnConnStop != nil {
  132. fmt.Println("---> CallOnConnStop....")
  133. s.OnConnStop(conn)
  134. }
  135. }