论坛首页 Java企业应用论坛

socket 优化传输效率!!高手进

浏览 25163 次
精华帖 (0) :: 良好帖 (0) :: 新手帖 (0) :: 隐藏帖 (0)
作者 正文
   发表时间:2011-04-26   最后修改:2011-04-26
你把服务器的代码贴全呀, server.accept后的handleConnection方法内部用线程池做的处理吗,估计问题在这里。
0 请登录后投票
   发表时间:2011-04-26  
20921556 写道
JMS_Exception 写道
20921556 写道
一个服务单 一个客户端

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的网络发送,有限制??

小弟先在此谢过!!

lz
求解   服务器这段时间不间断的出现这个问题
2011-4-24 9:01:51 org.apache.jk.core.MsgContext action
警告: Unable to send headers
java.net.SocketException: Broken pipe
at java.net.SocketOutputStream.socketWrite0(Native Method)


操作系统是怎样的
什么情况下出现的??

linux
0 请登录后投票
   发表时间:2011-04-26  
tanjiazhang 写道
read是阻塞的,write是非阻塞的,比较它们的执行时间有意义吗。

大侠谁说write是非阻塞的,只是阻塞的时候少见,TCP的socket开发建议先看看TCP协议。。。。
0 请登录后投票
   发表时间:2011-04-27  
问题仍未解决..我试下测试mina看看
0 请登录后投票
   发表时间:2011-04-27  
楼主是单线程测试还是多线程?
0 请登录后投票
   发表时间:2011-04-28  
多线程..
性能有所提升..
增加socket.setTrafficClass(0x10);
0 请登录后投票
   发表时间:2011-10-24  
楼主,我碰到的问题和你相反,郁闷了很久。

我的客户端和服务端放在一台机器上反而很慢,如果分开在各自的服务器上反而快。
都不知道是系统的什么配置影响了。哎。

哪位高手请帮忙看看:
http://www.iteye.com/problems/73744
0 请登录后投票
论坛首页 Java企业应用版

跳转论坛:
Global site tag (gtag.js) - Google Analytics