docker容器内存占用过高(例如mysql)
简介
- 该文章适用于配置低,特别是内存低的服务器,在用容器部署服务时有可能会因为容器占用内存过高导致服务挂掉时参考解决(不是运行在容器里的话,同理也可以修改mysql的配置文件限制内存占用)
- docker部署mysql拉下来就能跑,默认配置下mysql的内存占用能达到500-600M,这对低配的1核1G内存的服务器来说是吃不消的
最近用docker部署了个系统,服务器配置是1G的内存,跑了两个容器,一个wbe服务,一个是mysql,使用的过程中发现服务经常挂,一开始因为运行的服务不太重要并且没时间处理就没太在意,每次挂了我就上去restart重启一下镜像。后面找了个时间排查了问题,查看了下docker-compose的日志,发现是因为运行的mysql容器占用内存过高导致的,在此记录下解决过程。
1.排查原因
docker-compose logs
从第1和第2条的error发现是因为mysql容器占用的内存过高,导致mysql挂了(shutdown)
2.解决
上网搜了一下,针对该问题一般的解决方法一般都是
- 1)进入到容器里修改mysql的配置文件,限制mysql容器的内容占用大小
- 2)增大服务器的swap
- 3)也可以在容器启动的时候增加限制内存的参数
--innodb-buffer-pool-size=64M
,详细百度
结合查询了其他资料,决定使用第一种解决方案。(增大swap治标不治本,而且增大swap是对系统而言的,swap不建议增大太多,扫描类的服务如果不限制容器的内存很容易爆
步骤如下:
-
1.docker ps
-
2.docker exec -it id bash
-
3.进入/etc/mysql/conf.d目录后,vim docker.cnf文件
首先需要安装vimapt-get update apt-get install vim
然后vim docker.cnf,编辑后保存退出
最后exit退出容器后,然后docker-compose restart即可
3.优化前后内存占用对比
优化前
优化后,对比还是比较明显的
4.附:
-
docker容器占用资源查看指令:docker stats
-
服务器内存资源情况查看:free -m/-g/-k #-m/-g/-k是指查看的单位
-
为什么调整内核用内存,尽量不用swap的参考
-
网友们的讨论
如果加班只是玩手机、刷微博,那一定是煎熬。如果是坚持的修炼,那一定收益颇丰。