问题: 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 生效
标签:systemd,compose,java,ulimit,initialization,nofile,40960,docker From: https://www.cnblogs.com/iyiluo/p/16785601.htmlsystemctl daemon-reload
systemctl restart docker