昨天在eclipse中编写代码,本来连接mongodb进行各项操作都是正常的,但是有一会儿突然之间就没法连接了,还一直抱错,错误如下:

  1. 信息: Cluster created with settings {hosts=[192.168.0.4:27017], mode=SINGLE, requiredClusterType=UNKNOWN, serverSelectionTimeout='30000 ms', maxWaitQueueSize=500}
  2. 十一月 06, 2015 9:23:42 上午 com.mongodb.diagnostics.logging.JULLogger log
  3. 信息: No server chosen by ReadPreferenceServerSelector{readPreference=primary} from cluster description ClusterDescription{type=UNKNOWN, connectionMode=SINGLE, all=[ServerDescription{address=192.168.0.4:27017, type=UNKNOWN, state=CONNECTING}]}. Waiting for 30000 ms before timing out
  4. 十一月 06, 2015 9:24:02 上午 com.mongodb.diagnostics.logging.JULLogger log
  5. 信息: Exception in monitor thread while connecting to server 192.168.0.4:27017
  6. com.mongodb.MongoSocketOpenException: Exception opening socket
  7. at com.mongodb.connection.SocketStream.open(SocketStream.java:63)
  8. at com.mongodb.connection.InternalStreamConnection.open(InternalStreamConnection.java:114)
  9. at com.mongodb.connection.DefaultServerMonitor$ServerMonitorRunnable.run(DefaultServerMonitor.java:127)
  10. at java.lang.Thread.run(Thread.java:745)
  11. Caused by: java.net.SocketTimeoutException: connect timed out
  12. at java.net.DualStackPlainSocketImpl.waitForConnect(Native Method)
  13. at java.net.DualStackPlainSocketImpl.socketConnect(DualStackPlainSocketImpl.java:85)
  14. at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:339)
  15. at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:200)
  16. at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:182)
  17. at java.net.PlainSocketImpl.connect(PlainSocketImpl.java:172)
  18. at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392)
  19. at java.net.Socket.connect(Socket.java:579)
  20. at com.mongodb.connection.SocketStreamHelper.initialize(SocketStreamHelper.java:50)
  21. at com.mongodb.connection.SocketStream.open(SocketStream.java:58)
  22. ... 3 more
  23.  
  24. 十一月 06, 2015 9:24:12 上午 org.apache.catalina.core.StandardWrapperValve invoke
  25. 严重: Servlet.service() for servlet [springMVC] in context with path [/birthdaySystem1] threw exception [Request processing failed; nested exception is com.mongodb.MongoTimeoutException: Timed out after 30000 ms while waiting for a server that matches ReadPreferenceServerSelector{readPreference=primary}. Client view of cluster state is {type=UNKNOWN, servers=[{address=192.168.0.4:27017, type=UNKNOWN, state=CONNECTING, exception={com.mongodb.MongoSocketOpenException: Exception opening socket}, caused by {java.net.SocketTimeoutException: connect timed out}}]] with root cause
  26. com.mongodb.MongoTimeoutException: Timed out after 30000 ms while waiting for a server that matches ReadPreferenceServerSelector{readPreference=primary}. Client view of cluster state is {type=UNKNOWN, servers=[{address=192.168.0.4:27017, type=UNKNOWN, state=CONNECTING, exception={com.mongodb.MongoSocketOpenException: Exception opening socket}, caused by {java.net.SocketTimeoutException: connect timed out}}]
  27. at com.mongodb.connection.BaseCluster.createTimeoutException(BaseCluster.java:370)
  28. at com.mongodb.connection.BaseCluster.selectServer(BaseCluster.java:101)
  29. at com.mongodb.binding.ClusterBinding$ClusterBindingConnectionSource.<init>(ClusterBinding.java:75)
  30. at com.mongodb.binding.ClusterBinding$ClusterBindingConnectionSource.<init>(ClusterBinding.java:71)
  31. at com.mongodb.binding.ClusterBinding.getReadConnectionSource(ClusterBinding.java:63)
  32. at com.mongodb.operation.OperationHelper.withConnection(OperationHelper.java:166)
  33. at com.mongodb.operation.FindOperation.execute(FindOperation.java:394)
  34. at com.mongodb.operation.FindOperation.execute(FindOperation.java:57)
  35. at com.mongodb.Mongo.execute(Mongo.java:738)
  36. at com.mongodb.Mongo$2.execute(Mongo.java:725)
  37. at com.mongodb.DBCursor.initializeCursor(DBCursor.java:815)
  38. at com.mongodb.DBCursor.hasNext(DBCursor.java:149)
  39. at services.servicesImp.UserServiceImp.findUserName(UserServiceImp.java:60)
  40. at controllers.UserController.login(UserController.java:43)
  41. at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
  42. at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57)
  43. at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
  44. at java.lang.reflect.Method.invoke(Method.java:606)
  45. at org.springframework.web.method.support.InvocableHandlerMethod.doInvoke(InvocableHandlerMethod.java:221)
  46. at org.springframework.web.method.support.InvocableHandlerMethod.invokeForRequest(InvocableHandlerMethod.java:137)
  47. at org.springframework.web.servlet.mvc.method.annotation.ServletInvocableHandlerMethod.invokeAndHandle(ServletInvocableHandlerMethod.java:110)
  48. at org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.invokeHandleMethod(RequestMappingHandlerAdapter.java:777)
  49. at org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.handleInternal(RequestMappingHandlerAdapter.java:706)
  50. at org.springframework.web.servlet.mvc.method.AbstractHandlerMethodAdapter.handle(AbstractHandlerMethodAdapter.java:85)
  51. at org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:943)
  52. at org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:877)
  53. at org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:966)
  54. at org.springframework.web.servlet.FrameworkServlet.doGet(FrameworkServlet.java:857)
  55. at javax.servlet.http.HttpServlet.service(HttpServlet.java:620)
  56. at org.springframework.web.servlet.FrameworkServlet.service(FrameworkServlet.java:842)
  57. at javax.servlet.http.HttpServlet.service(HttpServlet.java:727)
  58. at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:303)
  59. at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:208)
  60. at org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:52)
  61. at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:241)
  62. at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:208)
  63. at org.springframework.web.filter.CharacterEncodingFilter.doFilterInternal(CharacterEncodingFilter.java:88)
  64. at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:107)
  65. at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:241)
  66. at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:208)
  67. at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:220)
  68. at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:122)
  69. at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:503)
  70. at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:170)
  71. at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:103)
  72. at org.apache.catalina.valves.AccessLogValve.invoke(AccessLogValve.java:950)
  73. at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:116)
  74. at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:421)
  75. at org.apache.coyote.http11.AbstractHttp11Processor.process(AbstractHttp11Processor.java:1070)
  76. at org.apache.coyote.AbstractProtocol$AbstractConnectionHandler.process(AbstractProtocol.java:611)
  77. at org.apache.tomcat.util.net.JIoEndpoint$SocketProcessor.run(JIoEndpoint.java:316)
  78. at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1145)
  79. at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:615)
  80. at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61)
  81. at java.lang.Thread.run(Thread.java:745)

对于这个问题,查了好多的资料硬是没能解决。后来偶然间关掉了QQ管家里边开启的“免费wifi”,没想到连接就一下子正常了。

于是,我有试了若干次,结果竟然都是一开这个wifi,mongodb立马就连不上,一关掉然后就一切正常。

问题解决了,但根本原因还是不曾明白。

java连接mongodb的一个奇葩问题及奇葩解决方式的更多相关文章

  1. Java 连接MongoDB

    1.驱动 通过java连接MongoDB需要一个java版的驱动 下载地址:http://mongodb.github.io/mongo-java-driver/ 2.连接MongoDB 通过 com ...

  2. MongoDB第三天(正则,管道,聚合,字符串,算术,日期,java连接MongoDB)

    部分正则表达式: i:忽略大小写 m:多行查找 x:设置 x 选项后,正则表达式中的非转义的空白字符将被忽略.   s:允许点字符(即.)匹配包括换行符在内的所有字符. w:匹配包括下划线的任何单词字 ...

  3. java连接mongodb数据库

    最近毕设需要用到这个数据库.然而又不会,没办法,只能上网学习学习. 记录一下java连接mongodb数据库的简单方法.这里只是记录一下学习.熟悉一下CURD方法. 但是毕业用到的是SpringBoo ...

  4. java 连接 mongodb 及使用

    MongoDB是当今非常流行的一款NoSQL数据库,本文介绍如何使用MongoDB的Java驱动来操作MongoDB. 一.引入MongoDB Java Driver包 如果需要操作MongoDB的J ...

  5. Java连接MongoDB报错“java.lang.IllegalArgumentException: clusterListener can not be null”的解决办法

    我使用的MongoDB版本是3.6.9. 下面是一个很基础的示例代码,功能就是连接MongoDB: package com.zifeiy.snowflake.handle.etl.mongodb; i ...

  6. java连接mysql的一个小例子

    想要用java 连接数据库,需要在classpath中加上jdbc的jar包路径 在eclipse中,Project的properties里面的java build path里面添加引用 连接成功的一 ...

  7. java连接MongoDB查询导出为excel表格

    背景 因为项目需求.每一个星期须要统计每一个公众号7天的訪问数,月底就须要统计一个月的訪问数,40多个公众号.每次手动统计都须要花费1个小时,总之是一项无技术耗时耗神的手工活. 于是.想写个程序来统计 ...

  8. java连接Fastdfs图片服务器上传失败的解决方法

    照着视频上做,但是却连接不了虚拟机linux上的图片服务器,估计是linux防火墙的问题(这个实在是神烦,前面有好几次连接不了都是因为linux防火墙),果不其然,关闭即可. Linux关闭防火墙的命 ...

  9. 【kafka】Java连接出现Connection refused: no further information的解决方法

    在Linux机器(ip:10.102.16.203)安装完kafka(参考:kafka的安装及使用),在windows上使用Java接口访问服务时(参考:Java实现Kafka的生产者.消费者),报异 ...

随机推荐

  1. Javascript中的函数、this以及原型

    关于函数 在Javascript中函数实际上就是一个对象,具有引用类型的特征,所以你可以将函数直接传递给变量,这个变量将表示指向函数“对象"的指针,例如: function test(mes ...

  2. 02java语法基础问题总结

    S和t引用的不是同一个对象 不是原始数据类型 结论: 枚举类型是引用类型,枚举不属于原始数据类型.它的每一个具体值都引用一个特定的对象. 2. 以下代码的输出结果是什么? int X=100; int ...

  3. spark与storm的对比

    对比点 Storm Spark Streaming 实时计算模型 纯实时,来一条数据,处理一条数据 准实时,对一个时间段内的数据收集起来,作为一个RDD,再处理 实时计算延迟度 毫秒级 秒级 吞吐量 ...

  4. 奇怪的电梯(HDU1548) (Dijkstra)或者(BFS)

    问题 E: 奇怪的电梯 时间限制: 1 Sec  内存限制: 64 MB提交: 35  解决: 16[提交][状态][讨论版] 题目描述 有一天桐桐做了一个梦,梦见了一种很奇怪的电梯.大楼的每一层楼都 ...

  5. STM32学习笔记:系统时钟和SysTick定时器

    原文:http://blog.sina.com.cn/s/blog_49cb42490100s60d.html 1.     STM32的时钟系统 在STM32中,一共有5个时钟源,分别是HSI.HS ...

  6. caffe 训练时,出现错误:Check failed: error == cudaSuccess (4 vs. 0) unspecified launch failure

    I0415 15:03:37.603461 27311 solver.cpp:42] Solver scaffolding done.I0415 15:03:37.603549 27311 solve ...

  7. maven&&gradle

    https://maven.apache.org/guides/introduction/introduction-to-the-lifecycle.html http://maven.apache. ...

  8. 使用substring和split方法从字符串中抽取一组清单

    提取前: '这是一个句子.这是一个句子,包含了一列清单: 樱桃, 橙子, 桔子, 苹果, 香蕉.这是清单内容.'; 提取后: ["樱桃", " 橙子", &qu ...

  9. java_queue

    队列是一种特殊的线性表,先进先出(first in first out)FIFO,它只允许在表的前端(front)进行删除操作,只允许在表的后端(rear)进行插入操作. 实际应用:排队等待公交车,银 ...

  10. linux nginx 配置ssl证书访问

    http://www.linuxidc.com/Linux/2013-08/88271.htm 一.什么是 SSL 证书,什么是 HTTPSSSL 证书是一种数字证书,它使用 Secure Socke ...