docker-compose 启动 java 容器时报错 library initialization failed - unable to allocate file descriptor table

问题: docker-compose 启动 java 容器时报错

library initialization failed - unable to allocate file descriptor table - out of memoryPicked up JAVA_TOOL_OPTIONS: xxx
无法启动

排查: 搜索一下,发现是 ulimit 参数问题
查看系统 ulimit 参数,发现值设置的过小,只有 1024,
修改 /etc/security/limits.conf 设置

* soft noproc 40960
* hard noproc 40960
* soft nofile 40960
* hard nofile 40960

重启 docker 发现故障依旧,还是报错。
单独给 docker 添加 --ulimit nofile=122880:122880 启动参数,发现可以解决问题,但是每个容器都要加参数,非常麻烦。
最后终于发现可能是 systemd 的问题
running-jdk-8-in-docker-suddenly-broken

解决:
/etc/systemd/system/ 或者 /usr/lib/systemd/system/
找到 docker.service 文件,在 ExecStart=/usr/bin/dockerd 后面添加 --default-ulimit nofile=65536:65536 参数

重启 docker 生效

systemctl daemon-reload

systemctl restart docker

posted @ 2022-10-12 18:48  iyiluo  阅读(3080)  评论(0编辑  收藏  举报