现象:
麒麟v10系统部署mysql内存占用过高,如下刚部署完成占用16G 内存
原因:
百度得知:open_files_limit初始化太高
【Docker】(全网首发)Kylin V10 下 MySQL 容器内存占用异常的解决方法_kylin10 mysql docker-CSDN博客 后续解决方法主要参考该文章
解决方法:
一:修改官方镜像中的启动脚本
entrypoint.sh
entrypoint.sh增加以下内容
代码语言:javascript复制# 解决Kylin V10兼容性问题
ulimit -n 1048576 && ulimit -a >/dev/null && ulimit -n
编写Dockerfile用来替换entrypoint.sh mysql中的entrypoint.sh使用的软连接,实际为usr/local/bin/docker-entrypoint.sh
代码语言:javascript复制[root@node1 test]# cat Dockerfile
FROM mysql:5.7.35
COPY entrypoint.sh usr/local/bin/docker-entrypoint.sh
重命名为之前版本
代码语言:javascript复制docker build -t mysql:5.7.36 .
docker tag mysql:5.7.36 dockerhub.kubekey.local/other/mysql:5.7.35
修改后
二:修改docker.service参数
Docker 守护进程通过 docker.service 文件的 LimitNOFILE 参数限制容器的 open files 在安装 Docker 时使用了 LimitNOFILE=infinity 这个默认配置,导致 Kylin V10 下容器取值为 1073741816(即 2^30),在其他操作系统如centos,ubuntu,Anolis等操作系统中值为1048576。 因此问题的解决方法也可以如下:
代码语言:javascript复制#编辑对应的 docker.service 文件,修改如下:
LimitNOFILE=1048576
#保存退出后执行
systemctl daemon-reload && systemctl restart docker
将mysql换回官网版本后查看内容占用情况
结论:
第二种方式可以作为一种通用方案使用,以规避 MySQL 以外的其他容器出现相同问题。