由于本人才疏学浅,本文难免存在遗漏之处,欢迎大家留言指正,本人将感激不尽。
一、sendmsg和sendmmsg简介
其中sendmsg就是一个发包的系统调用,一次只能发送一个包,具体的可参考 https://linux.die.net/man/2/sendmsg
sendmmsg是对sendmsg的优化,调用一次sendmmsg可以发送多个segments,具体可参考 http://man7.org/linux/man-pages/man2/sendmmsg.2.html
这篇文章主要介绍sendmmsg能够带来多大的提升,主要通过代码解释测试的过程,然后给出测试结果。
二、测试代码及测试环境说明
测试数据大小为1000MB,测试发送完1000MB数据的消耗的时间。由于测试机是万兆网卡(10000Mb/s),如果一直发送,将打满网卡,网卡成为瓶颈,此处在每一次调用sendmmsg发包之后,调用usleep将进程睡眠,缓解网卡的压力。此处测试,限制sendmmsg每次发包个数最多为16,包大小固定为1330,所以万兆网卡将16个包发完大概需要16微妙,所以此处每次调用sendmmsg之后,进程睡眠16微妙,虽然此处通过usleep睡眠16微妙,但是加上进程上下文切换的时间,sendmmsg的调用间隔大于16微