swap空間對于操作系統(tǒng)來說比較重要,當(dāng)我們使用操作系統(tǒng)的時候,如果系統(tǒng)內(nèi)存不足,常常會將一部分內(nèi)存數(shù)據(jù)頁進行swap操作,以解決臨時的內(nèi)存困境。swap空間由磁盤提供,對于高并發(fā)場景下,swap空間的使用會嚴(yán)重降低系統(tǒng)性能,因為它引入了磁盤IO操作。
在Linux中,提供了free命令來查詢操作系統(tǒng)的內(nèi)存使用情況,free 命令的結(jié)果中也包含了swap相關(guān)的情況,例如下面的結(jié)果中:
[root@VM-0-14-centos ~]# free -ht
total used free shared buff/cache available
Mem: 1.8G 1.3G 72M 692K 433M 283M
Swap: 0B 0B 0B
Total: 1.8G 1.3G 72M
我們可以看到swap的值都是0,說明當(dāng)前的內(nèi)存是沒有配置swap空間的,目前的操作系統(tǒng)的內(nèi)存是足夠的,通常情況下swap一行的used列應(yīng)該是0B比較好,它證明你的操作系統(tǒng)內(nèi)存充足,沒有發(fā)生swap空間的交換操作。
實時查看swap的使用
Linux中還為我們封裝了vmstat這個命令來查看系統(tǒng)的相關(guān)性能指標(biāo),其中也包含swap空間,其中和swap有關(guān)的指標(biāo)是si和so,分別代表swap in和swap out,我們看看vmstat的執(zhí)行結(jié)果:
[root@VM-0-14-centos ~]# vmstat
procs -----------memory---------- ---swap-- -----io---- -system-- ------cpu-----
r b swpd free buff cache si so bi bo in cs us sy id wa st
4 0 0 73712 84464 362016 0 0 7 26 7 1 1 1 98 0 0
查看執(zhí)行進程占用swap的情況
在Linux操作系統(tǒng)中,/proc/pid/smaps這個文件記錄了當(dāng)前進程所對應(yīng)的內(nèi)存映像信息,這個信息對于查詢指定進程的swap使用情況很有幫助。下面以一個Redis實例進行說明:
[root@VM-0-14-centos ~]# ps -ef|grep redis
root 1711 1 0 Jul20 ? 00:20:15 src/redis-server 127.0.0.1:21243
root 2370 1 0 Jul20 ? 00:20:18 src/redis-server 127.0.0.1:21244
root 2371 1 0 Jul20 ? 00:20:13 src/redis-server 127.0.0.1:21263
root 7815 5781 0 23:39 pts/3 00:00:00 grep --color=auto redis
root 14804 1 0 Jul20 ? 00:20:39 redis-server *:6379
我們以14804這個redis進程為例
[root@VM-0-14-centos ~]# cat /proc/14804/smaps | grep Swap
Swap: 0 kB
Swap: 0 kB
Swap: 0 kB
.....
Swap: 0 kB
Swap: 0 kB
Swap: 0 kB
通常情況下,Linux服務(wù)器不會等到所有物理內(nèi)存都被使用完再使用swap空間,它引入swapiness這個變量來決定操作系統(tǒng)使用swap空間的傾向程度,它的取值是0~100,值越大,表示操作系統(tǒng)使用swap的可能性越高,反之則越低。swapiness變量值存在于系統(tǒng)配置文件/proc/sys/vm/swappiness 和/etc/sysctl.conf中,其前面的文件在重啟之后,就失效了,只有將這個值寫入后面的文件,才能長久的保存下去。
[root@VM-0-14-centos ~]# cat /proc/sys/vm/swappiness
30
寫入/etc/sysctl.conf的方法如下:
echo vm.swappiness={value} >> /etc/sysctl.conf
Redis在不同版本下,對于swapiness的建議配置也不一樣,通常情況下,swapness的值可以設(shè)置為:0、1、60、100這幾個。
其中:
設(shè)置為60是默認(rèn)值,
設(shè)置為100則操作系統(tǒng)會主動使用swap空間,
設(shè)置成為0的話,在Linux3.4以及更早的Linux版本中,內(nèi)存不夠時,傾向使用swap而不是OOM killer,在Linux3.5以及之后的版本中,傾向使用OOM Killer而不是swap空間
設(shè)置為1的話,在Linux3.5以及后續(xù)版本中,內(nèi)存不夠用的時候,傾向于使用swap空間,而不是OOM Killer
多說一句:OOM kill是指Linux發(fā)現(xiàn)操作系統(tǒng)不可用的時候,也就是Out Of Memory的時候,強制殺死一些非內(nèi)核進程,來保證有足夠的可用內(nèi)存進行分配。一般OOM的日志記錄在系統(tǒng)日志/var/log/message中
以上就是Redis swap空間的使用示例的詳細內(nèi)容,更多關(guān)于Redis swap空間的資料請關(guān)注腳本之家其它相關(guān)文章!
您可能感興趣的文章:- 一次關(guān)于Redis內(nèi)存詭異增長的排查過程實戰(zhàn)記錄
- 淺談redis內(nèi)存數(shù)據(jù)的持久化方式
- Redis教程(十一):虛擬內(nèi)存介紹
- redis 限制內(nèi)存使用大小的實現(xiàn)
- redis內(nèi)存空間效率問題的深入探究