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.

118 lines
2.8 KiB

  1. package znet
  2. import (
  3. "fmt"
  4. "net"
  5. "time"
  6. "zinx/utils"
  7. "zinx/ziface"
  8. )
  9. //iServer 接口实现,定义一个Server服务类
  10. type Server struct {
  11. //服务器的名称
  12. Name string
  13. //tcp4 or other
  14. IPVersion string
  15. //服务绑定的IP地址
  16. IP string
  17. //服务绑定的端口
  18. Port int
  19. //当前Server由用户绑定的回调router,也就是Server注册的链接对应的处理业务
  20. Router ziface.IRouter
  21. }
  22. /*
  23. 创建一个服务器句柄
  24. */
  25. func NewServer () ziface.IServer {
  26. utils.GlobalObject.Reload()
  27. s:= &Server {
  28. Name :utils.GlobalObject.Name,
  29. IPVersion:"tcp4",
  30. IP:utils.GlobalObject.Host,
  31. Port:utils.GlobalObject.TcpPort,
  32. Router: nil,
  33. }
  34. return s
  35. }
  36. //============== 实现 ziface.IServer 里的全部接口方法 ========
  37. //开启网络服务
  38. func (s *Server) Start() {
  39. fmt.Printf("[START] Server name: %s,listenner at IP: %s, Port %d is starting\n", s.Name, s.IP, s.Port)
  40. fmt.Printf("[Zinx] Version: %s, MaxConn: %d, MaxPacketSize: %d\n",
  41. utils.GlobalObject.Version,
  42. utils.GlobalObject.MaxConn,
  43. utils.GlobalObject.MaxPacketSize)
  44. //开启一个go去做服务端Linster业务
  45. go func() {
  46. //1 获取一个TCP的Addr
  47. addr, err := net.ResolveTCPAddr(s.IPVersion, fmt.Sprintf("%s:%d", s.IP, s.Port))
  48. if err != nil {
  49. fmt.Println("resolve tcp addr err: ", err)
  50. return
  51. }
  52. //2 监听服务器地址
  53. listenner, err:= net.ListenTCP(s.IPVersion, addr)
  54. if err != nil {
  55. fmt.Println("listen", s.IPVersion, "err", err)
  56. return
  57. }
  58. //已经监听成功
  59. fmt.Println("start Zinx server ", s.Name, " succ, now listenning...")
  60. //TODO server.go 应该有一个自动生成ID的方法
  61. var cid uint32
  62. cid = 0
  63. //3 启动server网络连接业务
  64. for {
  65. //3.1 阻塞等待客户端建立连接请求
  66. conn, err := listenner.AcceptTCP()
  67. if err != nil {
  68. fmt.Println("Accept err ", err)
  69. continue
  70. }
  71. //3.2 TODO Server.Start() 设置服务器最大连接控制,如果超过最大连接,那么则关闭此新的连接
  72. //3.3 处理该新连接请求的 业务 方法, 此时应该有 handler 和 conn是绑定的
  73. dealConn := NewConntion(conn, cid, s.Router)
  74. cid ++
  75. //3.4 启动当前链接的处理业务
  76. go dealConn.Start()
  77. }
  78. }()
  79. }
  80. func (s *Server) Stop() {
  81. fmt.Println("[STOP] Zinx server , name " , s.Name)
  82. //TODO Server.Stop() 将其他需要清理的连接信息或者其他信息 也要一并停止或者清理
  83. }
  84. func (s *Server) Serve() {
  85. s.Start()
  86. //TODO Server.Serve() 是否在启动服务的时候 还要处理其他的事情呢 可以在这里添加
  87. //阻塞,否则主Go退出, listenner的go将会退出
  88. for {
  89. time.Sleep(10*time.Second)
  90. }
  91. }
  92. //路由功能:给当前服务注册一个路由业务方法,供客户端链接处理使用
  93. func (s *Server)AddRouter(router ziface.IRouter) {
  94. s.Router = router
  95. fmt.Println("Add Router succ! " )
  96. }