Socket timeout是什么引起的(java mongo连接问题,一直超时,原因不知道在哪)

2024-08-19 10:50:04 :22

socket timeout是什么引起的(java mongo连接问题,一直超时,原因不知道在哪)

各位老铁们好,相信很多人对socket timeout是什么引起的都不是特别的了解,因此呢,今天就来为大家分享下关于socket timeout是什么引起的以及java mongo连接问题,一直超时,原因不知道在哪的问题知识,还望可以帮助大家,解决大家的一些困惑,下面一起来看看吧!

本文目录

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即可。

以上就是我们为大家找到的有关“socket timeout是什么引起的(java mongo连接问题,一直超时,原因不知道在哪)”的所有内容了,希望可以帮助到你。如果对我们网站的其他内容感兴趣请持续关注本站。

socket timeout是什么引起的(java mongo连接问题,一直超时,原因不知道在哪)

本文编辑:admin
Copyright © 2022 All Rights Reserved 威海上格软件有限公司 版权所有

鲁ICP备20007704号

Thanks for visiting my site.