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

【linux学习】swap分区你学会了吗?

nanshan 2025-01-14 16:07 11 浏览 0 评论

swap分区如何合理使用

本文我会介绍swap交换分区以及其实现过程,并且会讲到swap分区的创建、激活、禁用、优先级、挂载。有兴趣的小伙伴可以收藏学习。

swap交换分区是系统RAM的补充,swap 分区支持虚拟内存。当没有足够的 RAM 保存系统处理的数据时会将数据写入 swap 分区,当系统缺乏 swap 空间时,内核会因 RAM 内存耗尽而终止进程。配置过多 swap 空间会造成存储设备处于分配状态但闲置,造成浪费,过多 swap 空间还会掩盖内存泄露

实现过程:(1)创建交换分区或文件;(2)使用mkswap写入特殊签名;(3)在/etc/fstab文件中添加适当的条目;(4)使用swapon -a 激活交换空间。

创建swap分区 echo -e 'n\np\n\n\n+2G\nt\n82\nw\n' | fdisk /dev/sdc

格式化swap文件系统 mkswap /dev/sdc1

查看分区信息 blkid /dev/sdc1

持久挂载swap分区 echo “UUID=d3140a7a-65b7-4cb7-8a2b-12d38aa98c6f swap swap defaults 0 0“ 》/etc/fstab

启用swap分区 swapon -a

查看swap内存大小信息 free -h

查看swap分区信息 cat /proc/swaps

禁用swap分区 sed -i.bak '/swap/d' /etc/fstab

关闭swap swapoff -a

扩展swap逻辑卷,增加6G lvextend -L +6GB /dev/mapper/VolGroup-lv_swap

swap分区缩容,减少200M lvreduce -L -200M /dev/Vo-Group/LogVol

swap的使用策略

/proc/sys/vm/swappiness 的值决定了当内存占用达到一定的百分比时,会启用swap分区的空间。

可通过修改Linux内核参数【vm.swappiness=30】进行实时修改生效百分比

查看内存占用百分比启用swap分区 cat /proc/sys/vm/swappiness

当vm.swappiness = 0时不会禁止对swap的使用,只是最大限度地降低了使用swap的可能性

接下来我再讲讲挂载。

挂载:将额外文件系统与根文件系统某现存的目录建立起关联关系,进而使得此目录作为其它文件访问入口的行为; 卸载则为解除此关联关系的过程。

注意:把设备关联挂载点(mount Point),挂载点下原有文件在挂载完成后会被临时隐藏,因此,挂载点目录一般为空;进程正在使用中的设备无法被卸载。

挂载文件系统 mount 格式: mount [-fnrsvw] [-t vfstype] [-o options] device mountpoint

挂载规则:

(1)一个挂载点同一时间只能挂载一个设备;(2)一个挂载点同一时间挂载了多个设备,只能看到最后一个设备的数据,其他设备上的数据将被隐藏;(3)一个设备可以同时挂载到多个挂载点;(4)通常挂载点一般是已存在空的目录;(5)卸载时,可使用设备,也可使用挂载点。

device:指明要挂载的设备

mountpoint:挂载点目录必须事先存在,建议使用空目录

常用命令:

-t fstype 指定要挂载的设备上的文件系统类型,如:ext4,xfs

-r readonly,只读挂载

-w read and write, 读写挂载

-n 不更新/etc/mtab,mount不可见

-a 自动挂载所有支持自动挂载的设备(定义在了/etc/fstab文件中,且挂载选项中有

auto功能)

-L 'LABEL' 以卷标指定挂载设备

-U 'UUID' 以UUID指定要挂载的设备

-B, --bind 绑定目录到另一个目录上

-o options:(挂载文件系统的选项),多个选项使用逗号分隔

async 异步模式

sync 同步模式

atime/noatime 包含目录和文件

diratime/nodiratime 目录的访问时间戳

auto/noauto 是否支持开机自动挂载,是否支持-a选项

exec/noexec 是否支持将文件系统上运行应用程序

dev/nodev 是否支持在此文件系统上使用设备文件

suid/nosuid 是否支持suid和sgid权限

remount 重新挂载

ro/rw 只读、读写

user/nouser 是否允许普通用户挂载此设备,/etc/fstab使用

acl/noacl 启用此文件系统上的acl功能

loop 使用loop设备

_netdev 当网络可用时才对网络资源进行挂载,如:NFS文件系统

defaults 相当于rw, suid, dev, exec, auto, nouser, async

卸载文件系统: umount 设备名|挂载点

查看内核追踪到的已挂载的所有设备cat /proc/mounts

查看挂载点情况findmnt 设备名|挂载点

根据文件或挂载点查找系统的进程fuser -v 挂载点

终止所有在正访问指定的文件系统的进程fuser -km 挂载点

启用挂载 /etc/fstab格式帮助man 5 fstab

学习是一个持续的过程,需要不断积累总结,对linux学习有兴趣的小伙伴不妨点个关注一起交流学习。

相关推荐

Let’s Encrypt免费搭建HTTPS网站

HTTPS(全称:HyperTextTransferProtocoloverSecureSocketLayer),是以安全为目标的HTTP通道,简单讲是HTTP的安全版。即HTTP下加入...

使用Nginx配置TCP负载均衡(nginx tcp负载)

假设Kubernetes集群已经配置好,我们将基于CentOS为Nginx创建一个虚拟机。以下是实验种设置的详细信息:Nginx(CenOS8Minimal)-192.168.1.50Kube...

Nginx负载均衡及支持HTTPS与申请免费SSL证书

背景有两台minio文件服务器已做好集群配置,一台是192.168.56.41:9000;另一台是192.168.56.42:9000。应用程序通过Nginx负载均衡调用这两台minio服务,减轻单点...

HTTPS配置实战(https配置文件)

原因现在网站使用HTTPS是规范操作之一,前些日子买了腾讯云服务,同时申请了域名http://www.asap2me.top/,目前该域名只支持HTTP,想升级为HTTPS。关于HTTPS的链接过程大...

只有IP地址没有域名实现HTTPS访问方法

一般来说,要实现HTTPS,得有个注册好的域名才行。但有时候呢,咱只有服务器的IP地址,没注册域名,这种特殊情况下,也能照样实现HTTPS安全访问,按下面这些步骤来就行:第一步,先确认公网...

超详解:HTTPS及配置Django+HTTPS开发环境

众所周知HTTP协议是以TCP协议为基石诞生的一个用于传输Web内容的一个网络协议,在“网络分层模型”中属于“应用层协议”的一种。在这里我们并不研究该协议标准本身,而是从安全角度去探究使用该协议传输数...

Godaddy购买SSL之后Nginx配置流程以及各种错误的解决

完整流程:参考地址:https://sg.godaddy.com/zh/help/nginx-generate-csrs-certificate-signing-requests-3601生成NGI...

Nginx从安装到高可用,一篇搞定(nginx安装与配置详解)

一、Nginx安装1、去官网http://nginx.org/下载对应的nginx包,推荐使用稳定版本2、上传nginx到linux系统3、安装依赖环境(1)安装gcc环境yuminstallgc...

阿里云免费证书申请,配置安装,使用tomcat,支持http/https访问

参数说明商品类型默认已选择云盾证书服务(无需修改)。云盾证书服务类型SSL证书服务的类型。默认已选择云盾SSL证书(无需修改),表示付费版SSL证书。如果您需要免费领取或付费扩容DV单域名证书【免费试...

你试过两步实现Nginx的规范配置吗?极速生成Nginx配置小工具

NGINX是一款轻量级的Web服务器,最强大的功能之一是能够有效地提供HTML和媒体文件等静态内容。NGINX使用异步事件驱动模型,在负载下提供可预测的性能。是当下最受欢迎的高性能的Web...

从零开始搭建HTTPS服务(搭建https网站)

搭建HTTPS服务的最初目的是为了开发微信小程序,因为wx.request只允许发起HTTPS请求,并且还必须和指定的域名进行网络通信。要从零开始搭建一个HTTPS的服务需要下面4...

群晖NAS使用官网域名和自己的域名配置SSL实现HTTPS访问

安全第一步,群晖NAS使用官网域名和自己的域名配置SSL实现HTTPS访问【新手导向】NAS本质还是一个可以随时随地访问的个人数据存储中心,我们在外网访问的时候,特别是在公网IP下,其实会面临着很多安...

让网站快速升级HTTPS协议提高安全性

为什么用HTTPS网络安全越来越受到重视,很多互联网服务网站,都已经升级改造为https协议。https协议下数据包是ssl/tcl加密的,而http包是明文传输。如果请求一旦被拦截,数据就会泄露产生...

用Https方式访问Harbor-1.9版本(https访问流程)

我上周在头条号写过一篇原创文章《Docker-Harbor&Docker-kitematic史上最详细双系统配置手册》,这篇算是它的姊妹篇吧。这篇文章也将用到我在头条写的另一篇原创文章的...

如何启用 HTTPS 并配置免费的 SSL 证书

在Linux服务器上启用HTTPS并配置免费的SSL证书(以Let'sEncrypt为例)可以通过以下步骤完成:---###**一、准备工作**1.**确保域名已解析**...

取消回复欢迎 发表评论: