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小时+