百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

ubuntu6:修改增加交换分区

nanshan 2024-11-22 18:26 8 浏览 0 评论


1 sawp分区简介

swap 分区通常也称为交换分区,它是一块特殊的硬盘空间,即当系统物理内存不够用的时,操作系统会从内存中取出一部分暂时不用的数据,存放到放在交换分区中,也就是说,当内存不够用时,可使用 swap 分区来临时顶替。

使用 swap 交换分区的显著优点是,通过操作系统的调度,可以使程序使用的内存空间远超实际物理内存。由于硬盘空间的价格远低于 RAM 价格,因此使用swap分区无疑是最经济实惠的方式。但是,由于这种方式会频繁地读写硬盘(硬盘读写速度相对慢),会显著降低操作系统的运行速率,这也是使用 swap 交换分区带来的性能限制(目前nvme硬盘速度快,性能有很大的提升)。

创建swap有多种方式,一种是在系统安装时创建swap分区,一种是创建一个单独的分区做swap分区,还有一种是使用dd命令创建一个swap文件。下文将使用swap file方式,相对比较简单,可随时修改。

一般我们在物理内存较小,并且需要多线程编译大型工程或库时需要增加swap分区大小,以免编译器因内存报错而导致编译失败。

2 查看swap分区

一般安装ubuntu系统时,选择自动安装默认会分配swap分区,一般是2GB或4GB,可通过如下命令查看swap分区信息。

free -h
swapon -s
swapon --show
  • total:是指总数;
  • used:是指已经使用的;
  • free:是指空闲的;
  • shared:是指共享的;
  • buffers/cached:是指缓冲内存容量;
  • avaliable:是指可用内存容量;

3 修改swap分区

修改swap分区,增加swap分区大小为20GB执行如下命令。

sudo swapoff /swapfile
sudo rm -f /swapfile
sudo fallocate -l 20G /swapfile
ls -alh /swapfile
sudo chmod 600 /swapfile
sudo mkswap /swapfile
sudo swapon /swapfile
sudo swapon --show
free -h

如果是想减小swap分区大小,只需要修改fallocate命令,例如修改swap分区为8GB.执行如下命令:

sudo dd if=/dev/zero of=/swapfile bs=1G count=8

此外,也可以使用dd命令代替fallocate命令创建swap分区文件,例如使用如下命令创建10GB的swap分区文件:

sudo dd if=/dev/zero of=/swapfile bs=1G count=10

一般创建swap分区文件名为“swapfile” ,路径是“/"根目录,也可以更改为其它名称或其它目录下,如有改变路径和文件名,需要后面的命令中使用相同的路径和文件名。

4 创建swap分区

如果安装系统时没有创建swap分区,那么需要自己创建swap分区,创建swap分区和修改swap分区操作相似,去掉停止、删除swap分区命令,直接从dd命令开始。

sudo fallocate -l 20G /swapfile
ls -alh /swapfile
sudo chmod 600 /swapfile
sudo mkswap /swapfile
sudo swapon /swapfile
sudo swapon --show
free -h

创建好swap分区文件并使用后,还需要修改/etc/fstab文件,添加如下内容,以便于开机自动挂载swap分区,

/swapfile                                 none            swap    sw              0       0

最后实行如下命令检测/etc/fstab文件正确性,一定要执行此步骤否则可能会导致重启后开机失败。

sudo mount -a

<file sysytem> : 待挂载分区或存储设备(可用uuid)

<mount point> : 挂载路径

<type> : 待挂载设备的文件系统类型,例如:ext2, ext3, ext4, reiserfs, xfs, jfs, smbfs, iso9660, vfat, ntfs, swapauto。 设置成auto类型,mount会自动猜测匹配

<opptions> : 挂载使用的参数,部分参数是特定文件系统才有的。一些比较常用的参数有:

  • auto - 在启动时或键入了 mount -a 命令时自动挂载。
  • noauto - 只在你的命令下被挂载。
  • exec - 允许执行此分区的二进制文件。
  • noexec - 不允许执行此文件系统上的二进制文件。
  • ro - 以只读模式挂载文件系统。
  • rw - 以读写模式挂载文件系统。
  • user - 允许任意用户挂载此文件系统,若无显示定义,隐含启用 noexec, nosuid, nodev 参数。
  • users - 允许所有 users 组中的用户挂载文件系统.
  • nouser - 只能被 root 挂载。
  • owner - 允许设备所有者挂载.
  • sync - I/O 同步进行。
  • async - I/O 异步进行。
  • dev - 解析文件系统上的块特殊设备。
  • nodev - 不解析文件系统上的块特殊设备。
  • suid - 允许 suid 操作和设定 sgid 位。这一参数通常用于一些特殊任务,使一般用户运行程序时临时提升权限。
  • nosuid - 禁止 suid 操作和设定 sgid 位。
  • noatime - 不更新文件系统上 inode 访问记录,可以提升性能(参见 atime 参数)。
  • nodiratime - 不更新文件系统上的目录 inode 访问记录,可以提升性能(参见 atime 参数)。
  • relatime - 实时更新 inode access 记录。只有在记录中的访问时间早于当前访问才会被更新。(与 noatime 相似,但不会打断如 mutt 或其它程序探测文件在上次访问后是否被修改的进程。),可以提升性能(参见 atime 参数)。
  • flush - vfat 的选项,更频繁的刷新数据,复制对话框或进度条在全部数据都写入后才消失。
  • defaults - 使用文件系统的默认挂载参数,例如 ext4 的默认参数为:rw, suid, dev, exec, auto, nouser, async.

<dump> : dump 工具使用该数字来决定是否对这个文件系统进行备份,可配置值为 0 或 1 。0 表示忽略, 1 则进行备份。一般用户没有安装 dump ,故一般 <dump> 设置为 0。

<pass> : fsck 读取 <pass> 的数值来决定需要检查的文件系统的检查顺序。可配置值是0, 1, 和2。 不需要fsck检查设置为0,1为最先检查,根目录应当设置为 1, 2为1之后的检查,除根目录外其它所有需要被检查的设备一般设置为 2。

swap分区可以创建多个。

5 相关命令说明

1、查看swappiness值

系统中通过swappiness值配置触发使用swap分区物理内存使用量,系统默认值是60,可在proc下查看swappiness值。

# 查看swappiness
cat /proc/sys/vm/swappiness

可在/etc/sysctl.conf中配置swappiness值

sudo -i
echo "vm.swappiness=10" >> /etc/sysctl.conf

swappiness=0:只使用物理内存,不使用swap,当物理内存用光时,用OOM kill杀死分值低的进程。

swappiness=1:当物理内存用光时,使用swap内存而不杀死相关进程。

swappiness=60:系统默认值。

swappiness=100:表示积极的使用swap分区,并且把内存上的数据及时的搬运到swap空间里面。

2 查看swap使用状态

# 查看swap io使用状态
vmstat
# 间隔1s 输出结果
vmstat 1

si和so分别代表swap的换入和换出

3、停用swap

如果swap分区已经在使用,则需要将swap分区数据同步到磁盘。

#系统会周期性的sync数据到磁盘
sync
# 清空页缓存 
echo 1 > /proc/sys/vm/drop_caches
# 清空inode和目录树缓存 
echo 2 > /proc/sys/vm/drop_caches 
# 清空所有缓存 
echo 3 > /proc/sys/vm/drop_caches

# 释放swap分区,需要等待,如果swap分区使用了大,例如20G,则可能要等待较久
swapoff -a
# 启用所有swap分区
swapon -a

相关推荐

详解 HTTPS、TLS、SSL、HTTP区别和关系

一、什么是HTTPS、TLS、SSLHTTPS,也称作HTTPoverTLS。TLS的前身是SSL,TLS1.0通常被标示为SSL3.1,TLS1.1为SSL3.2,TLS1.2为SSL...

锐安信SSL证书自动化运维系统:灵活管理SSL/TLS证书全生命周期

点击上方关注“锐成云分销”,云建站解决方案专家!域名、SSL证书、DNS、主机一站选齐在SSL/TLS证书的生命周期管理中,证书的各种操作方式是基础且核心的部分之一,更是保障用户数据传输加密的关键。这...

宝塔免费的 SSL/TLS 证书如何续签

申请之前,请确保域名已解析,如未解析会导致审核失败(包括根域名)宝塔SSL申请的是免费版TrustAsiaDVSSLCA-G5证书,仅支持单个域名申请有效期1年,不支持续签,到期后需要重新申...

HTTPS、HTTP、TLS/SSL工作及握手原理、PKI/CA密钥体系

一、HTTPS与HTTP介绍二、TLS/SSL工作原理三、TSL/SSL握手过程四、HTTPS性能优化五、PKI体系一、HTTPS与HTTP介绍1.Https(SecureHypetextTran...

什么是SSL证书卸载 SSL证书卸载有什么作用

SSL证书是数字证书的一种,安装部署的话可以对网站起到身份验证和数据加密的作用。网站部署SSL证书,相对就必然会有SSL证书卸载,那么SSL证书卸载是什么呢?SSL证书卸载有什么作用?随着SSL通信量...

让SSL/TLS协议流行起来:深度解读SSL/TLS实现1

一前言SSL/TLS协议是网络安全通信的重要基石,本系列将简单介绍SSL/TLS协议,主要关注SSL/TLS协议的安全性,特别是SSL规范的正确实现。本系列的文章大体分为3个部分:SSL/TLS协...

苹果、谷歌、微软等一致同意!SSL/TLS证书最长有效期锐减至47天

快科技4月14日消息,苹果此前向CA/B论坛(负责管理SSL/TLS证书的行业组织)提议,将所有证书有效期缩短至45天。日前CA/B论坛服务器证书工作组投票通过SC-081v3提案,最终决定将SSL/...

Android怎么设置端口转发,将访问本设备的端口转到另外一台设备

一、Android系统怎么设置端口转发,将访问本设备的端口转到另外一台设备?要设置端口转发,您需要先在Android设备上安装一个支持端口转发的应用程序。其中一个常用的应用是"Termux&#...

大神级产品:手机装 Linux 运行 Docker 如此简单

本内容来源于@什么值得买APP,观点仅代表作者本人|作者:灵昱Termux作为一个强大的Android终端模拟器,能够运行多种Linux环境。然而,直接在Termux上运行Docker并不可行,需要...

关于H3C交换机的SSH功能配置方法(华三交换机ssh配置)

对于交换机的初步学习,作为初学者的我,还望诸位不吝赐教。若存在不足之处,烦请大家多提宝贵意见。同样身为初学者的我们,亦可携手共进,相互分享技术经验。一、本地用户配置(核心步骤)1.创建用户并设置密码...

Linux常用操作ssh(linux中的ssh命令)

ssh#p是小写ssh-p22user@hostsftp#连接sftp-P22root@host#将文件上传到服务器上:put[本地文件的地址][服务器上文件存储的位置]#将...

小白心得,如何使用SSH连接飞牛系统(fnos)?

一、背景作为一个刚接触飞牛系统的小白,在研究飞牛os的时候,发现很多功能都需要连接ssh,但是如何使用SSH连接飞牛系统成为入门飞牛os的一道坎。下面以自己的学习经历详细记录下过程吧。二、系统设置1、...

如何在 Windows 11 或 10 上使用 Winget 安装 OpenSSH

SSH(SecureShell)是大多数开发人员和系统管理员用来通过Linux远程连接托管服务器或任何云服务的工具,因为SSH在Linux中是内置的。然而,对于Windows呢?是的...

linux文件之ssh配置文件的含义与作用

ssh远程登录命令是操作系统(包括linux和window系统)下常用的操作命令,可以帮助用户,远程登录服务器系统,查看,操作系统相关信息。linux系统对于ssh命令有专门保存其相关配置的目录和文件...

害怕Linux SSH不安全?这几个小妙招安排上!

ssh是访问远程服务器最常用的方法之一,同时,其也是Linux服务器受到攻击的最常见的原因之一。不过别误会...我们并不是说ssh有什么安全漏洞,相反,它在设计上是一个非常安全的协议。但是安...

取消回复欢迎 发表评论: