前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >修复麒麟V10下Mysql内存占用过高问题

修复麒麟V10下Mysql内存占用过高问题

作者头像
编码如写诗
发布2024-08-30 11:35:30
1050
发布2024-08-30 11:35:30
举报
文章被收录于专栏:编码如写诗

现象:

麒麟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 以外的其他容器出现相同问题。

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2024-08-08,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 编码如写诗 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 现象:
  • 原因:
  • 解决方法:
    • 一:修改官方镜像中的启动脚本
      • 二:修改docker.service参数
      • 结论:
      相关产品与服务
      容器服务
      腾讯云容器服务(Tencent Kubernetes Engine, TKE)基于原生 kubernetes 提供以容器为核心的、高度可扩展的高性能容器管理服务,覆盖 Serverless、边缘计算、分布式云等多种业务部署场景,业内首创单个集群兼容多种计算节点的容器资源管理模式。同时产品作为云原生 Finops 领先布道者,主导开源项目Crane,全面助力客户实现资源优化、成本控制。
      领券
      问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档