docker无法用exec进入容器的问题[cannot allocate memory]

今同事小飞飞遇到一个坑爹的问题,可乐死我了….  我发现他们组docker用的量也不少,但是经常出问题….    这次是无法使用docker -it exec 进入容器。奇怪的是docker的提示是 内存无法分配,我们ps aux看了下docker的后端进程,内存已经用到40G了… …    

[ruifengyun@wx-social-web01 socialx]$ docker exec -it wh-online-deploy bash
Cannot run exec command 7559431b2205817b2405d33cc22339dcf90f9e3a9f8c01b2f93e7562bcf1f279 in container c326f588d91bf77a3234ac0a063543e8b27d69f43934b486593f2a1c2dd33f61: fork/exec /usr/bin/docker: cannot allocate memory Error starting exec command in container                                                                      

docker的版本是1.5                   

[ruifengyun@wx-social-web01 socialx]$ docker -v
Docker version 1.5.0, build a8a31ef/1.5.0

                                                                                                                          

[ruifengyun@wx-social-web01 socialx]$ free -m

             total       used       free     shared    buffers     cached
Mem:         64375      48876      15499          0        505       9739
-/+ buffers/cache:      38631      25744
Swap:            0          0          0

看了下docker的github里的issue,大多数人把overcommit_memory配置成1或者2 .

[ruifengyun@wx-social-web01 socialx]$ cat /proc/sys/vm/overcommit_memory
0
[ruifengyun@wx-social-web01 socialx]$ cat /proc/sys/vm/overcommit_ratio
50

您还可以配置交换空间;在这种情况下,进程不会被杀死,但如果内存使用量增长太多,系统可能会变得反应迟钝。

这虽然在一定程度上保证不死,但是问题是docker为毛占用了40G的内存…   最后的解决方法是,万能重启….


关于 docker cannot allocate memory Error starting exec command in container 的继续探讨…..

7-13,有遇到这jb问题了….. 已经确定其中一个容器里面的应用有个模块有内存泄漏的问题,fix解决…. 

但是让人奇怪的是,从docker主机外面查看内存占用,不会看到具体的进程,只会看到docker进程占用了50g的内存….



大家觉得文章对你有些作用! 如果想赏钱,可以用微信扫描下面的二维码,感谢!
另外再次标注博客原地址  xiaorui.cc

5 Responses

  1. feifeiiiiiiiiiii 2015年7月20日 / 下午9:13

    现在又遇到这问题了

    • 峰云就她了 2015年7月22日 / 上午10:29

      你丫写得node.js不严谨吧? 要不就是这一版的docker内存泄露问题

  2. 胶东牛国磊 2015年7月14日 / 上午10:52

    看来存在内存泄露,docker还需继续成熟。

  3. 360sa 2015年6月12日 / 上午6:37

    果然是重启,我门也是

发表评论

邮箱地址不会被公开。 必填项已用*标注