基本介绍

gtcp 模块实现简便易用、轻量级的 TCPServer 服务端。

使用方式

  1. import "github.com/gogf/gf/v2/net/gtcp"

接口文档https://pkg.go.dev/github.com/gogf/gf/v2/net/gtcp

  1. type Server
  2. func GetServer(name ...interface{}) *Server
  3. func NewServer(address string, handler func(*Conn), name ...string) *Server
  4. func NewServerKeyCrt(address, crtFile, keyFile string, handler func(*Conn), name ...string) *Server
  5. func NewServerTLS(address string, tlsConfig *tls.Config, handler func(*Conn), name ...string) *Server
  6. func (s *Server) Close() error
  7. func (s *Server) Run() (err error)
  8. func (s *Server) SetAddress(address string)
  9. func (s *Server) SetHandler(handler func(*Conn))
  10. func (s *Server) SetTLSConfig(tlsConfig *tls.Config)
  11. func (s *Server) SetTLSKeyCrt(crtFile, keyFile string) error

其中, GetServer 使用单例模式通过给定一个唯一的名称获取/创建一个单例 Server,后续可通过 SetAddressSetHandler 方法动态修改Server属性; NewServer 则直接根据给定参数创建一个Server对象,并可指定名称。

我们通过实现一个简单的 echo服务器 来演示 TCPServer 的使用:

  1. package main
  2. import (
  3. "fmt"
  4. "github.com/gogf/gf/v2/net/gtcp"
  5. )
  6. func main() {
  7. gtcp.NewServer("127.0.0.1:8999", func(conn *gtcp.Conn) {
  8. defer conn.Close()
  9. for {
  10. data, err := conn.Recv(-1)
  11. if len(data) > 0 {
  12. if err := conn.Send(append([]byte("> "), data...)); err != nil {
  13. fmt.Println(err)
  14. }
  15. }
  16. if err != nil {
  17. break
  18. }
  19. }
  20. }).Run()
  21. }

在这个示例中我们使用了 SendRecv 来发送和接收数据。其中 Recv 方法会通过阻塞方式接收数据,直到客户端”发送完毕一条数据”(执行一次 Send,底层Socket通信不带缓冲实现),或者关闭链接。关于其中的链接对象 gtcp.Conn 的介绍,请继续阅读后续章节。

执行之后我们使用 telnet 工具来进行测试:

  1. john@home:~$ telnet 127.0.0.1 8999
  2. Trying 127.0.0.1...
  3. Connected to 127.0.0.1.
  4. Escape character is '^]'.
  5. hello
  6. > hello
  7. hi there
  8. > hi there

每一个客户端发起的TCP链接,TCPServer都会创建一个 goroutine 进行处理,直至TCP链接断开。由于goroutine比较轻量级,因此可以支撑很高的并发量。

相关文档

🗃️ TCP组件-连接对象2 个项目

📄️ TCP组件-工具方法GoFrame框架中的gtcp模块和一些常用的工具方法,通过这些方法可以实现TCP连接的创建、TLS安全加密通信以及数据发送和接收的功能,并提供了一个具体示例展示如何通过TCP访问指定的Web站点。

📄️ TCP组件-TLS加密使用GoFrame框架的gtcp模块在安全性要求较高的环境中实现TLS加密通信。通过提供的示例代码,我们讲解了如何创建TLS服务端和客户端,如何使用证书进行数据加密传输,以及如何处理可能出现的证书过期问题。这对于需要安全传输数据的开发者来说至关重要。

📄️ TCP组件-连接池特性GoFrame框架中的gtcp模块连接池特性,通过gtcp.PoolConn实现的连接池具有600秒的固定存活时间,并具备数据发送时的断开重连机制,适用于频繁短链接操作和高连接并发的场景。文章提供了两个示例,演示了连接池的基础使用及断开重连操作,帮助用户深刻理解连接池在网络编程中的实际应用。