本文目录
- java mongo连接问题,一直超时,原因不知道在哪
- java.net.sockettimeoutexception安卓开发
- SocketTimeoutException和ConnectTimeoutException的区别
- java.net.SocketTimeoutException: Read timed out at java.net.SocketInputStream.socketRead0(Native M
- oralce Socket read timed out 我快疯了,什么原因造成的
java mongo连接问题,一直超时,原因不知道在哪
在对超过百万条记录的集合进行聚合操作。DBObject match=(DBObject)JSON.parse("{$match:{logType:{’$in’:}}}"); DBObject group=(DBObject)JSON.parse("{$group:{’_id’:’$domainUrl’,’count’:{’$sum’:1}}}"); AggregationOutput output = logCollection.aggregate(match,group); 偶尔会发生Read timed out 异常。com.mongodb.MongoException$Network: Read operation to server /192.168.10.202:27017 failed on database adLogTable at com.mongodb.DBTCPConnector.innerCall(DBTCPConnector.java:253) at com.mongodb.DB.command(DB.java:261) at com.mongodb.DB.command(DB.java:243) ... Caused by: java.net.SocketTimeoutException: Read timed out at java.net.SocketInputStream.socketRead0(Native Method) at java.net.SocketInputStream.read(SocketInputStream.java:152) 通过多次测试,发现执行一次聚合平均时间为5s,超过5s时就会报错!然后查看MongoDB的配置信息:socket-timeout="5000" //5s socket-timeout的默认配置为0,也就是没有限制。没有超时限制,系统出了问题也不容易发现,应该根据实际情况,给出合理的超时时间。通过多次测试发现最长执行时间为6秒,就把超时时间设置成了10000。socket-timeout="10000" //10s 注意:MongoDB在与Spring整合时,如果要配置多个MongDB源,只会启用最后一个《mongo:options》配置。应该把参数配置信息存储在properties文件中。《mongo:mongo host="${mongodb.ip}" id="mongo202" port="${mongodb.port}"》 《mongo:options connections-per-host="200" threads-allowed-to-block-for-connection-multiplier="100" connect-timeout="1000" max-wait-time="1000" auto-connect-retry="true" socket-keep-alive="true" socket-timeout="10000" slave-ok="true" write-number="1" write-timeout="0" write-fsync="true" /》 《/mongo:mongo》 通过Java API获取配置参数DBCollection logCollection = mongoTemplate.getCollection(collName); MongoOptions mongoOptions = logCollection.getDB().getMongo().getMongoOptions(); System.out.println(mongoOptions.getSocketTimeout()); 最后一点: ConnectionTimeOut和SocketTimeOut的区别:一次完整的请求包括三个阶段:建立连接数据传输断开连接如果与服务器(这里指数据库)请求建立连接的时间超过ConnectionTimeOut,就会抛 ConnectionTimeOutException,即服务器连接超时,没有在规定的时间内建立连接。如果与服务器连接成功,就开始数据传输了。如果服务器处理数据用时过长,超过了SocketTimeOut,就会抛出SocketTimeOutExceptin,即服务器响应超时,服务器没有在规定的时间内返回给客户端数据。
java.net.sockettimeoutexception安卓开发
sockettimeoutexception是网络请求超时异常,在网络状况不佳,且设置了RequestTimeOut、ReadTimeOut时会爆出该错误。此时应该给出网络连接超时的提示,并给出用户重试的交互,或建立自动重新连接的线程。注意文件传输时,万万不可设置连接最大超时,否则极易导致文件下载中断等问题!
SocketTimeoutException和ConnectTimeoutException的区别
1、SocketTimeoutException一般是服务器响应超时,即服务器已经收到了请求但是没有给客户端进行有效的返回;而ConnectTimeoutException指服务器请求超时,指在请求的时候无法客户端无法连接上服务端:
请求超时和响应超时的意义可通过下面的例子理解:
当一笔交易,如果请求失败,那可以允许用户再次提交。如果是响应失败,那就说明用户提交成功了,应该防止用户再次提交
2、在代码里可以对应的设置请求超时和响应超时的最大时间:
***隐藏网址***
***隐藏网址***
java.net.SocketTimeoutException: Read timed out at java.net.SocketInputStream.socketRead0(Native M
Read timed out是指读超时,this.tcpClient.getInputStream();,这个读取到了流,但是对端迟迟没有发送相应,导致读超时。
oralce Socket read timed out 我快疯了,什么原因造成的
很明显,出现这种问题的原因是读取文件超时,解决方法是将HTTP Keep-Alive Timeout这个参数设置地尽量大,但是有没有更好的解决方法,由于使用的服务器是tomcat,便可以通过修改服务器配置来解决该问题,具体的解决方法如下:修改tomcat配置文件server.xml,找到类似于下面配置:
《Connector port="8086" maxHttpHeaderSize="8192"maxThreads="150" minSpareThreads="25" maxSpareThreads="75"enableLookups="false" redirectPort="8443" acceptCount="100"connectionTimeout="20000" disableUploadTimeout="true" /》
将上面的参数disableUploadTimeout值改为false即可。