在c语言中如何屏蔽一段程序,如何在用C语言关闭TCP程序中的Nagle算法
TCP為了防止在網(wǎng)絡(luò)中過多的小分組會導(dǎo)致阻塞,因此提供了Nagle算法:要求一個TCP連接上最多只能有一個未被確認(rèn)的未完成的小分組,在該分組的確認(rèn)到達(dá)之前不能發(fā)送其他的小分組。相反,TCP收集這些少量的分組,并在確認(rèn)到來時(shí)以一個分組的方式發(fā)出去。Nagle算法會導(dǎo)致自己寫的TCP程序中,小分組不能及時(shí)的發(fā)送出去。
現(xiàn)在我寫了個基于TCP的socket程序,希望AP往client端發(fā)送1000個16字節(jié)的報(bào)文。結(jié)果發(fā)現(xiàn)client端接收到的報(bào)文并不是每次大小都是82字節(jié)(82字節(jié)是因?yàn)橛?6字節(jié)的TCP和IP頭等,外加16字節(jié)我自己的數(shù)據(jù)),會出現(xiàn)大小為98字節(jié)的數(shù)據(jù)(98字節(jié)是因?yàn)橛?6字節(jié)的TCP和IP頭等,外加兩個16字節(jié)的自己的數(shù)據(jù))。如下圖所示:
這時(shí)就想起了關(guān)閉TCP中的Nagle算法。于是在我的TCP發(fā)送的Socket程序中加入如下代碼(記得還要導(dǎo)入頭文件:?#include ):
/* Disable the Nagle (TCP No Delay) algorithm */
//sock_cli是自己定義的socket套接字
int flag = 1;
int ret = setsockopt( sock_cli, IPPROTO_TCP, TCP_NODELAY, (char *)&flag, sizeof(flag) );
if (ret == -1) {
printf("Couldn‘t setsockopt(TCP_NODELAY)\n");
exit(-1);
}
重新編譯并且運(yùn)行,抓包后如下圖所示:
可以發(fā)現(xiàn)不會在出現(xiàn)小分組等待的現(xiàn)象,說明關(guān)閉了Nagle算法。
總結(jié)
以上是生活随笔為你收集整理的在c语言中如何屏蔽一段程序,如何在用C语言关闭TCP程序中的Nagle算法的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: linux perl模块检测,Linux
- 下一篇: 电子签章如何帮助检测机构无纸化电子签章如