今天同事在做NEC测试的时候发现两个设备不能正常工作,通过抓包发现包的Tcp层中出现下面的错误:
CheckSum: 0xe719 [Incorrect, should be 0xc2f8 (maybe caused by "TCP checksum offload"?)]
在网上搜寻了很久,各种说法都有。但比较普遍的看法是因为网卡帮助Tcp协议栈处理了校验和从而发生的错误。也就是说本身校验和是Tcp协议栈来处理的,但为了提高效率,降低CPU的负担,将校验和的任务分担给网卡来完成,从而提高吞吐率。
因此,为了去掉该错误的方法就是关闭网卡的该功能。在windows下直接通过右击网卡属性就可以进行修改。这里只记录Linux下的修改方法:
ethtool -K eth1 rx off tx off sg off tso off
通过ethtool -k eth1可以查看网卡的属性
Offload parameters for eth1:
rx-checksumming: off
tx-checksumming: off
scatter-gather: off
tcp segmentation offload: off
但事实上,我修改之后继续测试,问题依旧。而且为了避免多个网卡的原因,我才用本地测法这个问题还是在。
不过可以肯定的是,这个校验和的问题似乎对应用层的程序没有什么影响。