求助!! android 上使用mina 出现java.net.SocketException: Too many open files

原创 2011年12月30日 14:57:54
 在android上做一个Mina的客户端定时的向Lunix服务器端(也是用Mina做的)发送心跳包,每发到158左右的时候就会报以下的异常(不管心跳的时间长短都会有问题),
在网上找了很多资料,有的说连接没有关闭,但是我用进程工具发现用过的连接线程都会关掉;还有人说要修改Linux的配置参数,如下:

修正方法:
参考了网上的一篇文章,用root身份对ulimit参数进行如下修改即可。
1. 修改/etc/security/limits.conf文件,插入以下两行,第一个字段*表示所有用户,如果要只允许某一用户,可将该用户名取代*符号。
*        soft        nofile        4096

*        hard       nofile        4096

2. 修改/etc/pam.d/common-session文件,增加session required pam_limits.so这一行即可。
按上述修改,将ulimit中打开文件数量值从1024增加到了4096(也可以是其它值)。修改生效后,再运行CTS就正常了,差不多四个半小时后,整个测试例就全部跑完了。
----
但是Android上没有这个文件可以修改。


心跳时间加长会报异常:Could not create 1232896-byte ashmem mark stack: Too many open files

短则报异常:
W/System.err(2393): java.net.SocketException: Too many open files
W/System.err(2393):  at org.apache.harmony.luni.platform.OSNetworkSystem.acceptSocketImpl(Native Method)
W/System.err(2393):  at org.apache.harmony.luni.platform.OSNetworkSystem.accept(OSNetworkSystem.java:69)
W/System.err(2393):  at org.apache.harmony.luni.net.PlainSocketImpl.accept(PlainSocketImpl.java:126)
W/System.err(2393):  at java.net.ServerSocket.implAccept(ServerSocket.java:281)
W/System.err(2393):  at org.apache.harmony.nio.internal.ServerSocketChannelImpl$ServerSocketAdapter.accept(ServerSocketChannelImpl.java:247)
W/System.err(2393):  at org.apache.harmony.nio.internal.ServerSocketChannelImpl$ServerSocketAdapter.access$100(ServerSocketChannelImpl.java:194)
W/System.err(2393):  at org.apache.harmony.nio.internal.ServerSocketChannelImpl.accept(ServerSocketChannelImpl.java:144)
W/System.err(2393):  at org.apache.harmony.nio.internal.PipeImpl$SourceChannelImpl.accept(PipeImpl.java:120)
W/System.err(2393):  at org.apache.harmony.nio.internal.PipeImpl.<init>(PipeImpl.java:49)
W/System.err(2393):  at org.apache.harmony.nio.internal.SelectorProviderImpl.openPipe(SelectorProviderImpl.java:51)
W/System.err(2393):  at org.apache.harmony.nio.internal.SelectorImpl.<init>(SelectorImpl.java:141)
W/System.err(2393):  at org.apache.harmony.nio.internal.SelectorProviderImpl.openSelector(SelectorProviderImpl.java:58)
W/System.err(2393):  at java.nio.channels.Selector.open(Selector.java:48)
W/System.err(2393):  at org.apache.mina.transport.socket.nio.NioProcessor.<init>(NioProcessor.java:59)
W/System.err(2393):  at java.lang.reflect.Constructor.constructNative(Native Method)
W/System.err(2393):  at java.lang.reflect.Constructor.newInstance(Constructor.java:446)
W/System.err(2393):  at org.apache.mina.core.service.SimpleIoProcessorPool.<init>(SimpleIoProcessorPool.java:180)
W/System.err(2393):  at org.apache.mina.core.service.SimpleIoProcessorPool.<init>(SimpleIoProcessorPool.java:112)
W/System.err(2393):  at org.apache.mina.core.polling.AbstractPollingIoConnector.<init>(AbstractPollingIoConnector.java:93)
W/System.err(2393):  at org.apache.mina.transport.socket.nio.NioSocketConnector.<init>(NioSocketConnector.java:56)
W/System.err(2393):  at com.farben.ams.handler.AmsSendMsgBiz.sendMsg(AmsSendMsgBiz.java:54)
W/System.err(2393):  at com.farben.ams.activity.PlayActivity$startAskDmsOntimeThread.run(PlayActivity.java:219)
W/System.err(2393): java.net.SocketException: Too many open files
W/System.err(2393):  at org.apache.harmony.luni.platform.OSNetworkSystem.createServerStreamSocketImpl(Native Method)
W/System.err(2393):  at org.apache.harmony.luni.platform.OSNetworkSystem.createServerStreamSocket(OSNetworkSystem.java:170)
W/System.err(2393):  at org.apache.harmony.luni.net.PlainServerSocketImpl.create(PlainServerSocketImpl.java:45)
W/System.err(2393):  at java.net.ServerSocket.checkClosedAndCreate(ServerSocket.java:475)
W/System.err(2393):  at java.net.ServerSocket.bind(ServerSocket.java:391)
W/System.err(2393):  at org.apache.harmony.nio.internal.ServerSocketChannelImpl$ServerSocketAdapter.bind(ServerSocketChannelImpl.java:215)
W/System.err(2393):  at java.net.ServerSocket.bind(ServerSocket.java:369)
W/System.err(2393):  at org.apache.harmony.nio.internal.ServerSocketChannelImpl$ServerSocketAdapter.bind(ServerSocketChannelImpl.java:285)
W/System.err(2393):  at org.apache.harmony.nio.internal.PipeImpl$SourceChannelImpl.<init>(PipeImpl.java:110)
W/System.err(2393):  at org.apache.harmony.nio.internal.PipeImpl.<init>(PipeImpl.java:47)
W/System.err(2393):  at org.apache.harmony.nio.internal.SelectorProviderImpl.openPipe(SelectorProviderImpl.java:51)
W/System.err(2393):  at org.apache.harmony.nio.internal.SelectorImpl.<init>(SelectorImpl.java:141)
W/System.err(2393):  at org.apache.harmony.nio.internal.SelectorProviderImpl.openSelector(SelectorProviderImpl.java:58)
W/System.err(2393):  at java.nio.channels.Selector.open(Selector.java:48)
W/System.err(2393):  at org.apache.mina.transport.socket.nio.NioProcessor.<init>(NioProcessor.java:59)
W/System.err(2393):  at java.lang.reflect.Constructor.constructNative(Native Method)
W/System.err(2393):  at java.lang.reflect.Constructor.newInstance(Constructor.java:446)
W/System.err(2393):  at org.apache.mina.core.service.SimpleIoProcessorPool.<init>(SimpleIoProcessorPool.java:217)
W/System.err(2393):  at org.apache.mina.core.service.SimpleIoProcessorPool.<init>(SimpleIoProcessorPool.java:112)
W/System.err(2393):  at org.apache.mina.core.polling.AbstractPollingIoConnector.<init>(AbstractPollingIoConnector.java:93)
W/System.err(2393):  at org.apache.mina.transport.socket.nio.NioSocketConnector.<init>(NioSocketConnector.java:56)
W/System.err(2393):  at com.farben.ams.handler.AmsSendMsgBiz.sendMsg(AmsSendMsgBiz.java:54)
W/System.err(2393):  at com.farben.ams.activity.PlayActivity$startAskDmsOntimeThread.run(PlayActivity.java:219)
E/dalvikvm-gc(2393): Could not create 1220608-byte ashmem mark stack: Too many open files
E/dalvikvm-heap(2393): dvmHeapBeginMarkStep failed; aborting

Caused by: java.net.SocketException: Too many open files

通过ulimit -n命令可以查看linux系统里打开文件描述符的最大值,一般缺省值是1024,对一台繁忙的服务器来说,这个值偏小,所以有必要重新设置linux系统里打开文件描述符的最大值。那么应该在...
  • u010469632
  • u010469632
  • 2015年01月26日 18:03
  • 926

mina高并发连接导致java.io.IOException: Too many open files解决方法

这几天在实习的公司给一个项目搞测试,主要测试项目部署在Linux Server上的并发访问,即所谓的压力测试; 模拟网关,建立大量并发连接,用的是apache的mina建立的NioSocketCo...
  • canlets
  • canlets
  • 2013年12月25日 20:37
  • 2811

关于mina框架里产生too many open files的错误的解决办法

网上很多说法是增加修改可打开文件数  通过修改ulimit -n  这个命令来实现。 其实都是治标不治本的办法。 要解决这个问题,要从两个方面入手。 一个是设置session的超时状态。 比...
  • godghkj
  • godghkj
  • 2013年11月25日 20:23
  • 564

mina高并发短连接报java.io.IOException: Too many open files

mina高并发短连接导致java.io.IOException: Too many open files解决方案    这几天在解决一个用mina开发的高并发通信过程中产生的一个bug。    模...
  • smithdoudou88
  • smithdoudou88
  • 2015年08月27日 16:44
  • 506

java.net.SocketException: Too many open files

今天实施同事报现场有一个节点无法访问,把现场的weblogic日志拿回来,显示如下:                   ...
  • guogang83
  • guogang83
  • 2014年08月13日 18:25
  • 3157

关于android中的too many open files(error 24)

在android中,所有的IO操作最终都是需要句柄来操作文件实现的。句柄数量对于每一个app都有一个上限,常见的是1024个。一旦某个app同时使用的句柄数超过了这个限制,就会看到这个异常:too m...
  • bruceloveweiwei
  • bruceloveweiwei
  • 2016年09月29日 10:23
  • 1874

mina高并发短连接导致java.io.IOException: Too many open files解决方案

这几天在解决一个用mina开发的高并发通信过程中产生的一个bug。    模拟场景为:    通过定时触发启动线程模拟高并发短连接测试,测试的服务端有2个,一个是服务有起,一个没起,客户端...
  • AlbertFly
  • AlbertFly
  • 2016年06月23日 22:57
  • 1615

解决Linux下“java.net.SocketException: Too many open files”异常

背景: 项目上线后发现Telnet模块在稳定运行一段时间后会自动断开,无法登陆,后台抛出:“java.net.SocketException: Too many open files”异常。 ...
  • e_wsq
  • e_wsq
  • 2012年08月17日 11:46
  • 1153

too many open files解决办法

在/etc/security/limit.conf 最后加上如下两行: root soft nofile 32000 root hard nofile 32000...
  • hljlzc2007
  • hljlzc2007
  • 2014年09月11日 15:01
  • 2998

Too many open files解决方法

用命令ulimit -a查看 [root@test security]# ulimit -a core file size        (blocks, -c) 0 data seg size...
  • u011018979
  • u011018979
  • 2015年02月06日 13:50
  • 2120
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:求助!! android 上使用mina 出现java.net.SocketException: Too many open files
举报原因:
原因补充:

(最多只允许输入30个字)