Netpoll 是由 字节跳动 开发的高性能 NIO(Non-blocking I/O) 网络库,专注于 RPC 场景。
RPC 通常有较重的处理逻辑,因此无法串行处理 I/O。而 Go 的标准库 net 设计了 BIO(Blocking I/O) 模式的 API,使得 RPC 框架设计上只能为每个连接都分配一个 goroutine。 这在高并发下,会产生大量的 goroutine,大幅增加调度开销。此外,net.Conn 没有提供检查连接活性的 API,因此 RPC 框架很难设计出高效的连接池,池中的失效连接无法及时清理。
另一方面,开源社区目前缺少专注于 RPC 方案的 Go 网络库。类似的项目如:evio , gnet 等,均面向 Redis, Haproxy 这样的场景。
因此 Netpoll 应运而生,它借鉴了 evio 和 netty 的优秀设计,具有出色的 性能,更适用于微服务架构。 同时,Netpoll 还提供了一些 特性,推荐在 RPC 设计中替代 net 。
基于 Netpoll 开发的 RPC 框架 KiteX 和 HTTP 框架 Hertz (即将开源),性能均业界领先。
范例 展示了如何使用 Netpoll 构建 RPC Client 和 Server。
更多信息请参阅 文档。
-
已经支持
- LinkBuffer 提供可以流式读写的 nocopy API
- gopool 提供高性能的 goroutine 池
- mcache 提供高效的内存复用
IsActive
支持检查连接是否存活Dialer
支持构建 clientEventLoop
支持构建 server- 支持 TCP,Unix Domain Socket
- 支持 Linux,Mac OS(操作系统)
-
即将开源
- multisyscall 支持批量系统调用
- io_uring
- Shared Memory IPC
- 串行调度 I/O,适用于纯计算
- 支持 TLS
- 支持 UDP
-
不被支持
- Windows(操作系统)
性能测试并非数字游戏,首先应满足工业级使用要求,在 RPC 场景下,并发请求、等待超时是必要的支持项。
因此我们设定,性能测试应满足如下条件:
- 支持并发请求, 支持超时(1s)
- 使用协议: header(4 byte) 表明总长
对比项目为 net, evio , gnet ,我们通过 测试代码 比较了它们的性能。
更多测试参考 Netpoll-Benchmark , KiteX-Benchmark 和 Hertz-Benchmark
- CPU: Intel(R) Xeon(R) Gold 5118 CPU @ 2.30GHz, 4 cores
- Memory: 8GB
- OS: Debian 5.4.56.bsk.1-amd64 x86_64 GNU/Linux
- Go: 1.15.4