hhhvs 2013-11-25 11:19 采纳率: 100%
浏览 3255
已采纳

Log4J中Logger如何关闭IO流

在项目由于日志需要对日志进行扩展,根据交易号和日期生成logger对象放入队列中,每天会清除之前的日志对象,刚开始没有发现问题,大约到了1个月左右,生产中报了java.net.SocketException:too many open files异常,首先整个系统中除了日志外,只有读取配置文件的两个本地IO操作,其他的是网络IO,其次在早上没有大规模并发请求,除了心跳报文外,其他无请求,综合上述可以将问题定位在日志上。仔细想每天我只是把日志对象从Hashtable中remove了,但是被remove的Logger对象并未立刻被GC,我想在remove后,将Logger中IO资源立即释放,求高手指点。

  • 写回答

1条回答

  • Todd_Pointer 2013-11-25 16:15
    关注

    确定是日志文件的问题? 我Java不太熟, 但至少读写文件不会出SocketException应该是肯定的吧?

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 程序不包含适用于入口点的静态Main方法
  • ¥15 素材场景中光线烘焙后灯光失效
  • ¥15 请教一下各位,为什么我这个没有实现模拟点击
  • ¥15 执行 virtuoso 命令后,界面没有,cadence 启动不起来
  • ¥50 comfyui下连接animatediff节点生成视频质量非常差的原因
  • ¥20 有关区间dp的问题求解
  • ¥15 多电路系统共用电源的串扰问题
  • ¥15 slam rangenet++配置
  • ¥15 有没有研究水声通信方面的帮我改俩matlab代码
  • ¥15 ubuntu子系统密码忘记