关于基础的Swap分区知识讲解

运维 系统运维
Swap分区的原理是一个较复杂的问题,需要大量的篇幅来说明。在这里只作简单的介绍,在以后的文章中将和大家详细讨论Swap实现的细节。

Swap分区,即交换区,除了安装Linux的时候,有多少人关心过它呢?其实,Swap分区的调整对Linux服务器,特别是Web服务器的性能至关重要。通过调整Swap分区,有时可以越过系统性能瓶颈,节省系统升级费用。

Swap分区的原理是一个较复杂的问题,需要大量的篇幅来说明。在这里只作简单的介绍,在以后的文章中将和大家详细讨论Swap实现的细节。

众所周知,现代操作系统都实现了“虚拟内存”这一技术,不但在功能上突破了物理内存的限制,使程序可以操纵大于实际物理内存的空间,更重要的是,“虚拟内存”是隔离每个进程的安全保护网,使每个进程都不受其它程序的干扰。

Swap空间的作用可简单描述为:当系统的物理内存不够用的时候,就需要将物理内存中的一部分空间释放出来,以供当前运行的程序使用。那些被释放的空间可能来自一些很长时间没有什么操作的程序,这些被释放的空间被临时保存到Swap空间中,等到那些程序要运行时,再从Swap分区中恢复保存的数据到内存中。这样,系统总是在物理内存不够时,才进行Swap交换。

计算机用户会经常遇这种现象。例如,在使用Windows系统时,可以同时运行多个程序,当你切换到一个很长时间没有理会的程序时,会听到硬盘“哗哗”直响。

这是因为这个程序的内存被那些频繁运行的程序给“偷走”了,放到了Swap分区中。因此,一旦此程序被放置到前端,它就会从Swap区取回自己的数据,将其放进内存,然后接着运行。

需要说明一点,并不是所有从物理内存中交换出来的数据都会被放到Swap分区中(如果这样的话,Swap就会不堪重负),有相当一部分数据被直接交换到文件系统。

例如,有的程序会打开一些文件,对文件进行读写(其实每个程序都至少要打开一个文件,那就是运行程序本身),当需要将这些程序的内存空间交换出去时,就没有必要将文件部分的数据放到Swap分区空间中了,而可以直接将其放到文件里去。

如果是读文件操作,那么内存数据被直接释放,不需要交换出来,因为下次需要时,可直接从文件系统恢复;如果是写文件,只需要将变化的数据保存到文件中,以便恢复。

但是那些用malloc和new函数生成的对象的数据则不同,它们需要Swap分区空间,因为它们在文件系统中没有相应的“储备”文件,因此被称作“匿名”(Anonymous)内存数据。这类数据还包括堆栈中的一些状态和变量数据等。所以说,Swap空间是“匿名”数据的交换空间。

【编辑推荐】

  1. 删除多余的Unix Swap空间
  2. Ubuntu系统引导程序和SWAP
  3. Linux建立Swap分区文件并自动mount
  4. 让你学会SUSE交换空间swap的操作
  5. Ubuntu下优化swap交换分区攻略
责任编辑:小霞
相关推荐

2010-05-24 12:27:48

swap分区

2014-08-08 09:56:28

LinuxSwap分区

2010-05-24 13:13:25

Swap空间

2010-04-21 11:54:22

Unix 命令

2017-08-15 11:00:33

LinuxSwap

2010-05-11 10:43:10

Unix awk

2010-04-23 17:09:25

Aix文件系统

2010-05-13 15:24:24

2011-05-12 10:18:41

数据库基础知识

2009-11-23 19:24:01

PHP面向对象编程

2009-10-23 18:29:02

linux Debia

2010-05-12 16:12:18

2009-12-18 13:49:04

2010-05-18 14:47:58

IIS服务器

2010-06-12 15:49:54

TCP IP协议基础知

2009-11-19 15:35:51

路由器基础知识

2015-05-28 15:16:19

交换机

2009-01-14 13:19:45

Ubuntu优化swap

2010-03-05 14:33:19

Ubuntu硬盘分区

2010-05-12 17:21:00

IIS 服务器
点赞
收藏

51CTO技术栈公众号