SWAP(交换内存)

1、什么是交换内存?

在硬盘上创建一块区域,当你的物理内存快要被用光的时候,内核临时的

物理内存上的文件数据交换到硬盘上的这段区域上面,当物理内存有闲置的时候

在把交换内存上的数据调回到物理内存上的。可能在大多数时候,你会发现你的

交换内存没有被用到,为什么我们的系统在安装的时候强制我们要建立交换内存?

牺牲一定的硬盘空间,给操作系统买份保险!

2、创建交换内存:

创建的步骤:

1、 创建新分区,并且更改分区标识符号为82.

或者在本机上使用dd命令创建一个虚拟文件。

2、 使用mkswap对指定设备制作交换内存文件系统。

3、 swapon开启交换内存

(但是非常遗憾,下次启动机器的时候仍然需要手动使用swapon手动开启)建议直接写入到/etc/fstab中

4、 查看free  -m   ,swapon  -s进行查看

分区类型交换内存:速度快、独立分区

1、fdisk  /dev/sdb

n     t    82

#partprobe  /dev/sdb          //重新加载分区表

2、制作swap

# mkswap  /dev/sdb7          //以sdb7为例

3、写/etc/fstab

/dev/sdb7    swap  swap   defaults  0  0     //永久挂载格式

UUID=XXXXXX   swap  swap  defaults  0  0     //生产环境blkid查看文件系统UUID

# swapon  -a

4、查看:

# free  -m

# swapon  -s

文件类型的交换内存:相对速度慢、比较灵活

1、创建虚拟文件:

# dd  if=/dev/zero  of=/tmp/swap-file1  bs=1M  count=N   //N为正整数

2、制作swap文件系统

# mkswap  /tmp/swap-file1

3、挂载使用/etc/fstab

/tmp/swap-file1  swap  swap  defaults 0 0

# swapon  -a

4、查看:

# free  -m

# swapon  -s

 

交换内存的优化及人为干预:

交换内存的调优:

 

可调参数:/proc/sys/vm/swappiness

 

当系统非常需要使用内存时,内核会把匿名内存(Anonymous memory)和System V的共享内存(shared memory)交换到磁盘上去,而真正的文件不需要交换到交换内存上去,而是直接写会到磁盘文件系统上(清掉page cache)。

调低/proc/sys/vm/swappiness时,核心倾向于不交换,主要用于更快的响应速度。如:apache

调高/proc/sys/vm/swappiness时,核心倾向于使用交换内存,主要用于繁忙的吞吐量。如:文件服务器

 

内核尝试去检查一个参数swap_tendency:

Swap_tendency  < 100,内核会尽量的从page cache中做回收(写回page cache)

Swap_tendency  >=100,内核会尽量交换匿名内存和共享内存。

Swap_tendency = mapped_ratio/2  + distress + vm_swappiness(swap_tendency计算公式)

● mapped_ration : 物理内存的使用百分比。

 distress : 内核尝试释放物理内存的难易程度0-100(page  cache回收的难易程度)。distress悲痛;危难

vm_swappiness:是我们可以通过/proc/sys/vm/swappiness内核参数调节的值。

可以看出我们可以人为的干预交换内存的交换,但无法准确控制因为有distress参数

 

交换内存的优化:

使用多个磁盘做raid0

● 使用SSD设备

● 2.6内核开始交换文件和交换分区,速度上区别不太只要文件没有太多碎片。

● 当挂载交换分区或文件时,每新加一个交换设备优先级比前一个要低一些(优先级高的被先用到)。可以使用 pri=values来指定挂载优先级。

如果要使用多个交换分区来轮询(round-robin),那么多个交换分区使用相同的优先级。

交换内存设置为多大?

docs.redhat.com

 

如何设置优先级:

/dev/sdb7     swap   swap  defaults,pri=5   0   0

/dev/sdc6     swap   swap   defaults,pri=5  0   0  

linux中的交换分区(swap)及优化的更多相关文章

  1. linux 交换分区 swap

    linux swap分区用来保证内存过载时也可以使用,是在磁盘级别对内存的一次扩展,swap分区必须是一个单独的分区 创建过程: 1.用fdisk 命令新建分区,在创建过程中通过L命令和t命令来调整分 ...

  2. Linux 交换分区swap

    Linux 交换分区swap 一.创建和启用swap交换区 如果你的服务器的总是报告内存不足,并且时常因为内存不足而引发服务被强制kill的话,在不增加物理内存的情况下,启用swap交换区作为虚拟内存 ...

  3. Linux之添加交换分区

    Linux下的交换分区我们可以随意改变大小,如果说日常生活中分区不够用,今天我们来举个例子如何添加. 1.首先是使用dd命令创建一个空文件,这个空文件的大小就是你要继续添加的swap的大小,比如我这里 ...

  4. Linux中磁盘mbr分区——实践篇

    Linux中磁盘mbr分区——实践篇 fdisk命令 语法 fdisk(选项)(参数) 选项 -b <分区大小> 指定每个分区的大小 -l 列出分区表信息 -v 显示版本信息 参数 设备文 ...

  5. Linux_交换分区SWAP

    一.交换分区SWAP 1️⃣:交换分区SWAP就是LINUX下的虚拟内存分区,它的作用是在物理内存使用完之后,将磁盘空间(也就是SWAP分区)虚拟成内存来使用. 2️⃣:交换分区一般指定虚拟内存的大小 ...

  6. Linux设置交换分区swap

    参考: http://www.vpser.net/opt/vps-add-swap.html https://www.zntec.cn/archives/vps-swap.html http://yz ...

  7. Linux交换分区swap

    一.SWAP 说明 1.1 SWAP 概述 当系统的物理内存不够用的时候,就需要将物理内存中的一部分空间释放出来,以供当前运行的程序使用.那些被释放的空间可能来自一些很长时间没有什么操作的程序,这些被 ...

  8. Linux - 创建交换分区 swap

    购买的 1GB 内存的 Linux 小机器,在编译安装 PHP 的时候内存捉急,只好开启 swap 交换分区来增大内存. [root@VM_139_38_centos php-7.2.12]# cat ...

  9. linux(centos8): 临时关闭/永久关闭交换分区swap?

    一,为什么要关闭swap? 1,swap的用途? swap 分区就是交换分区,(windows平台叫虚拟内存) 在物理内存不够用时, 操作系统会从物理内存中把部分暂时不被使用的数据转移到交换分区, 从 ...

随机推荐

  1. Cesium专栏-大量gltf三维模型加载

    Cesium 是一款面向三维地球和地图的,世界级的JavaScript开源产品.它提供了基于JavaScript语言的开发包,方便用户快速搭建一款零插件的虚拟地球Web应用,并在性能,精度,渲染质量以 ...

  2. 度及拓扑图的使用-UESTC1958学霸周选课

    学霸周选课 Time Limit: 1000 MS     Memory Limit: 128 MB Submit Status 众所周知周大爷不仅编程了得,专业课成绩更是名列前茅,恰巧又到了选课的季 ...

  3. ubuntu文件权限

    以root身份登录linux. 在某一目录下执行 ls -al,显示类似如下内容: dr-xr-x---. 14 root root 4096 Aug 27 09:38 . dr-xr-xr-x. 2 ...

  4. PYTHON5000:CMOS图象传感器演示

    http://www.onsemi.cn/PowerSolutions/supportVideo.do?docId=1002896

  5. Linux-(2)Linux安装

    二.Linux 安装 2.1 物理机安装 使用相关镜像制作软件(软碟通等)制作U盘启动盘即可,按照正常的安装步骤安装即可,一般来说(迷你版本)有线网卡直接会有驱动,无线网卡的驱动需要自行编译或者查找. ...

  6. 一次使用pip后的总结

    pip 常用命令及搭配操作 一 .当安装了多个版本python的时候,表示用pythonx 的pip 进行: 1.pythonx -m pip install + 包名 装 包 2.pythonx - ...

  7. 【hibernate】常用注解

    [hibernate]常用注解 转载:https://www.cnblogs.com/yangchongxing/p/10357118.html 目录 ======================== ...

  8. 【同步工具类】CountDownLatch闭锁任务同步

    [同步工具类]CountDownLatch闭锁任务同步 转载:https://www.cnblogs.com/yangchongxing/p/9214284.html 打过dota的同学都知道,多人一 ...

  9. Vmare 无法打开内核设备“\\.\VMCIDev\VMX”: 系统找不到指定的文件。您在安装 VMware Workstation 后是否进行了重新引导?的解决办法

    1.使用管理员省份运行cmd:net start vmx86(切记是要用管理员身份),启动服务成功问题即可解决. 2.若1操作中启动失败,则到Vmare安装目录下搜索vmx86.sys文件,并拷贝到C ...

  10. 从多核CPU Cache一致性的应用到分布式系统一致性的概念迁移

    概述 现代多核CPU的cache模型基本都跟下图1所示一样,L1 L2 cache是每个核独占的,只有L3是共享的,当多个cpu读.写同一个变量时,就需要在多个cpu的cache之间同步数据,跟分布式 ...