您好,欢迎来到意榕旅游网。
搜索
您的当前位置:首页Linux SWAP 分区建立及释放内存

Linux SWAP 分区建立及释放内存

来源:意榕旅游网
方法一:

一、查看系统当前的分区情况:

>free -m

二、创建用于交换分区的文件:

>dd if=/dev/zero of=/whatever/swap bs=block_size (10M)count=number_of_block(3000)

三、设置交换分区文件:

>mkswap /export/swap/swapfile

四、立即启用交换分区文件: >swapon /whateever/swap

五、若要想使开机时自启用,则需修改文件/etc/fstab中的swap行:

/whatever/swap swap swap defaults 0 0

方法二

增加交换分区空间的方法:

1.查看一下/etc/fstab确定目前的分区 2.swapoff /dev/hd**

3.free 看一下是不是停了. 4.fdisk 删了停掉的swap分区

5.重新用FDISK建一个新的SWAP分区 6.mkswap /dev/hd**把新的分区做成swap 7.swapon /dev/hd**打开swap 8.修改/etc/fstab

操作实例:

1.查看系统Swap空间使用 # free

total used free shared buffers cached

Mem: 513980 4930 20340 0 143808 271780 -/+ buffers/cache: 78052 435928 Swap: 1052248 21256 1030992

2.在空间合适处创建swap文件 # mkdir swap

# cd swap

# dd if=/dev/zero of=swapfile bs=1024 count=10000 10000+0 records in 10000+0 records out # ls -al

total 10024

drwxr-xr-x 2 root root 4096 7月 28 14:58 . drwxr-xr-x 19 root root 4096 7月 28 14:57 ..

-rw-r--r-- 1 root root 10240000 7月 28 14:58 swapfile

# mkswap swapfile

Setting up swapspace version 1, size = 9996 KiB

3.激活swap文件 # swapon swapfile # ls -l

total 10016

-rw-r--r-- 1 root root 10240000 7月 28 14:58 swapfile # free

total used free shared buffers cached

Mem: 513980 505052 28 0 143900 282288 -/+ buffers/cache: 788 435116 Swap: 1062240 21256 1040984

生成1G的文件

# dd if=/dev/zero of=swapfile bs=10M count=3000

创建为swap文件

#mkswap swapfile

让swap生效

#swapon swapfile 查看一下swap #swapon -s

[root@cluster /]# swapon

-sFilename Type Size Used Priority/dev/sda3 partition 1020116 1728 -1/state/partition1/swap/swapfile file 30719992 0 -2 加到fstab文件中让系统引导时自动启动 #vi /etc/fstab

/state/partition1/swap/swapfil swap swap defaults 0 0

完毕。

二,Linux释放内存

细心的朋友会注意到,当你在linux下频繁存取文件后,物理内存会很快被用光,当程序结束后,内存不会被正常释放,而是一直作为caching.这个问题,貌似有不少人在问,不过都没有看到有什么很好解决的办法.那么我来谈谈这个问题.

先来说说free命令

[root@cluster /]# free -m

total used free shared buffers cached

Mem: 31730 31590 139 0 37 27537

-/+ buffers/cache: 4015 27714

Swap: 30996 1 30994

其中:

total 内存总数

used 已经使用的内存数

free 空闲的内存数

shared 多个进程共享的内存总额

buffers Buffer Cache和cached Page Cache 磁盘缓存的大小

-buffers/cache 的内存数:used - buffers - cached

+buffers/cache 的内存数:free + buffers + cached

可用的memory=free memory+buffers+cached

有了这个基础后,可以得知,我现在used为163MB,free为86,buffer和cached分别为10,94

那么我们来看看,如果我执行复制文件,内存会发生什么变化.

[root@cluster /]# cp -r /etc ~/test/

[root@cluster /]# free -m

total used free shared buffers cached

Mem: 31730 31590 139 0 37 27537

-/+ buffers/cache: 4015 27714

Swap: 30996 1 30994

在我命令执行结束后,used为244MB,free为4MB,buffers为8MB,cached为174MB,天呐都被cached吃掉了.别紧张,这是为了提高文件读取效率的做法.

引 用[url]http://www.2qyou.com/thread-591-1-1.html[/url] 为了提高磁盘存取效率, Linux做了一些精心的设计, 除了对dentry进行缓存(用于VFS,加速文件路径名到inode的转换), 还采取了两种主要Cache方式:Buffer Cache和Page Cache。前者针对磁盘块的读写,后者针对文件inode的读写。这些Cache有效缩短了 I/O系统调用(比如read,write,getdents)的时间。\"

那么有人说过段时间,linux会自动释放掉所用的内存,我们使用free再来试试,看看是否有释放>?

[root@cluster /]# free -m

total used free shared buffers cached

Mem: 31730 31590 139 0 37 27537

-/+ buffers/cache: 4015 27714

Swap: 30996 1 30994

MS没有任何变化,那么我能否手动释放掉这些内存呢???回答是可以的!

/proc是一个虚拟文件系统,我们可以通过对它的读写 操作做为与kernel实体间进行通信的一种手段.也就是说可以通过修改/proc中的文件,来对当前kernel的

行为做出调整.那么我们可以通过调整 /proc/sys/vm/drop_caches来释放内存.操作如下:

[root@cluster /]# cat /proc/sys/vm/drop_caches 0

首先,/proc/sys/vm/drop_caches的值,默认为0

[root@cluster /]# sync

手动执行sync命令(描述:sync 命令运行 sync 子例程。如果必须停止系统,则运行 sync 命令以确保文件系统的完整性。sync 命令将所有未写的系统缓冲区写到磁盘中,包含已修改的 i-node、已延迟的块 I/O 和读写映射文件)

[root@server test]# echo 3 > /proc/sys/vm/drop_caches

[root@server test]# cat /proc/sys/vm/drop_caches 3

将/proc/sys/vm/drop_caches值设为3

[root@server test]# free -m

total used free shared buffers cached

Mem: 249 66 182 0 0 11

-/+ buffers/cache: 55 194

Swap: 511 0 511

再来运行free命令,发现现在的used为66MB,free为182MB,buffers为0MB,cached为11MB.那么有效的释放了buffer和cache.

有关/proc/sys/vm/drop_caches的用法在下面进行了说明

/proc/sys/vm/drop_caches (since Linux 2.6.16)

Writing to this file causes the kernel to drop clean caches,

dentries and inodes from memory, causing that memory to become free.

To free pagecache, use echo 1 > /proc/sys/vm/drop_caches;

to free dentries and inodes, use echo 2 > /proc/sys/vm/drop_caches;

to free pagecache, dentries and inodes, use echo 3 > /proc/sys/vm/drop_caches.

Because this is a non-destructive operation and dirty objects

Linux调整swap大小和swap性能优化

机器上的swap空间太大,但是由于硬盘io较慢,所以决定做一些优化:调小swap,然后尽可能的\"禁用\"swap。

1、先“df -h”和“fdisk - l”命令查看一下当前分区情况

/dev/mapper/vg_\"hostname\"-lv_swap就是swap分区,为2G。swap分区亦可用free命令查看到。

 2、用swapoff命令关闭交换分区(或者用swapoff -a): # swapoff /dev/mapper/vg_\"hostname\"-lv_swap 然后用free命令检查下swap是否变为0了。

 3、用lvreduce命令把swap分区减小4096M:

# lvreduce -L -4096M /dev/mapper/vg_\"hostname\"-lv_swap 输入y,确定,看到提示swap减小了4GB。

 4、重新把/dev/mapper/vg_\"hostname\"-lv_swap设置为swap分区: # mkswap /dev/mapper/vg_\"hostname\"-lv_swap

 5、swapon开启swap分区:

# swapon /dev/mapper/vg_\"hostname\"-lv_swap 然后用free命令检查下swap是否减小了4GB

 6、把多余的空间挂载到/root目录 # vgdisplay 显示空闲的磁盘 4GB

#lvextend -L +4G /dev/mapper/VolGroup-lv_root

 7、激活大小

#resize2fs -p /dev/mapper/VolGroup-lv_root

 

8、df -h查看大小 9、尽可能\"禁止\"使用swap

# echo 'vm.swappiness=10'>> /etc/sysctl.conf

注:(为什么要尽可能避免使用swap? # cat /proc/sys/vm/swappiness,值默认值

是60, swappiness=0的时候表示最大限度使用物理内存,然后才是 swap空间,swappiness=100的时候表示积极的使用swap分区,并且把内存上的数据及时的搬运到swap空间里面。现在服务器的内存动不 动就是上百G,或者云主机架构,机器io太慢会极大的影响机器性能,所以我们可以把这个参数值设置的低一些,让操作系统尽可能的使用物理内存,降低系统对 swap的使用,从而提高系统的性能。另:在大内存服务器中我们需要设置这个值为0,尤其是在Mysql服务器上)

临时修改方案:

# sysctl vm.swappiness=10 vm.swappiness = 10

# cat /proc/sys/vm/swappiness 10

这里我们的修改已经生效,但是如果我们重启了系统,又会变成60.

永久修改方案:

在/etc/sysctl.conf 文件里添加如下参数: vm.swappiness=10 或者:

# echo 'vm.swappiness=10'>> /etc/sysctl.conf

因篇幅问题不能全部显示,请点此查看更多更全内容

Copyright © 2019- yrrf.cn 版权所有 赣ICP备2024042794号-2

违法及侵权请联系:TEL:199 1889 7713 E-MAIL:2724546146@qq.com

本站由北京市万商天勤律师事务所王兴未律师提供法律服务