在使用python写程序的时候,发现一个可以无限迭代的迭代器,从而可以直接将系统中的内存占满,那么占满之后会发生什么呢?

1、 创建无限迭代,生成列表,如下:

[root@python ~]# python
Python 2.7.11 (default, Mar 20 2016, 14:21:08)
[GCC 4.4.6 20110731 (Red Hat 4.4.6-3)] on linux2
Type "help", "copyright", "credits" or "license" for more information.
>>> import itertools
>>> r = map(lambda x :x*x,itertools.count(1))

2、监控使用命令vmstat

[root@python ~]# vmstat 1 -S m  #每隔一秒采集一次信息,单位为Mb

3、系统使用情况如下

procs -----------memory---------- ---swap-- -----io---- --system-- -----cpu-----
r b swpd free buff cache si so bi bo in cs us sy id wa st
1 0 0 851 15 52 0 0 0 0 414 69 34 3 63 0 0
1 0 0 610 15 52 0 0 0 0 995 7 83 17 0 0 0
1 0 0 458 15 52 0 0 0 0 616 13 70 30 0 0 0
1 0 0 345 15 52 0 0 0 0 489 9 70 30 0 0 0
1 0 0 187 15 52 0 0 0 0 694 11 77 23 0 0 0
3 2 29 50 2 18 0 0 220 41400 1154 190 71 23 0 6 0
1 2 238 65 1 13 0 0 580 191392 1232 261 49 25 0 26 0
1 2 375 50 0 12 0 0 1720 134264 1360 284 64 25 0 11 0
0 3 452 50 0 11 0 0 768 75212 758 150 38 13 0 49 0
1 1 528 62 0 9 0 0 192 74668 972 134 52 18 0 30 0
1 1 700 50 0 9 0 0 0 167244 1084 150 55 23 0 22 0
0 3 767 50 0 9 0 0 0 66068 456 48 17 12 0 71 0
1 1 808 60 0 9 0 0 1652 39688 505 191 17 9 0 74 0
0 3 952 50 0 7 0 0 504 141228 1078 191 57 20 0 23 0
0 2 1068 58 0 7 0 0 288 113176 860 127 40 21 0 40 0
2 2 1136 50 0 7 0 0 1584 66656 939 279 46 17 0 37 0
0 4 1252 50 0 7 0 0 276 113460 679 90 31 14 0 55 0
0 6 1266 53 0 8 0 0 904 13332 267 116 8 4 0 88 0
1 0 1339 63 0 7 0 0 216 71196 957 116 43 19 0 38 0
0 2 1549 52 0 7 0 0 0 205896 1196 194 49 31 0 20 0
1 0 1666 71 0 6 0 0 0 114372 948 57 43 19 0 37 0
0 2 1799 51 0 5 0 0 0 130104 1101 214 57 24 0 20 0
1 1 1922 61 0 5 0 0 0 119856 1092 132 51 23 0 26 0
0 2 2002 50 0 5 0 0 0 77788 662 103 31 17 0 52 0
2 0 2093 51 0 5 0 0 32 89104 1054 257 49 25 0 26 0
0 2 16 990 0 1 0 0 3824 19836 786 1639 21 17 0 62 0

从上面可以看出,swap使用的越来越多,free的空间越来越少,到最后达到swap的最大值之后,开始恢复内存空间。

系统的内存如下:

[root@python ~]# free -m
total used free shared buffers cached
Mem: 996 64 932 0 1 10
-/+ buffers/cache: 52 943
Swap: 2015 14 2001

4、 结论

当内存使用太多,没有剩余的内存的时候,操作系统会直接将进程杀死,如下所示:

[root@python ~]# python
Python 2.7.11 (default, Mar 20 2016, 14:21:08)
[GCC 4.4.6 20110731 (Red Hat 4.4.6-3)] on linux2
Type "help", "copyright", "credits" or "license" for more information.
>>> import itertools
>>> r = map(lambda x :x*x,itertools.count(1))
Killed

最后一个killed表示杀死进程,开始回收空间。

linux系统中内存爆满之后会如何?的更多相关文章

  1. Linux 系统中僵尸进程

    Linux 系统中僵尸进程和现实中僵尸(虽然我也没见过)类似,虽然已经死了,但是由于没人给它们收尸,还能四处走动.僵尸进程指的是那些虽然已经终止的进程,但仍然保留一些信息,等待其父进程为其收尸.配图源 ...

  2. 77 swapon-激活Linux系统中交换空间

    Linux swapon命令用于激活Linux系统中交换空间,Linux系统的内存管理必须使用交换区来建立虚拟内存. 语法 /sbin/swapon -a [-v] /sbin/swapon [-v] ...

  3. Linux系统中“动态库”和“静态库”那点事儿 /etc/ld.so.conf 动态库的后缀为*.so 静态库的后缀为 libxxx.a ldconfig 目录名

    Linux系统中“动态库”和“静态库”那点事儿 /etc/ld.so.conf  动态库的后缀为*.so  静态库的后缀为 libxxx.a   ldconfig   目录名 转载自:http://b ...

  4. Linux系统中“动态库”和“静态库”那点事儿【转】

    转自:http://blog.chinaunix.net/uid-23069658-id-3142046.html 今天我们主要来说说Linux系统下基于动态库(.so)和静态(.a)的程序那些猫腻. ...

  5. Linux系统中“动态库”和“静态库”那点事儿

    摘自http://blog.chinaunix.net/uid-23069658-id-3142046.html 今天我们主要来说说Linux系统下基于动态库(.so)和静态(.a)的程序那些猫腻.在 ...

  6. Linux系统中常见文件系统格式

    Windows常用的分区格式有三种,分别是FAT16.FAT32.NTFS格式. 在Linux操作系统里有Ext2.Ext3.Linux swap和VFAT四种格式. FAT16: 作为一种文件名称, ...

  7. 极客时间-左耳听风-程序员攻略-Linux系统、内存和网络

    程序员练级攻略:Linux系统.内存和网络 Linux 系统相关 Red Hat Enterprise Linux 文档 . Linux Insides ,GitHub 上的一个开源电子书,其中讲述了 ...

  8. Unix/Linux系统中僵尸进程是如何产生的?有什么危害?如何避免?

    如题 Unix/Linux系统中僵尸进程是如何产生的?有什么危害?如何避免? 一个进程在调用exit命令结束自己的生命的时候,其实他并没有真正的被销毁,而是留下一个称为僵尸进程(Zombie)的数据结 ...

  9. (笔记)Linux内核中内存相关的操作函数

    linux内核中内存相关的操作函数 1.kmalloc()/kfree() static __always_inline void *kmalloc(size_t size, gfp_t flags) ...

随机推荐

  1. SSIS ->> 通过Checkoints实现SSIS的包重启(Package Restartability Fullfilled By Checkoints)

    Checkpoints是实现SSIS包重载的基础.它的原理是把当前运行环境的配置.变量以及到了包运行到哪一步和哪一步失败这些信息写入到一个文件中.而且有一点很重要,Checkpoint只发生在Cont ...

  2. JavaScript DOM实战:创建和克隆元素

    DOM来创建和克隆元素. createElement()和createTextNode() createElement()和createTextNode()做的事情正如它们的名字所说的那样.最常见的J ...

  3. ActiveXObject Word.Application 打印小票

    javascript 时间格式 Date.prototype.format = function (format) { var o = { "M+": this.getMonth( ...

  4. NAND Flash【转】

    转自:http://www.cnblogs.com/lifan3a/articles/4958224.html 以Micron公司的MT29F2G08为例介绍NAND Flash原理和使用. 1. 概 ...

  5. YTU 2615: AB编程题--世界杯小组赛

    2615: AB编程题--世界杯小组赛 时间限制: 1 Sec  内存限制: 128 MB 提交: 100  解决: 35 题目描述 注:本题目自由设计,但必须使用类进行代码设计. 世界杯32支参赛队 ...

  6. R语言数据类型转换

    test for data type is.numeric(), is.character(), is.vector(), is.matrix(), is.data.frame() convert i ...

  7. java线程安全理解

    java线程安全理解 如果你的代码所在的进程中有多个线程在同时运行,而这些线程可能会同时运行这段代码.如果每次运行结果和单线程运行的结果是一样的,而且其他的变量的值也和预期的是一样的,就是线程安全的. ...

  8. HTML5学习总结——HTML5新增属性与表单元素

    一HTML5新增属性 1.1contcxtmcnu contextmenu的作用是指定右键菜单. <!DOCTYPE html> <html> <head> < ...

  9. LA 3602 DNA Consensus String

    最近审题老是一错再错,Orz 题目中说求一个Hamming值总和最小的字符串,而不是从所给字符中找一个最小的 这样的话,我们逐列处理,所求字符串当前位置的字符应该是该列中出现次数最多其次ASCII值最 ...

  10. 约束优化方法之拉格朗日乘子法与KKT条件

    引言 本篇文章将详解带有约束条件的最优化问题,约束条件分为等式约束与不等式约束,对于等式约束的优化问题,可以直接应用拉格朗日乘子法去求取最优值:对于含有不等式约束的优化问题,可以转化为在满足 KKT ...