在前面的文章中, 我们说过, udp的最大业务数据报的大小为65507个字节, 调用send后, 这些数据是一次udp包发送的吗? 来看看:
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <sys/socket.h>
#include <netinet/in.h>
#include <arpa/inet.h>
#include <unistd.h>
#include <errno.h>
int main(int argc, char *argv[])
{
struct sockaddr_in srvAddr;
bzero(&srvAddr, sizeof(srvAddr));
srvAddr.sin_family = AF_INET;
srvAddr.sin_addr.s_addr = inet_addr("127.0.0.1");
srvAddr.sin_port = htons(8765);
int iSock = socket(AF_INET, SOCK_DGRAM, 0); // udp
char szBuf[1024 * 64 -1 - 20 - 8] = {0};
int iRet = sendto(iSock, szBuf, sizeof(szBuf), 0, (struct sockaddr *)&srvAddr, sizeof(srvAddr));
printf("send size is %d, iRet is %d, errmsg[%s]\n", sizeof(szBuf), iRet, strerror(errno));
close(iSock);
return 0;
}
发送端抓包:
xxxxxx$ sudo tcpdump -iany port 8765 -nlps0
tcpdump: verbose output suppressed, use -v or -vv for full protocol decode
listening on any, link-type LINUX_SLL (Linux cooked), capture size 65535 bytes
21:58:04.610298 IP 127.0.0.1.27365 > 127.0.0.1.ultraseek-http: UDP, length 65507
可见, 就是一个udp包发送的。
但是, 如上行为确实有点奇怪, 按理说, 应该会分片啊, 我在接收端抓了一下, 果然是分片的。
所以, 这里应该还是分包/片了的。
后记: 通过更深入的学习, 发现发送端的行为可能与gso有关.