java.net.SocketException: Bad file descriptor (Write failed)

mac 报错 java.net.SocketException: Bad file descriptor (Write failed)

这两天淘了台mac,然后想将开发环境迁移到mac上,障碍重重,一是公司有自己的开发平台,二是mac几乎没人用,也没人适配

正题说这个报错
报错出来的问题是连接pg数据库,报这个错:

Caused by: java.net.SocketException: Bad file descriptor (Write failed)
	at java.net.SocketOutputStream.socketWrite0(Native Method)
	at java.net.SocketOutputStream.socketWrite(SocketOutputStream.java:111)
	at java.net.SocketOutputStream.write(SocketOutputStream.java:155)
	at java.io.BufferedOutputStream.flushBuffer(BufferedOutputStream.java:82)
	at java.io.BufferedOutputStream.flush(BufferedOutputStream.java:140)
	at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:459)
	at java.net.Socket.connect(Socket.java:606)
	at org.postgresql.core.PGStream.createSocket(PGStream.java:231)
	at org.postgresql.core.PGStream.<init>(PGStream.java:95)
	at org.postgresql.core.v3.ConnectionFactoryImpl.tryConnect(ConnectionFactoryImpl.java:98)
	at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:213)

但是切换到 oracle 数据库就不报错
就一直搜这个错误,但是网上的解决办法少之又少
不过还是有些端倪:
https://stackoverflow.com/questions/44763989/jedis-bad-file-descriptor-error
https://xhao.io/2017/01/nio-open-file/
就是这个启发了我,认为非常可能是文件数打开的限制问题

然后就用

sysctl kern.maxfiles
sysctl kern.maxfilesperproc

sysctl -w kern.maxfiles=204800
sysctl -w kern.maxfilesperproc=180000

疯狂扩大,但还是不好使
就又发现一个命令

ulimit -n 40960

执行后,解决!

耗时 6小时+

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值