`
huanhuan1022
  • 浏览: 54925 次
  • 性别: Icon_minigender_1
  • 来自: 天津
社区版块
存档分类
最新评论

No buffer space available

    博客分类:
  • java
阅读更多

java.net.SocketException: No buffer space available (maximum connections reached?): JVM_Bind

一个朋友让我帮忙解决他服务器上一个JAVA应用出现的问题,我利用业务时间赶赴现场两次,终于解决了这个疑难杂症,赶紧记录下来,不求能解救曾经和我一样困惑的劳苦大众,但愿自己别忘了。

一、问题的表现

首先说明一下环境,服务器是WINDOWS SERVER 2003,我对这个操作系统的特性不是很熟悉,只是当做普通的个人版操作系统来使用。我平时一般JAVA服务器都是安装LINUX。

数据库使用的SQL SERVER 2005,SP2。他的数据库本来是SQL SERVER 2000的,是我上周帮他做的迁移。

中间件使用RESIN 2.1.17,这是我非常喜欢和熟悉的SERVLET容器,加不加装APACHE都具有很好的WEB服务性能。

杀毒软件使用的瑞星,双网卡,硬件防火墙,什么牌子我没管。

那到底是什么问题?

这个!

com.microsoft.sqlserver.jdbc.SQLServerException: 到主机  的 TCP/IP 连接失败。 java.net.SocketException: No buffer space available (maximum connections reached?): JVM_Bind

RESIN启动后,在短时间内正常,但是在没有访问的情况下,会在几个小时后,自己死掉。静态页面没有问题,也就是基于HTTPWEB服务器没有死,涉及数据库连接的,都不行。

二、分析

我是第一次碰到这个错误,赶紧GOOGLE。

我首先自己排除了是程序的问题,网上有人说,是数据库连接没有关闭,这样的同志都是新手,而且我自己也可以肯定,程序是肯定没有问题的,这个错误,出现的位置绝对比数据库连接要底层的多。

网上的文章非常少,都看了一遍,总结一共有以下几个原因。

1. Windows服务器运行自动更新。具体为什么自动更新运行后,就会消耗系统这么多的SOCKET 连接,我还搞不清楚。但是有一点,自动更新肯定会占用网络带宽和CPU,在服务器上,我觉得应该是关闭自动更新的,采用人工更新的方法。

2.机器中了木马。木马会打开很多后门,创建大量的连接,包括局域网肉鸡上的,还有外网的。这也会导致机器出现无法上网,或者程序无法连接。在搜索到的结果中,大量的结果都是采用的SQLSERVER数据库服务器,这是很容易招来木马和病毒的服务器,大部分是SQLSERVER出问题,不是偶然的。

3.虚拟内存配置过低。第一次发现这个问题后,我到现场打开机器,确实报了一个虚拟内存的错误,说虚拟内容不足。

4.有不当程序创建了大量的短连接,由于程序的不健壮,导致SOCKET处于忙碌或者TIME_WAIT状态,或者服务器和客户端有一方出现异常,而另一方没有得到通知,还在连接,持续不断的做写操作。

三、动手解决

经过分析,将准备采取的措施一一写下来,我的脑袋不太好用,容易忘记东西。

措施如下,先做什么,后做什么,看到这篇文章的朋友,可以自己调整。

1. 优化RESIN的配置,适当的扩大连接池的数量,虽然不是这个问题,还是稍微扩大一点。配置了远程监控,关闭了默认没有做的目录浏览,屏蔽了404等错误;使用HTTPD -INSTALL将RESIN安装入服务,原来我的朋友是直接启动的控制台,这容易导致程序在控制台缓存到顶后停止。关闭了HIBERNATE的SHOW_SQL开关。

2.关闭自动更新,并且关闭Background Intelligent Transfer Service服务。打开服务的时候,发现服务窗口5秒后会自动关闭,而且奇怪的服务非常多。同时看到NORTON已经被自动禁用了,打也打不开,得,这机器的病毒还不少。

3.杀毒。不看不知道,一看吓一跳。我这哥们真是个大猛男,妈的,各种病毒都中了,还服务呢,这SERVER真是可怜啊!病了主人也不给看病,为国家服务的机器,不可能没有医保嘛。亲爸不管叔叔来给你治病。经过分析,中的病毒有U盘病毒,还有RUNAUTO..病毒,灰鸽子,传奇木马,各种不知名的后门和木马,还被安装了一个远程控制的小东西。下载了一个360,想偷懒,结果根本无法安装。删除了RUNAUTO..,(我以前的博客有专门描述怎么对付这玩意的)结果C盘都打不开了,只能在资源管理器中打开。还挺麻烦。于是找到病毒几个藏身之所,分析了未知服务,用DOS删除不掉,还是360的文件粉碎有用。什么c:\windows\lsass.exe等等,cmd.exe.exe这都太普通了。具体过程也不是很清楚了,总之最后360可以安装并更新了。360这东西确实好,木马都清除了。现在服务窗口也不自动关闭了,NORTON也正常监控,机器没有异常打开的端口,没有莫名其妙的服务,恩,差不多了。

4.优化服务器设置。其实我也不知道这么优化。看了看,虚拟内存都在C盘,C盘空间已经非常少了,找了点看的明白的东西,往别的盘搬了搬,看不懂的,不敢随便给人家动。重新打开服务窗口,没什么用的服务都开着,把我确定的都关闭,什么SERVER服务,还开着ADMIN$呢,赶紧都关了,他这机器根本用不着。还有什么IIS,APACHE,开的还真全,我看还安装了TOMCAT了,干脆加上RESIN全打开算了,那真是够热闹的,万马齐喑。我当然不允许这事出现,全干掉。

5.检查是否某个程序有漏洞。由于我自己在RESIN下还配置了一个只有我自己连GOOGLE的机器人都无法发现(并且也拒绝了机器人扫描)的小工具,之前就看到有外网IP不时的创建大量的连接,但都处于TIME_WAIT状态。这也很要命。看了一下,除了这个WEB应用,还有一个每天自动接收数据的小程序。这个程序是使用的SOCKET长连接还是短连接就不知道了,有朋友关心这方面的内容可以详细GOOGLE一下。但是这个程序确实是没有被配置为开机自动运行(我给加上了),可能是外网那个IP上的客户端在不断的寻求连接吧!SOCKET.close()是不马上释放连接的,而是设置为TIME_WAIT状态,这个时间默认是240S,也就是4分钟。这太长了,有30秒(最小值)就可以了。在修改这个默认值的时候,还发现这台机器并没有开启大端口服务,也就是高于5000的端口。这也是会出现“系统缺乏足够缓冲区空间或者因为队列已满无法执行套接字上操作”错误的!而那WEB服务就是配置到1万以上端口的!赶紧,操作方法如下:

1. 启动注册表编辑器。 HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\Tcpip\Parameters 
2. 新建

值名称:MaxUserPort 
值类型: DWORD
值数据: 65534(用十进制的方法写进去就可以,如果是十六进制,是FFFE,因为4个F是65535嘛)
有效范围: 5000 - 65534 (十进制)
默认: 0x1388 5000 (十进制)

新建

值名称:TCPTimedWaitDelay
值类型: DWORD
值数据: 0000001e(也就是30,不行可以用WINDOWS计算器,很方便,这个表示TIME_WAIT的秒数)

OK!

经过一番折腾,我在震耳欲聋的轰鸣声中,终于安抚了这台哭泣的服务器,也驯服了几匹小木马,好好调教了我的RESIN服务器。顺便说一句,我身后有台什么爱默生服务器,隔一会就象打嗝似的叫一声,时常把我吓到……

希望花费我1个多小时写的这个总结,对我自己肯定有用,也希望能帮到更多的朋友,如果转载,请注明出处。

分享到:
评论

相关推荐

    KB2553549,KB2577795(No buffer space available 问题)

    标题 "KB2553549,KB2577795(No buffer space available 问题)" 涉及的是Windows操作系统中的一个常见错误,即"No buffer space available (maximum connections reached?): connect"。这个错误通常发生在用户尝试...

    kb2577795,kb2553549补丁 修复No buffer space available 异常

    在这个案例中,它们被设计用来修复"No buffer space available"异常。这个异常通常与网络或存储系统有关,表明系统在处理数据传输时遇到了缓冲区不足的情况,这可能是由于内存资源紧张或网络配置不当所导致的。 ...

    kb2577795,kb2553549 windows 2008 r2 补丁 解决No buffer space available

    标题提到的"kb2577795,kb2553549 windows 2008 r2 补丁 解决No buffer space available"针对的是Windows Server 2008 R2操作系统中的一个问题,该问题表现为“No buffer space available”的错误提示。这个错误通常...

    kb2577795,kb2553549 windows 2008 r2 补 解决No buffer space available 早期版本漏洞 亲测可用

    “No buffer space available”错误通常与网络或存储子系统有关,当系统的缓冲区资源耗尽时,可能会出现这种问题。这可能是因为网络流量过大、TCP/IP堆栈配置不当或者是驱动程序存在兼容性问题。这两个补丁的目的...

    socket no buffer available

    在IT领域,尤其是在网络编程中,“socket no buffer available”是一个常见的问题,特别是在使用Delphi ICS(Internet Component Suite)和Java Socket编程时。本篇文章将深入探讨这一问题,并结合给出的部分代码...

    如何解决线程太多导致java socket连接池出现的问题

    3. 错误信息:当Socket连接池出现问题时,可能会出现错误信息,如"java.net.SocketException: No buffer space available (maximum connections reached?): listen failed"。 解决方法 要解决线程太多导致Socket...

    windows解决socket连接不释放补丁包

    标题 "windows解决socket连接不释放补丁包" 涉及到的是Windows Server 2008 R2操作系统上的一个特定问题,这个问题可能导致系统在处理网络连接时出现"No buffer space available"错误。这个错误通常表明系统的网络...

    windows server 2008 r2 bug修复补丁

    当系统出现"No buffer space available (maximum connections reached?): JVM_Bind"错误时,意味着系统已经达到了其最大连接数,无法再建立新的网络连接。这个问题对服务的稳定性和可用性产生了重大影响,尤其是对于...

    Windows系统kb2577795,kb2553549 补丁.zip

    这两个补丁对于保持系统的稳定性和安全性至关重要,特别是对于那些频繁遭遇“no buffer space available”或“由于系统缓冲空间不足或队列已满”错误的用户来说。 KB2577795补丁主要修复了Windows网络堆栈中的一个...

    Windows2008补丁.rar

    然而,像所有操作系统一样,Windows 2008 也可能会遇到各种问题,其中“no buffer space available”(无缓冲空间可用)和“由于系统缓冲空间不足或队列已满,不能执行套接字上的操作”是两个常见的错误提示,这些...

    Windows6.1-KB2577795-x64.msu Windows6.1-KB2553549-v2-x64.msu

    描述中提到的"解决no buffer space available、由于系统缓冲空间不足或队列已满问题",是指在运行Windows系统时可能会遇到的一种错误情况。"no buffer space available"通常出现在网络通信或文件读写过程中,当系统...

    Windows6.1-KB2553549、KB2577795-x64.zip

    1.解决服务器报错:java.net.SocketException: No buffer space available (maximum connections reached?): JVM_Bind 2.解决Windows Server 2003/2008 R2系统BUG导致windows缓冲区已满(no buffer space),Windows...

    _tcp_WSAEventSelect_vc6.rar

    错误代码10055,"No buffer space available",通常表示系统没有足够的资源来完成请求的操作。这可能是由于网络堆栈中的缓冲区不足,或者是系统资源紧张导致的。在XP系统中,可能由于系统配置、驱动程序兼容性或者...

    socket错误代码对应表

    - **Socket error #10055 - No buffer space available**:没有可用的缓冲空间。 - **Socket error #10056 - Socket is already connected**:Socket已经连接。 - **Socket error #10057 - Socket is not connected*...

    socket常见错误代码解析.pdf

    Socket Error 10055 - No buffer space available Socket Error 10055是指缓冲区空间不足,这种错误通常是由于系统资源不足所致。解决方法是释放系统资源或增加缓冲区空间。 Socket Error 10056 - Socket is ...

    Kernel sockets leak on a multiprocessor computer that is running Windows 7

    No buffer space available (maximum connections reached?): JVM_Bind 解决方案: 此问题是windows的bug,唯一解决问题的方法就是reboot,然后给系统打补丁,The problem was fixed with Microsoft's patch: ...

    微软内部资料-SQL性能优化2

    Although 2 GB of address space may seem like a large amount of memory, application such as SQL Server could leverage more memory if it were available. The boot.ini option /3GB was created for those ...

    uhdd.sys源码

    using its B switch first boots in temporary space When upper memory gets enabled by the EMM driver XMGR loads there with no B copies all its boot data and takes over XMS work For a small XMS only ...

    H248-协议错误码

    13. **432 Out of Termination IDs or No Termination ID Available**:终止ID不足或没有可用的终止ID。 14. **433 Termination ID is Already in a Context**:终止ID已经在某个上下文中使用。 15. **434 Max ...

Global site tag (gtag.js) - Google Analytics