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.

112 lines
2.5 KiB

  1. package znet
  2. import (
  3. "fmt"
  4. "net"
  5. "time"
  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. }
  19. //============== 实现 ziface.IServer 里的全部接口方法 ========
  20. //开启网络服务
  21. func (s *Server) Start() {
  22. fmt.Printf("[START] Server listenner at IP: %s, Port %d, is starting\n", s.IP, s.Port)
  23. //开启一个go去做服务端Linster业务
  24. go func() {
  25. //1 获取一个TCP的Addr
  26. addr, err := net.ResolveTCPAddr(s.IPVersion, fmt.Sprintf("%s:%d", s.IP, s.Port))
  27. if err != nil {
  28. fmt.Println("resolve tcp addr err: ", err)
  29. return
  30. }
  31. //2 监听服务器地址
  32. listenner, err:= net.ListenTCP(s.IPVersion, addr)
  33. if err != nil {
  34. fmt.Println("listen", s.IPVersion, "err", err)
  35. return
  36. }
  37. //已经监听成功
  38. fmt.Println("start Zinx server ", s.Name, " succ, now listenning...")
  39. //3 启动server网络连接业务
  40. for {
  41. //3.1 阻塞等待客户端建立连接请求
  42. conn, err := listenner.AcceptTCP()
  43. if err != nil {
  44. fmt.Println("Accept err ", err)
  45. continue
  46. }
  47. //3.2 TODO Server.Start() 设置服务器最大连接控制,如果超过最大连接,那么则关闭此新的连接
  48. //3.3 TODO Server.Start() 处理该新连接请求的 业务 方法, 此时应该有 handler 和 conn是绑定的
  49. //我们这里暂时做一个最大512字节的回显服务
  50. go func () {
  51. //不断的循环从客户端获取数据
  52. for {
  53. buf := make([]byte, 512)
  54. cnt, err := conn.Read(buf)
  55. if err != nil {
  56. fmt.Println("recv buf err ", err)
  57. continue
  58. }
  59. //回显
  60. if _, err := conn.Write(buf[:cnt]); err !=nil {
  61. fmt.Println("write back buf err ", err)
  62. continue
  63. }
  64. }
  65. }()
  66. }
  67. }()
  68. }
  69. func (s *Server) Stop() {
  70. fmt.Println("[STOP] Zinx server , name " , s.Name)
  71. //TODO Server.Stop() 将其他需要清理的连接信息或者其他信息 也要一并停止或者清理
  72. }
  73. func (s *Server) Serve() {
  74. s.Start()
  75. //TODO Server.Serve() 是否在启动服务的时候 还要处理其他的事情呢 可以在这里添加
  76. //阻塞,否则主Go退出, listenner的go将会退出
  77. for {
  78. time.Sleep(10*time.Second)
  79. }
  80. }
  81. /*
  82. 创建一个服务器句柄
  83. */
  84. func NewServer (name string) ziface.IServer {
  85. s:= &Server {
  86. Name :name,
  87. IPVersion:"tcp4",
  88. IP:"0.0.0.0",
  89. Port:7777,
  90. }
  91. return s
  92. }