免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
12
最近访问板块 发新帖
楼主: xtlx2000
打印 上一主题 下一主题

[内存管理] linux内存使用过高的原因? [复制链接]

论坛徽章:
0
11 [报告]
发表于 2013-05-24 18:51 |只看该作者
chenyu105 发表于 2013-05-24 14:07
大部分花销是在low区间, 并且不是在slab,pagecache这些地方,那会是哪里? 难道是内核自己get_free_pages分配的。
看有没有哪位同学来解释一下。.



同求大牛解释,这个确实很费解

另外非常好奇,此时此刻,我用户态一个进程突然占了 500M内存,会发生什么?会OOM?还是会把这部分内存分给用户态?
比如 python -c "x='0';x = x * 1024 * 1024 * 500;"

如果 这现象可以反复重现,并且执行上面命令没崩溃,倒是有手段跟踪

论坛徽章:
2
羊年新春福章
日期:2015-04-27 16:56:53射手座
日期:2015-04-27 16:58:18
12 [报告]
发表于 2013-05-24 19:07 |只看该作者
内存用光很正常啊,只有不用到swap那边就可以

论坛徽章:
0
13 [报告]
发表于 2013-05-24 20:00 |只看该作者
内核还有slab池和page table消耗。
http://blog.yufeng.info/archives/2456 这里讲的很详细

另:你这个内存有点不正常啊,是不是虚拟机的?

论坛徽章:
22
丑牛
日期:2014-08-15 14:32:0015-16赛季CBA联赛之同曦
日期:2017-12-14 15:28:14黑曼巴
日期:2017-08-10 08:14:342017金鸡报晓
日期:2017-02-08 10:39:42黑曼巴
日期:2016-11-15 15:48:38CU十四周年纪念徽章
日期:2016-11-09 13:19:1015-16赛季CBA联赛之同曦
日期:2016-04-08 18:00:03平安夜徽章
日期:2015-12-26 00:06:30程序设计版块每日发帖之星
日期:2015-12-03 06:20:002015七夕节徽章
日期:2015-08-21 11:06:17IT运维版块每日发帖之星
日期:2015-08-09 06:20:002015亚冠之吉达阿赫利
日期:2015-07-03 08:39:42
14 [报告]
发表于 2013-05-25 14:57 |只看该作者
本帖最后由 amarant 于 2013-05-25 15:06 编辑

只要内核没用光你的内存就是没有问题的。内存使用率高,从一方面来说,是有利的。
举一个例子,假设你执行了一个cd的命令,在这个解析路径的过程中,就会用了一些内存,但是解析完成以后,内核不会马上释放。这样你下一次执行这个cd的命令就会快很多。
同样的道理,还运用在文件的读写上,这就是内核对使用过的数据缓存起来,只要内存还有,就不释放。直到内存使用到了一定的百分比之后,才开始释放那些比较久比较少访问过的缓存。
我才刚开机没多久内存的使用率就这样了:
~$ free
             total       used       free     shared    buffers     cached
Mem:       8071712    3035096    5036616          0     347016    1247304

论坛徽章:
1
双鱼座
日期:2013-08-28 13:47:26
15 [报告]
发表于 2013-05-25 17:44 |只看该作者
本帖最后由 firkraag 于 2013-05-26 09:36 编辑

Perhaps memory leaking caused by some device drivers. Or maybe used by the kernel mode stacks and the kernel modules.

论坛徽章:
16
2015亚冠之吉达阿赫利
日期:2015-08-17 11:21:462015年迎新春徽章
日期:2015-03-04 09:58:11酉鸡
日期:2014-12-07 09:06:19水瓶座
日期:2014-11-04 14:23:29天秤座
日期:2014-03-02 08:57:52双鱼座
日期:2014-02-22 13:07:56午马
日期:2014-02-14 11:08:18双鱼座
日期:2014-02-13 11:09:37卯兔
日期:2014-02-06 15:10:34子鼠
日期:2014-01-20 14:48:19戌狗
日期:2013-12-19 09:37:46射手座
日期:2013-12-19 09:33:47
16 [报告]
发表于 2013-06-06 15:46 |只看该作者
回复 10# xtlx2000



echo m > /proc/sysrq-trigger


dmesg的log发出来

   

论坛徽章:
0
17 [报告]
发表于 2013-06-08 11:15 |只看该作者
回复 16# embeddedlwp


    dmesg_output.rar (16.38 KB, 下载次数: 4)

论坛徽章:
16
2015亚冠之吉达阿赫利
日期:2015-08-17 11:21:462015年迎新春徽章
日期:2015-03-04 09:58:11酉鸡
日期:2014-12-07 09:06:19水瓶座
日期:2014-11-04 14:23:29天秤座
日期:2014-03-02 08:57:52双鱼座
日期:2014-02-22 13:07:56午马
日期:2014-02-14 11:08:18双鱼座
日期:2014-02-13 11:09:37卯兔
日期:2014-02-06 15:10:34子鼠
日期:2014-01-20 14:48:19戌狗
日期:2013-12-19 09:37:46射手座
日期:2013-12-19 09:33:47
18 [报告]
发表于 2013-06-08 12:20 |只看该作者
本帖最后由 embeddedlwp 于 2013-06-08 12:21 编辑

回复 17# xtlx2000


lowmem的各种统计加起来比实际内存少了些,检查一下memory leak吧。

下边这个配置上。

  │ Symbol: DEBUG_KMEMLEAK [=n]                                                                                                                          │  
  │ Type  : boolean                                                                                                                                      │  
  │ Prompt: Kernel memory leak detector                                                                                                                  │  
  │   Location:                                                                                                                                          │  
  │ (4) -> Kernel hacking


echo scan > /sys/kernel/debug/kmemleak 开始扫描
cat /sys/kernel/debug/kmemleak 查看结果

不过这个工具经常会有误报,你试试吧
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP