在使用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. SQL Server ->> 关于究竟ALTER INDEX ... REBUILD会不会导致改变索引选项和Filegroup的验证

    其实之前做过类型的验证,不过影响不是特别深,只是记得不会改变DATA COMPRESSION,那今天再次遇到这个问题就再拿出来验证一下.随便写个脚本验证下.ALTER INDEX ... REBUIL ...

  2. github简单使用教程(转)

    github是一个基于git的代码托管平台,付费用户可以建私人仓库,我们一般的免费用户只能使用公共仓库,也就是代码要公开.对于一般人来说公共仓库就已经足够了,而且我们也没多少代码来管理,O(∩_∩)O ...

  3. c#对文件进行MD5加密校验

    public static string GetFileMd5Hash(string strFileFullPath) { // Create a new instance of the MD5Cry ...

  4. spring各个包之间的依赖关系

    从图中可以看到: 1.spring core,spring beans被其他较多包依赖,spring aop,spring context,spring expression分别被两个包依赖,而spr ...

  5. ftp 建立、配置、实用软件 fileZilla server

    ftp 建立.配置.实用软件  fileZilla server

  6. 【Android】MTK Android 编译命令

    命令格式:./maketek [option] [project] [action] [modules] Option: -t ,-tee :输出log信息到当前终端 -o , -opt=-- : 编 ...

  7. 推荐开源Api文档生成工具——Doxygen

    http://www.stack.nl/~dimitri/doxygen/index.html 非常的方便. 2步生成API文档. 具体信息见官网哟!

  8. [转载]流式大数据处理的三种框架:Storm,Spark和Samza

    许多分布式计算系统都可以实时或接近实时地处理大数据流.本文将对三种Apache框架分别进行简单介绍,然后尝试快速.高度概述其异同. Apache Storm 在Storm中,先要设计一个用于实时计算的 ...

  9. openfire源码分析

    启动流程 Socket接口 Socket通信使用Mina框架实现,是XMPP协议的处理入口,具体为: 消息接收后由不同的节处理器处理: StanzaHandler基础消息类型,之后进行消息路由: 最后 ...

  10. poj 2192 (DP)

    这个题题目意思是给你三个字符串str1,str2,str3.将str3从左自右扫描,去匹配str1和str2中的元素,不可重复,若存在一种匹配方法使得str1和str2都被匹配完全了,则输出yes,否 ...