我想编写一个在某些情况下用作 FTP 服务器的 gRPC 服务器(c++)。具体来说,客户端通过文件名请求文件,而服务器返回文件内容(如果存在)。在传统的socket编程中,我可以在linux系统上实现零拷贝sendfile
。这意味着文件内容将直接从磁盘进入套接字缓冲区,而无需在用户空间中传输。但是在 gRPC 世界中,套接字详细信息是隐藏的,这意味着您可能无法访问套接字后面所需的文件描述符sendfile
:
ssize_t sendfile(int out_fd, int in_fd, off_t *offset, size_t count);
因此,我必须先将文件字节读入内存,然后在 gRPC 响应中返回。这是不必要的性能损失。我想知道是否有任何 API 或解决方法。