SWAP的用处 Solaris7 交流 --- swap管理

五、swap管理(SWAP的用处)

本文介绍了在Solaris平台上Swap(交换)空间的基本概念、实现的原理以及对Swap(

交换)空间进行监控的方法和调整的策略 。

什么是SWAP(交换)空间

对于一般的Solaris系统管理员来说,很少会接触Swap(交换)空间,在他们看来Swap

区只不过是磁盘上的一两个分区或是几个Swap(交换)文件,当系统没有足够的物理内

存来处理当前进程的时候,就利用Swap(交换)空间作为虚拟内存的临时存储空间,这

种说法从技术角度来说是没有错的,但Solaris在实现Swap时有其非常独特的地方 。

SWAP空间作用

众所周知,现代操作系统都实现了“虚拟内存”这一技术,不但在功能上突破了物理内

存的限制,使程序可以操纵大于实际物理内存的空间,更重要的是“虚拟内存”是隔离

每个进程的安全保护网,使每个进程不受其他程序的干扰 。

Swap空间的作用可简单描述为:当系统的物理内存不够用的时候,就需要将物理内存中

的一部分空间释放出来,以供当前运行的程序使用 。那些被释放的空间可能来自一些很

长时间没有什么操作的程序,这些被释放的空间被临时保存到Swap空间中,等到那些程

序要运行时,再从Swap中恢复保存的数据到内存中 。这样,系统总是在物理内存不够时

,才进行Swap交换 。这种现象对于计算机使用者是经常遇到的 。

有一点要声明的是,并不是所有从物理内存中交换出来的数据都会被放到Swap中(如果

这样的话,Swap会不堪重负),有相当一部分的数据直接交换到文件系统 。例如,有的

程序会打开一些文件,对文件进行读写(其实每个程序都至少打开一个文件,那就是运行

程序本身),当这些程序的内存空间需要交换出去时,文件部分的数据就没有必要放到

Swap空间中了,如果是读文件操作,那么内存数据直接就释放了,不需要交换出来,因

为下次需要时,直接从文件系统就能恢复;如果是写文件,只需要将变化的数据保存到文

件中,以便恢复 。但是那些用malloc(3C)和new函数生成的对象的数据则不同,需要

Swap空间,因为它们在文件系统中没有相应的“储备”文件,因此被称为“匿名”

(Anonymous)的内存数据,这类数据还包括堆栈中的一些状态和变量数据等,所以说,

Swap空间是“匿名”数据的交换空间 。

Swap的配置对性能的影响

太多的Swap空间会浪费磁盘的空间,而太少的Swap空间,系统则会发生错误 。

如果系统的物理内存用光了,你的系统就会跑得慢,但仍能运行;如果Swap空间用光了

,那么系统就会发生错误 。例如,Web服务器能根据不同的请求数量衍生出多个服务进程

(或线程),如果Swap空间用完,则服务进程无法进动,通常会出现"application is

out of memory"的错误,严重时会造成服务进程的死锁 。因此Swap空间的分配是很重要

的 。

通常情况下,Swap空间应大于或等于物理内存的大小,最小不应小于64M,通常Swap空间

的大小应是物理内存的2-2.5倍(Solaris 2以上的版本有所变化,见下文) 。但根据不

同的应用,应有不同的配置:如果是小的桌面系统,只需要较小的Swap空间,而大的服

务器系统则视情况不同需要不同大小的Swap空间 。特别是数据库服务器和Web服务器会随

着访问量的增加,对Swap 空间的要求也会增加,具体配置参见各自服务器产品的说明 。

另外,Swap分区的数量对性能也有很大的影响 。因为Swap交换的操作是磁盘I/O的操作,

推荐阅读