JAVA socket 优化传输效率!!《求助》高手快来
一个服务单 一个客户端
1.将服务器,和客户端都在本机上进行传输 很快
本机很快,1s可发几万次
2.将服务器放到 局域网内另一台 linux 机器,客户端放到windows 上进行发送的时候就很慢
将服务器放到 局域网内另一台 windows 机器,客户端放到windows 进行发送,发送效率一样慢
客户端:
while(true){
一次发送的数据为 (8+15)=23字节,write(23字节);
等服务端得响应 read(16字节);
}
服务端:
while(true){
接受,
然后返回 响应 12+4 = 16的字节
}
客户端发送23字节,循环发送1000次,用时 60s。
将socket TcpNodelay设置为true后效率有所提升
发送23字节,循环发送1000次,用时 3s。
settcpnodelay(true)
我定位影响效率的原因是 in.read()阻塞导致的.
settcpnodelay(flase)即默认情况下
每次read()耗时 202ms左右,write() 0ms
settcpnodelay(true)即禁用negal算法,
每次read()耗时 1ms 左右,write() 1-3ms左右
偶尔出现一次40ms的情况
请教各位大侠,该如何优化,网络传输,read阻塞的情况啊
是JVM虚拟机的对socket的网络发送,有限制??
小弟先在此谢过!!