tcp、dup的socket发包支持零拷贝

linux内核的一个实现:

sendmsg copy avoidance with MSGprotect T1 extunderscore ZEROCOPY (netdevconf.org)icon-default.png?t=N7T8https://netdevconf.org/2.1/papers/netdev.pdf

socket sendmsg MSG_ZEROCOPY [LWN.net]icon-default.png?t=N7T8https://lwn.net/Articles/726353/

对于用户编程来说,需要做一些改动,即调用了send操作后,会很快返回,但是其sendbuf不能立即释放,需要等待通知后,才能释放。

要实现零拷贝,那么sendbuf需要在实际发出去之后,才能释放,这会有很大延迟,尤其是tcp这种需要等待确认,且有可能重传的情况。但如果send操作一直阻塞住,会很大程度影响用户发送数据的吞吐量。

在send数据小的情况下,零拷贝其实会有很大的内核开销:

on modern CPUs, mapping one page has even higher cost than copying it, because of kernel crossing and TLB flush costs

16KB的数据,才值得去做零拷贝:

To amortize page remapping cost, we only use zero copy for send or recv with at least 16 KiB payload size. Smaller messages are copied instead.

  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值