技术头条 - 一个快速在微博传播文章的方式     搜索本站
您现在的位置首页 --> Linux --> 处理Too open many files

处理Too open many files

浏览:2360次  出处信息

最近遇到的一个问题,其实Linux 下的Too open many files 问题很普遍,常用的解决办法 http://www.javaeye.com/topic/240389,我这里的情况还有些不一样,具体情况是,在项目中使用memcached作为缓存,同时使用xmemcached作为客户端包,程序中由于大量从网络机器中获取缓存数据,打开大量的IO,项目使用了5台机器负载均衡,唯独有一台机器报出以下异常,其他机器正常:

以下是代码片段:
[2011-01-27 18:24:35] 415615 [resin-tcp-connection-*:10002-8] INFO impl.AbstractController  - Controller has been stopped.
[2011-01-27 18:24:35] java.io.IOException: Too many open files
[2011-01-27 18:24:35]  at sun.nio.ch.EPollArrayWrapper.epollCreate(Native Method)
[2011-01-27 18:24:35]  at sun.nio.ch.EPollArrayWrapper.<INIT>(EPollArrayWrapper.java:68)
[2011-01-27 18:24:35]  at sun.nio.ch.EPollSelectorImpl.<INIT>(EPollSelectorImpl.java:52)
[2011-01-27 18:24:35]  at sun.nio.ch.EPollSelectorProvider.openSelector(EPollSelectorProvider.java:18)
[2011-01-27 18:24:35]  at java.nio.channels.Selector.open(Selector.java:209)
... ...

问题显然是处在epoll上,最后修改了一下系统参数:
echo “1024″ > /proc/sys/fs/epoll/max_user_instances
echo “1306071″ > /proc/sys/fs/epoll/max_user_max_user_watches

建议继续学习:

  1. Nginx源码分析-Epoll模块    (阅读:3931)
  2. redis源代码分析 - event library    (阅读:3160)
  3. epoll 事件之 EPOLLRDHUP    (阅读:2941)
QQ技术交流群:445447336,欢迎加入!
扫一扫订阅我的微信号:IT技术博客大学习
© 2009 - 2024 by blogread.cn 微博:@IT技术博客大学习

京ICP备15002552号-1