Linux系统交换空间介绍

交换空间是当今计算的一个共同方面,不管操作系统如何。Linux使用交换空间来增加主机可用的虚拟内存量。它可以在常规文件系统或逻辑卷上使用一个或多个专用交换分区或交换文件。

在一台典型的计算机中有两种基本的内存类型。第一种类型,随机存取存储器(RAM),用于存储数据和程序,而这些数据和程序正在由计算机积极使用。除非程序和数据存储在RAM中,否则计算机无法使用它们。RAM是易失性内存;也就是说,如果关闭计算机,存储在RAM中的数据就会丢失。
硬盘是用于长期存储数据和程序的磁性介质.磁性介质是非易失性的;存储在磁盘上的数据即使从计算机中移除电源也保持不变。CPU(中央处理单元)不能直接访问硬盘上的程序和数据;必须首先将其复制到RAM中,这就是CPU可以访问其编程指令和这些指令要操作的数据的地方。在引导过程中,计算机将特定的操作系统程序(如内核、init或systemd)以及硬盘驱动器中的数据复制到RAM中,由计算机的处理器CPU直接访问。

交换空间

交换空间是现代Linux系统中的第二种内存类型。交换空间的主要功能是当实际内存被填满,需要更多的空间时,用磁盘空间代替RAM内存。

例如,假设您有一个具有8GB RAM的计算机系统。如果您启动的程序不填充该RAM,一切都是好的,不需要交换。但是假设当您添加更多的行时,您正在处理的电子表格会增长,并且,再加上正在运行的所有其他内容,现在将填充所有的RAM。如果没有可用的交换空间,您将不得不停止电子表格的工作,直到您可以通过关闭一些其他程序来释放一些有限的RAM。

内核使用内存管理程序来检测最近没有使用内容的内存块,也就是页面。内存管理程序将这些相对较少使用的内存页交换到专门指定用于“分页”或交换的硬盘驱动器上的一个特殊分区。这将释放RAM,并为将更多数据输入电子表格腾出空间。内核的内存管理代码会跟踪那些交换到硬盘上的内存页,如果需要的话,可以将它们分页回RAM。

Linux计算机中的内存总量是RAM加上交换空间,称为虚拟存储器.

Linux交换的类型

Linux提供了两种类型的交换空间。默认情况下,大多数Linux安装都会创建交换分区,但也可以使用特殊配置的文件作为交换文件。交换分区正是它的名称所暗示的-一个标准磁盘分区,由mkswap命令。

如果没有可用的磁盘空间来创建新的交换分区,或者在卷组中可以为交换空间创建逻辑卷,则可以使用交换文件。这只是一个常规文件,它被创建并预先分配到指定的大小。然后mkswap命令将其配置为交换空间。除非绝对必要,否则我不建议使用文件作为交换空间。

震荡

当整个虚拟内存(包括RAM和交换空间)几乎满时,就会发生震荡。系统在交换空间和RAM之间花费大量的时间分页内存块,然后再分页,这样就只剩下很少的时间用于实际的工作了。这方面的典型症状是显而易见的:系统变得缓慢或完全没有响应,硬盘驱动器的活动几乎不断地亮着。

如果您能够设法发出如下命令free这显示了CPU负载和内存使用情况,您将看到CPU负载非常高,可能是系统中CPU核心数量的30至40倍。另一个症状是RAM和交换空间几乎都被完全分配了。

之后,查看SAR(系统活动报告)数据也可以显示这些症状。我在我工作的每一个系统上安装了SAR,并使用它进行修复后的法医分析。

适当的交换空间是多少?

许多年前,应该在硬盘上分配的交换空间数量的经验法则是计算机中安装的RAM数量的2倍(当然,大多数计算机的RAM是以KB或MB计算的)。因此,如果计算机有64 KB的RAM,128 KB的交换分区将是最佳大小。这条规则考虑到了这样一个事实,即当时RAM的大小通常很小,为交换空间分配超过2X的RAM并不能提高性能。由于交换内存超过两倍,大多数系统花费的时间比实际执行有用的工作花费的时间更多。

RAM已经成为一种廉价的商品,现在大多数电脑都有大量的RAM,可以扩展到几十GB。我的大多数较新的计算机至少有8GB的RAM,一台有32 GB,我的主工作站有64 GB。我的旧电脑有4到8GB的内存。

当处理具有大量RAM的计算机时,交换空间的限制性能因子远远低于2X乘法器。Fedora 28,定义了当前交换空间分配的思路。我在下面列出了该文件中的一些讨论和建议表。

下表提供了交换分区的推荐大小,这取决于系统中的RAM数量以及是否需要为系统冬眠提供足够的内存。推荐的交换分区大小是在安装期间自动确定的。但是,为了允许休眠,您需要在自定义分区阶段编辑交换空间。

表1:Fedora 28文档中推荐的系统交换空间

系统RAM数量 推荐交换空间 推荐与休眠的交换
小于2GB RAM数量的2倍 RAM数量的3倍
2GB-8GB 等于RAM的数量 RAM数量的2倍
8 GB-64 GB 内存数量的0.5倍 1.5倍的RAM数量
超过64 GB 工作负荷依赖 不建议冬眠

在上面列出的每个范围之间的边界(例如,具有2GB、8GB或64 GB系统RAM的系统),对选择的交换空间和休眠支持使用谨慎。如果您的系统资源允许的话,增加交换空间可能会带来更好的性能。

当然,大多数Linux管理员对于交换空间的适当数量有自己的想法-以及几乎所有其他的东西。下表2是我根据个人在多种环境中的经验提出的建议。这些可能不适用于您,但与表1一样,它们可能会帮助您开始工作。

表2:作者推荐的系统交换空间

RAM数量 推荐交换空间
≤2GB 2x RAM
2GB-8GB =RAM
>8GB 8GB

这两个表中的一个考虑因素是,随着RAM数量的增加,超过某个点,添加更多的交换空间只会在交换空间几乎被填满之前就会导致混乱。如果您在遵循这些建议的同时,虚拟内存太少,则应该在可能的情况下添加更多的RAM,而不是更多的交换空间。与影响系统性能的所有建议一样,请使用对特定环境最有效的建议。这将需要时间和精力来根据您的Linux环境中的条件进行实验和进行更改。

将更多的交换空间添加到非lvm磁盘环境中。

由于已经安装了Linux的主机上对交换空间的需求发生了变化,可能需要修改为系统定义的交换空间的数量。此过程可用于任何需要增加交换空间的一般情况。它假定有足够的可用磁盘空间。此过程还假定磁盘在“原始”EXT 4和交换分区中分区,不使用逻辑卷管理(LVM)。

要采取的基本步骤很简单:

  1. 关闭现有的交换空间。
  2. 创建一个所需大小的新交换分区。
  3. 重新读取分区表。
  4. 将分区配置为交换空间。
  5. 添加新的分区/etc/fSTAB。
  6. 打开交换。

不应该需要重新启动。

为了安全起见,在关闭交换之前,您至少应该确保没有运行应用程序,也没有使用交换空间。这,这个,那,那个free或top命令可以告诉您是否正在使用交换空间。为了更安全,您可以恢复到运行级别1或单用户模式。

使用关闭所有交换空间的命令关闭交换分区:

swapoff -a

现在,在硬盘上显示现有分区。

fdisk -l

这将显示每个驱动器上的当前分区表。按编号标识当前交换分区。

启动fdisk在与命令交互的模式下:

fdisk /dev/<device name>

例如:

fdisk /dev/sda

在这一点上,fdisk现在是交互式的,并且将只在指定的磁盘驱动器上运行。

使用fdiskp子命令来验证磁盘上是否有足够的空闲空间来创建新的交换分区。硬盘上的空间以512字节块和起始和结束柱面数表示,因此您可能需要做一些计算来确定分配分区之间和末尾的可用空间。

使用n命令创建一个新的交换分区。fdisk会问你启动汽缸的问题。默认情况下,它选择编号最低的可用圆柱.如果希望更改,请键入起始气缸的数目。

这,这个,那,那个fdisk命令现在允许您以多种格式输入分区的大小,包括最后一个圆柱号或以字节、KB或MB为单位的大小。输入4000米,这将在新分区上提供大约4GB的空间(例如),然后按Enter键。

使用p子命令,以验证分区是否按您指定的方式创建。注意,除非使用结束圆柱号,否则分区可能不是您指定的。这,这个,那,那个fdisk命令只能在整个圆柱上以增量方式分配磁盘空间,因此分区可能比指定的要小或大一些。如果分区不是您想要的,您可以删除它并再次创建它。

现在有必要指定新分区为交换分区。分命令t允许您指定分区的类型。所以进入t,指定分区号,当它请求十六进制代码分区类型时,类型82,即Linux交换分区类型,然后按Enter键。

当您对所创建的分区感到满意时,请使用w命令将新分区表写入磁盘。这,这个,那,那个fdisk程序在完成修改后的分区表后将退出并返回到命令提示符。您可能会收到以下消息:fdisk完成编写新分区表:

The partition table has been altered!
Calling ioctl() to re-read partition table.
WARNING: Re-reading the partition table failed with error 16: Device or resource busy.
The kernel still uses the old table.
The new table will be used at the next reboot.
Syncing disks.

此时,您可以使用partprobe命令强制内核重新读取分区表,以便不需要执行重新启动。

partprobe

现在使用以下命令fdisk -l要列出分区和新的交换分区,应该在列出的分区中。确保新的分区类型是“Linux交换”。

为了指向新的交换分区,必须修改/etc/fSTAB文件。现有的行可能如下所示:

LABEL=SWAP-sdaX  swap    swap  defaults   0 0

哪里X是分区号。根据新交换分区的位置,添加一个类似于此的新行:

/dev/sdaY     swap    swap  defaults   0 0

确保使用正确的分区号。现在,您可以执行创建交换分区的最后一步。使用mkswap命令将分区定义为交换分区。

mkswap /dev/sdaY

最后一步是使用以下命令打开交换:

swapon -a

您的新交换分区现在与以前存在的交换分区一起联机。您可以使用free或top验证这一点的命令。

将交换添加到lvm磁盘环境中。

如果您的磁盘安装程序使用LVM,则更改交换空间将相当容易。同样,这假设当前交换卷所在的卷组中有可用的空间。默认情况下,LVM环境中FedoraLinux的安装过程会将交换分区创建为逻辑卷。这很容易,因为您可以简单地增加交换卷的大小。

以下是在LVM环境中增加交换空间所需的步骤:

  1. 关掉所有交换。
  2. 增加指定用于交换的逻辑卷的大小。
  3. 将调整大小的卷配置为交换空间。
  4. 打开交换。

首先,让我们使用lvs命令(列出逻辑卷)。

[root@studentvm1 ~]# lvs
 LV   VG        Attr    LSize Pool Origin Data% Meta% Move Log Cpy%Sync Convert
 home  fedora_studentvm1 -wi-ao---- 2.00g
 pool00 fedora_studentvm1 twi-aotz-- 2.00g        8.17  2.93
 root  fedora_studentvm1 Vwi-aotz-- 2.00g pool00    8.17
 swap  fedora_studentvm1 -wi-ao---- 8.00g
 tmp  fedora_studentvm1 -wi-ao---- 5.00g
 usr  fedora_studentvm1 -wi-ao---- 15.00g
 var  fedora_studentvm1 -wi-ao---- 10.00g
[root@studentvm1 ~]#

您可以看到当前交换大小为8GB。在本例中,我们希望将2GB添加到此交换卷中。首先,停止现有的交换。如果正在使用交换空间,则可能必须终止正在运行的程序。

swapoff -a

现在增加逻辑卷的大小。

[root@studentvm1 ~]# lvextend -L +2G /dev/mapper/fedora_studentvm1-swap
 Size of logical volume fedora_studentvm1/swap changed from 8.00 GiB (2048 extents) to 10.00 GiB (2560 extents).
 Logical volume fedora_studentvm1/swap successfully resized.
[root@studentvm1 ~]#

运行mkswap命令将整个10 GB分区放入交换空间。

[root@studentvm1 ~]# mkswap /dev/mapper/fedora_studentvm1-swap
mkswap: /dev/mapper/fedora_studentvm1-swap: warning: wiping old swap signature.
Setting up swapspace version 1, size = 10 GiB (10737414144 bytes)
no label, UUID=3cc2bee0-e746-4b66-aa2d-1ea15ef1574a
[root@studentvm1 ~]#

打开掉包。

[root@studentvm1 ~]# swapon -a
[root@studentvm1 ~]#

现在,使用List块设备命令验证新的交换空间是否存在。同样,不需要重新启动。

[root@studentvm1 ~]# lsblk
NAME                 MAJ:MIN RM SIZE RO TYPE MOUNTPOINT
sda                  8:0  0  60G 0 disk
|-sda1                 8:1  0  1G 0 part /boot
`-sda2                 8:2  0  59G 0 part
 |-fedora_studentvm1-pool00_tmeta  253:0  0  4M 0 lvm
 | `-fedora_studentvm1-pool00-tpool 253:2  0  2G 0 lvm
 |  |-fedora_studentvm1-root    253:3  0  2G 0 lvm /
 |  `-fedora_studentvm1-pool00   253:6  0  2G 0 lvm
 |-fedora_studentvm1-pool00_tdata  253:1  0  2G 0 lvm
 | `-fedora_studentvm1-pool00-tpool 253:2  0  2G 0 lvm
 |  |-fedora_studentvm1-root    253:3  0  2G 0 lvm /
 |  `-fedora_studentvm1-pool00   253:6  0  2G 0 lvm
 |-fedora_studentvm1-swap      253:4  0  10G 0 lvm [SWAP]
 |-fedora_studentvm1-usr      253:5  0  15G 0 lvm /usr
 |-fedora_studentvm1-home      253:7  0  2G 0 lvm /home
 |-fedora_studentvm1-var      253:8  0  10G 0 lvm /var
 `-fedora_studentvm1-tmp      253:9  0  5G 0 lvm /tmp
sr0                  11:0  1 1024M 0 rom
[root@studentvm1 ~]#

您还可以使用swapon -s命令,或top, free,或者其他几个命令中的任何一个来验证这一点。

[root@studentvm1 ~]# free
       total    used    free   shared buff/cache  available
Mem:    4038808   382404   2754072    4152   902332   3404184
Swap:   10485756      0  10485756
[root@studentvm1 ~]#

注意,不同的命令以不同的形式显示或要求设备特殊文件作为输入。在/dev目录中访问特定设备的方式有很多种。

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对我们的支持。如果你想了解更多相关内容请查看下面相关链接

(0)

相关推荐

  • Linux中10个方便的Bash别名

    有多少次您在命令行上多次输入一个长命令,并希望有一种方法将其保存到以后?这就是Bash别名派上用场的地方.它们允许您将长而神秘的命令浓缩成易于记忆和使用的命令.需要一些例子让你开始吗?没问题! 要使用您创建的Bash别名,需要将其添加到位于主文件夹中的.bash_profile文件中.请注意,此文件是隐藏的,只能从命令行访问.处理此文件的最简单方法是使用类似Vi或Nano之类的东西. 10个Bash别名 1.您需要多次解压缩.tar文件而不记得所需的确切参数? 只需将以下内容添加到.bash_p

  • Linux系统磁盘格式化以及手动增加swap分区

    windows:支持NTFS ,fat linux支持文件格式: cat /etc/filesystems 查看Centos 7可支持的文件格式. xfs Centos 7 默认文件系统名称为xfs mount 查看 /dev/vda1 on / type ext4 (rw,relatime,data=ordered) 磁盘格式化 mke2fs -t exet4 指定格式化为什么格式的文件系统 mke2fs -b 指定块大小 例如:mke2fs -t ext4 -b 2048 /dev/sdb1

  • Linux推荐使用Xfce桌面环境的8个原因

    出于几个原因(包括好奇心),几周前我开始使用Xfce作为我的Linux桌面.原因之一是后台守护进程占用了我非常强大的主工作站上所有的CPU和I/O带宽.当然,有些不稳定可能是因为我删除了一些提供后台守护进程的RPM包.然而,即使在我移除RPM之前,事实是KDE是不稳定的,并且会导致性能和稳定性问题.我需要使用不同的桌面来避免这些问题. 我非常喜欢Xfce,并且比我想的更喜欢它的速度和轻盈. 作为我研究的一部分,我搜索了一下Xfce的含义.有对XForms公共环境的历史引用,但是Xfce不再使用X

  • Linux使用Sudo委派权限

    sudo权限委派介绍 su 切换身份:su –l username –c 'command' sudo 来自sudo包 man 5 sudoers sudo能够授权指定用户在指定主机上运行某些命令.如果未授权用户尝试使  用 sudo,会提示联系管理员 sudo可以提供日志,记录每个用户使用sudo操作 sudo为系统管理员提供配置文件,允许系统管理员集中地管理用户的使用权限和使用的主机 sudo使用时间戳文件来完成类似"检票"的系统,默认存活期为5分钟的"入场券"

  • Linux服务器安装GRUB步骤

    如何为 Linux 服务器安装 GRUB 当您无法通过 迁云工具 迁移内核版本较低,自带系统引导程序 GRand Unified Bootloader(GRUB)版本为 1.99 以下的 Linux 服务器,例如,CentOS 5 和 Debian 7.而且日志文件提示 Do Grub Failed 时,可能是因为没有安装 1.99 以上版本的系统引导程序 GRUB. 本文主要介绍如何为您的源服务器安装系统引导程序 GRUB 1.99 版本.安装 GRUB 1.99 及以上版本如 1.99 和

  • 吸引发烧友的视听Linux发行版

    我最近偶然发现视听Linux项目,许多专门的面向音乐的Linux发行版之一.视听Linux: 是基于ArchLInux 提供一个为播放音乐而定制的实时linux内核. 使用轻量级流动箱窗口管理器 避免不必要的守护进程和服务 允许播放dsf并支持通常的pcm格式. 支持各种音乐播放器,包括我最喜欢的组合之一:mpd+粤语 自2017年4月以来,这个亲音频的Linux网站并没有显示出太多的活动,但它确实包含了今年的一些更新和评论.考虑到它的定位和功能集,我决定在我的旧东芝笔记本电脑上运行一下. 安装

  • Linux中使用top命令的技巧

    首先介绍top中一些字段的含义:  VIRT:virtual memory usage 虚拟内存 1.进程"需要的"虚拟内存大小,包括进程使用的库.代码.数据等 2.假如进程申请100m的内存,但实际只使用了10m,那么它会增长100m,而不是实际的使用量 RES:resident memory usage 常驻内存 1.进程当前使用的内存大小,但不包括swap out 2.包含其他进程的共享 3.如果申请100m的内存,实际使用10m,它只增长10m,与VIRT相反 4.关于库占用内

  • Linux桌面的4种扫描工具

    当无纸化的世界还没有出现的时候,越来越多的人通过扫描文件和照片来摆脱纸张.不过,光有扫描仪是不够的.你需要软件来驱动扫描仪. 但问题是,许多扫描仪制造商没有Linux版本的软件,他们捆绑在他们的设备.在大多数情况下,这并不重要.为什么?因为Linux桌面上有很好的扫描应用程序.他们和各种各样的扫描仪一起工作,做得很好. 让我们来看看四个简单但灵活的开源Linux扫描工具.我使用了这些工具中的每一个并发现它们非常有用.你也可以 通过使用这些开源应用程序之一驱动您的扫描仪实现无纸化. Simple

  • Linux中查找工具的友好替代方案

    find命令用来在指定目录下查找文件.任何位于参数之前的字符串都将被视为欲查找的目录名.如果使用该命令时,不设置任何参数,则find命令将在当前目录下查找子目录与文件.并且将查找到的子目录和文件全部进行显示. 语法 find(选项)(参数) 选项 -amin<分钟>:查找在指定时间曾被存取过的文件或目录,单位以分钟计算: -anewer<参考文件或目录>:查找其存取时间较指定文件或目录的存取时间更接近现在的文件或目录: -atime<24小时数>:查找在指定时间曾被存取

  • 使用iptable和Firewalld工具来管理Linux防火墙连接规则

    防火墙 防火墙是一套规则.当数据包进入或离开受保护的网络空间时,将根据防火墙规则测试数据包的内容(特别是有关其来源.目标和计划使用的协议的信息),以确定是否应该允许数据包通过.下面是一个简单的例子: 防火墙可以根据协议或基于目标的规则过滤请求. 一方面,iptables是管理Linux机器上防火墙规则的工具. 另一方面,firewalld也是管理Linux机器上防火墙规则的工具. 你对此有意见吗?如果我告诉你外面还有另一个工具,叫做nftable? 好吧,我承认整件事闻起来有点怪怪的,所以让我解

  • 历史Linux镜像处理及修复方案

    历史Linux镜像创建的ECS云服务器,可能存在NTP没有配置,YUM没有配置,还可能存在最近暴漏较高的安全漏洞,请按照以下步骤进行修复,可以让您的云服务器更加安全,还可以使用阿里云提供的YUM服务进行安装软件,可以使用免费的阿里云提供的NTP进行时间同步. 1. 配置NTP 不区分发行版,先备份 /etc/ntp.conf,然后将其内容替换为如下: # ntp.conf # # ntpd config for aliyun ecs. # # 6LAN+6LAN+3WAN # shijun.ca

  • linux中pip操作时的超时解决方法

    如何解决 Linux 实例 pip 操作时的超时问题 pip 是当前最流行的 Python 安装包管理工具之一,很多阿里云用户会通过 pip 更新系统源.阿里云的 pip 源地址有以下三处: (默认)公网:mirrors.aliyun.com 专有网络 VPC 内网:mirrors.cloud.aliyuncs.com 经典网络内网:mirrors.aliyuncs.com 现象描述 Linux 实例的 pip 请求偶有超时或者失败现象.目前,受影响的公共镜像有: CentOS Debian U

随机推荐